diff options
author | Roman Smrž <roman.smrz@seznam.cz> | 2023-11-17 20:28:44 +0100 |
---|---|---|
committer | Roman Smrž <roman.smrz@seznam.cz> | 2023-11-18 20:03:24 +0100 |
commit | 88a7bb50033baab3c2d0eed7e4be868e8966300a (patch) | |
tree | 861631a1e5e7434b92a8f19ef8f7b783790e1d1f /src/Set.hs | |
parent | 5b908c86320ee73f2722c85f8a47fa03ec093c6c (diff) |
Split to library and executable parts
Diffstat (limited to 'src/Set.hs')
-rw-r--r-- | src/Set.hs | 78 |
1 files changed, 0 insertions, 78 deletions
diff --git a/src/Set.hs b/src/Set.hs deleted file mode 100644 index 263103f..0000000 --- a/src/Set.hs +++ /dev/null @@ -1,78 +0,0 @@ -module Set ( - Set, - - emptySet, - loadSet, - storeSetAdd, - - fromSetBy, -) where - -import Control.Arrow -import Control.Monad.IO.Class - -import Data.Function -import Data.List -import Data.Map (Map) -import Data.Map qualified as M -import Data.Maybe -import Data.Ord - -import Storage -import Storage.Merge -import Util - -data Set a = Set [Stored (SetItem (Component a))] - -data SetItem a = SetItem - { siPrev :: [Stored (SetItem a)] - , siItem :: [Stored a] - } - -instance Storable a => Storable (SetItem a) where - store' x = storeRec $ do - mapM_ (storeRef "PREV") $ siPrev x - mapM_ (storeRef "item") $ siItem x - - load' = loadRec $ SetItem - <$> loadRefs "PREV" - <*> loadRefs "item" - -instance Mergeable a => Mergeable (Set a) where - type Component (Set a) = SetItem (Component a) - mergeSorted = Set - toComponents (Set items) = items - - -emptySet :: Set a -emptySet = Set [] - -loadSet :: Mergeable a => Ref -> Set a -loadSet = mergeSorted . (:[]) . wrappedLoad - -storeSetAdd :: (Mergeable a, MonadIO m) => Storage -> a -> Set a -> m (Set a) -storeSetAdd st x (Set prev) = Set . (:[]) <$> wrappedStore st SetItem - { siPrev = prev - , siItem = toComponents x - } - - -fromSetBy :: forall a. Mergeable a => (a -> a -> Ordering) -> Set a -> [a] -fromSetBy cmp (Set heads) = sortBy cmp $ map merge $ groupRelated items - where - -- gather all item components in the set history - items :: [Stored (Component a)] - items = walkAncestors (siItem . fromStored) heads - - -- map individual roots to full root set as joined in history of individual items - rootToRootSet :: Map RefDigest [RefDigest] - rootToRootSet = foldl' (\m rs -> foldl' (\m' r -> M.insertWith (\a b -> uniq $ sort $ a++b) r rs m') m rs) M.empty $ - map (map (refDigest . storedRef) . storedRoots) items - - -- get full root set for given item component - storedRootSet :: Stored (Component a) -> [RefDigest] - storedRootSet = fromJust . flip M.lookup rootToRootSet . refDigest . storedRef . head . storedRoots - - -- group components of single item, i.e. components sharing some root - groupRelated :: [Stored (Component a)] -> [[Stored (Component a)]] - groupRelated = map (map fst) . groupBy ((==) `on` snd) . sortBy (comparing snd) . map (id &&& storedRootSet) |