diff options
author | Joey Hess <joey@kitenet.net> | 2013-04-23 11:38:52 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2013-04-23 11:38:52 -0400 |
commit | e8b1ae6a5f74e6f9d562f8bef63f284f3881df79 (patch) | |
tree | 78fb28b01e47b331cc8cafc4ad12c8c2d2238025 /Config | |
parent | 4d376b47b7aa506c4f4a4c5ccc83ca2ef1aeacc2 (diff) |
rename module
Diffstat (limited to 'Config')
-rw-r--r-- | Config/Files.hs | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/Config/Files.hs b/Config/Files.hs new file mode 100644 index 000000000..357481ca6 --- /dev/null +++ b/Config/Files.hs @@ -0,0 +1,57 @@ +{- git-annex extra config files + - + - Copyright 2012 Joey Hess <joey@kitenet.net> + - + - Licensed under the GNU GPL version 3 or higher. + -} + +module Config.Files where + +import Common +import Utility.TempFile +import Utility.FreeDesktop + +{- ~/.config/git-annex/file -} +userConfigFile :: FilePath -> IO FilePath +userConfigFile file = do + dir <- userConfigDir + return $ dir </> "git-annex" </> file + +autoStartFile :: IO FilePath +autoStartFile = userConfigFile "autostart" + +{- Returns anything listed in the autostart file (which may not exist). -} +readAutoStartFile :: IO [FilePath] +readAutoStartFile = do + f <- autoStartFile + nub . lines <$> catchDefaultIO "" (readFile f) + +{- Adds a directory to the autostart file. -} +addAutoStartFile :: FilePath -> IO () +addAutoStartFile path = do + dirs <- readAutoStartFile + when (path `notElem` dirs) $ do + f <- autoStartFile + createDirectoryIfMissing True (parentDir f) + viaTmp writeFile f $ unlines $ dirs ++ [path] + +{- Removes a directory from the autostart file. -} +removeAutoStartFile :: FilePath -> IO () +removeAutoStartFile path = do + dirs <- readAutoStartFile + when (path `elem` dirs) $ do + f <- autoStartFile + createDirectoryIfMissing True (parentDir f) + viaTmp writeFile f $ unlines $ + filter (not . equalFilePath path) dirs + +{- The path to git-annex is written here; which is useful when cabal + - has installed it to some aweful non-PATH location. -} +programFile :: IO FilePath +programFile = userConfigFile "program" + +{- Returns a command to run for git-annex. -} +readProgramFile :: IO FilePath +readProgramFile = do + programfile <- programFile + catchDefaultIO "git-annex" $ readFile programfile |