36 lines
		
	
	
	
		
			1 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
	
		
			1 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
{- git-annex extra config files
 | 
						|
 -
 | 
						|
 - Copyright 2012-2019 Joey Hess <id@joeyh.name>
 | 
						|
 -
 | 
						|
 - Licensed under the GNU AGPL version 3 or higher.
 | 
						|
 -}
 | 
						|
 | 
						|
{-# OPTIONS_GHC -fno-warn-tabs #-}
 | 
						|
 | 
						|
module Config.Files where
 | 
						|
 | 
						|
import Utility.FreeDesktop
 | 
						|
import Utility.Exception
 | 
						|
 | 
						|
import System.FilePath
 | 
						|
 | 
						|
{- ~/.config/git-annex/file -}
 | 
						|
userConfigFile :: FilePath -> IO FilePath
 | 
						|
userConfigFile file = do
 | 
						|
	dir <- userConfigDir
 | 
						|
	return $ dir </> "git-annex" </> file
 | 
						|
 | 
						|
autoStartFile :: IO FilePath
 | 
						|
autoStartFile = userConfigFile "autostart"
 | 
						|
 | 
						|
{- The path to git-annex is written here; which is useful when something
 | 
						|
 - has installed it to some awful non-PATH location. -}
 | 
						|
programFile :: IO FilePath
 | 
						|
programFile = userConfigFile "program"
 | 
						|
 | 
						|
{- A .noannex file in a git repository prevents git-annex from
 | 
						|
 - initializing that repository. The content of the file is returned. -}
 | 
						|
noAnnexFileContent :: Maybe FilePath -> IO (Maybe String)
 | 
						|
noAnnexFileContent repoworktree = case repoworktree of
 | 
						|
	Nothing -> return Nothing
 | 
						|
	Just wt -> catchMaybeIO (readFile (wt </> ".noannex"))
 |