git-annex/Annex/Version.hs

66 lines
1.4 KiB
Haskell
Raw Normal View History

2010-11-08 20:40:42 +00:00
{- git-annex repository versioning
-
- Copyright 2010,2013 Joey Hess <id@joeyh.name>
2010-11-08 20:40:42 +00:00
-
- Licensed under the GNU GPL version 3 or higher.
-}
{-# LANGUAGE CPP #-}
2011-10-04 04:40:47 +00:00
module Annex.Version where
2010-11-08 20:40:42 +00:00
import Annex.Common
import Config
import qualified Annex
2010-11-08 20:40:42 +00:00
type Version = String
defaultVersion :: Version
defaultVersion = "5"
latestVersion :: Version
latestVersion = "6"
supportedVersions :: [Version]
supportedVersions = ["5", "6"]
2010-11-08 20:40:42 +00:00
upgradableVersions :: [Version]
#ifndef mingw32_HOST_OS
upgradableVersions = ["0", "1", "2", "3", "4", "5"]
#else
upgradableVersions = ["2", "3", "4", "5"]
#endif
autoUpgradeableVersions :: [Version]
autoUpgradeableVersions = ["3", "4"]
versionField :: ConfigKey
versionField = annexConfig "version"
2010-11-08 20:40:42 +00:00
getVersion :: Annex (Maybe Version)
getVersion = annexVersion <$> Annex.getGitConfig
2010-11-08 20:40:42 +00:00
versionSupportsDirectMode :: Annex Bool
versionSupportsDirectMode = go <$> getVersion
where
go (Just "6") = False
go _ = True
versionSupportsUnlockedPointers :: Annex Bool
versionSupportsUnlockedPointers = go <$> getVersion
where
go (Just "6") = True
go _ = False
versionSupportsAdjustedBranch :: Annex Bool
versionSupportsAdjustedBranch = versionSupportsUnlockedPointers
versionUsesKeysDatabase :: Annex Bool
versionUsesKeysDatabase = versionSupportsUnlockedPointers
setVersion :: Version -> Annex ()
setVersion = setConfig versionField
removeVersion :: Annex ()
removeVersion = unsetConfig versionField