 0a4479b8ec
			
		
	
	
	
	
	0a4479b8ecghc 8 added backtraces on uncaught errors. This is great, but git-annex was using error in many places for a error message targeted at the user, in some known problem case. A backtrace only confuses such a message, so omit it. Notably, commands like git annex drop that failed due to eg, numcopies, used to use error, so had a backtrace. This commit was sponsored by Ethan Aubin.
		
			
				
	
	
		
			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
 | |
| 	giveup $ "cannot find git-annex program in PATH or in the location listed in " ++ f
 |