Newer
Older
Joey Hess
committed
{- git-annex repository differences
-
- Copyright 2015 Joey Hess <id@joeyh.name>
-
- Licensed under the GNU GPL version 3 or higher.
-}
module Types.Difference (
Difference(..),
Differences(..),
Joey Hess
committed
getDifferences,
differenceConfigKey,
differenceConfigVal,
hasDifference,
) where
Joey Hess
committed
import qualified Git
import qualified Git.Config
import Data.List
import Data.Maybe
import Data.Monoid
-- Describes differences from the v5 repository format.
--
-- The serialization is stored in difference.log, so avoid changes that
Joey Hess
committed
-- would break compatability.
--
-- Not breaking compatability is why a list of Differences is used, rather
Joey Hess
committed
-- than a sum type. With a sum type, adding a new field for some future
-- difference would serialize to a value that an older version could not
-- parse, even if that new field was not used. With the Differences list,
-- old versions can still parse it, unless the new Difference constructor
-- is used.
--
-- The constructors intentionally do not have parameters; this is to
-- ensure that any Difference that can be expressed is supported.
-- So, a new repository version would be Version6, rather than Version Int.
Joey Hess
committed
data Difference
= ObjectHashLower
| OneLevelObjectHash
| OneLevelBranchHash
deriving (Show, Read, Ord, Eq, Enum, Bounded)
Joey Hess
committed
data Differences
= Differences [Difference]
| UnknownDifferences
instance Eq Differences where
Differences a == Differences b = canon a == canon b
_ == _ = False -- UnknownDifferences cannot be equal
Joey Hess
committed
instance Monoid Differences where
mempty = Differences []
mappend (Differences l1) (Differences l2) = Differences (canon (l1 ++ l2))
Joey Hess
committed
mappend _ _ = UnknownDifferences
canon :: [Difference] -> [Difference]
canon = nub . sort
Joey Hess
committed
readDifferences :: String -> Differences
readDifferences = maybe UnknownDifferences Differences . readish
Joey Hess
committed
getDifferences :: Git.Repo -> Differences
getDifferences r = Differences $ catMaybes $
map getmaybe [minBound .. maxBound]
Joey Hess
committed
where
getmaybe d = case Git.Config.isTrue =<< Git.Config.getMaybe (differenceConfigKey d) r of
Just True -> Just d
_ -> Nothing
Joey Hess
committed
differenceConfigKey :: Difference -> String
differenceConfigKey ObjectHashLower = tunable "objecthashlower"
differenceConfigKey OneLevelObjectHash = tunable "objecthash1"
differenceConfigKey OneLevelBranchHash = tunable "branchhash1"
Joey Hess
committed
differenceConfigVal :: Difference -> String
differenceConfigVal _ = Git.Config.boolConfig True
Joey Hess
committed
tunable :: String -> String
tunable k = "annex.tune." ++ k
hasDifference :: (Difference -> Bool) -> Differences -> Bool
hasDifference f (Differences l) = any f l
hasDifference _ UnknownDifferences = False