git-annex/Annex/Version.hs

60 lines
1.2 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
2011-10-05 20:02:51 +00:00
import Common.Annex
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", "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
setVersion :: Version -> Annex ()
setVersion = setConfig versionField
removeVersion :: Annex ()
removeVersion = unsetConfig versionField