and ignore any such relative paths in the file This was a reversion caused by the relative path changes in 5.20150113.
		
			
				
	
	
		
			83 lines
		
	
	
	
		
			2.3 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
	
		
			2.3 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
{- git-annex extra config files
 | 
						|
 -
 | 
						|
 - Copyright 2012 Joey Hess <id@joeyh.name>
 | 
						|
 -
 | 
						|
 - Licensed under the GNU GPL version 3 or higher.
 | 
						|
 -}
 | 
						|
 | 
						|
{-# OPTIONS_GHC -fno-warn-tabs #-}
 | 
						|
 | 
						|
module Config.Files where
 | 
						|
 | 
						|
import Common
 | 
						|
import Utility.Tmp
 | 
						|
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
 | 
						|
	filter valid . nub . map dropTrailingPathSeparator . lines
 | 
						|
		<$> catchDefaultIO "" (readFile f)
 | 
						|
  where
 | 
						|
	-- Ignore any relative paths; some old buggy versions added eg "."
 | 
						|
	valid = isAbsolute
 | 
						|
 | 
						|
modifyAutoStartFile :: ([FilePath] -> [FilePath]) -> IO ()
 | 
						|
modifyAutoStartFile func = do
 | 
						|
	dirs <- readAutoStartFile
 | 
						|
	let dirs' = nubBy equalFilePath $ func dirs
 | 
						|
	when (dirs' /= dirs) $ do
 | 
						|
		f <- autoStartFile
 | 
						|
		createDirectoryIfMissing True (parentDir f)
 | 
						|
		viaTmp writeFile f $ unlines dirs'
 | 
						|
 | 
						|
{- Adds a directory to the autostart file. If the directory is already
 | 
						|
 - present, it's moved to the top, so it will be used as the default
 | 
						|
 - when opening the webapp. -}
 | 
						|
addAutoStartFile :: FilePath -> IO ()
 | 
						|
addAutoStartFile path = do
 | 
						|
	path' <- absPath path
 | 
						|
	modifyAutoStartFile $ (:) path'
 | 
						|
 | 
						|
{- Removes a directory from the autostart file. -}
 | 
						|
removeAutoStartFile :: FilePath -> IO ()
 | 
						|
removeAutoStartFile path = do
 | 
						|
	path' <- absPath path
 | 
						|
	modifyAutoStartFile $
 | 
						|
		filter (not . equalFilePath path')
 | 
						|
 | 
						|
{- The path to git-annex is written here; which is useful when cabal
 | 
						|
 - has installed it to some awful non-PATH location. -}
 | 
						|
programFile :: IO FilePath
 | 
						|
programFile = userConfigFile "program"
 | 
						|
 | 
						|
{- Returns a command to run for git-annex. -}
 | 
						|
readProgramFile :: IO FilePath
 | 
						|
readProgramFile = do
 | 
						|
	programfile <- programFile
 | 
						|
	p <- catchDefaultIO cmd $ 
 | 
						|
		fromMaybe cmd . headMaybe . lines <$> readFile programfile
 | 
						|
	ifM (inPath p)
 | 
						|
		( return p
 | 
						|
		, ifM (inPath cmd)
 | 
						|
			( return cmd
 | 
						|
			, cannotFindProgram
 | 
						|
			)
 | 
						|
		)
 | 
						|
  where
 | 
						|
	cmd = "git-annex"
 | 
						|
 | 
						|
cannotFindProgram :: IO a
 | 
						|
cannotFindProgram = do
 | 
						|
	f <- programFile
 | 
						|
	error $ "cannot find git-annex program in PATH or in the location listed in " ++ f
 |