63 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
	
		
			1.6 KiB
			
		
	
	
	
		
			Haskell
		
	
	
	
	
	
{- common command-line options
 | 
						|
 -
 | 
						|
 - Copyright 2010-2011 Joey Hess <id@joeyh.name>
 | 
						|
 -
 | 
						|
 - Licensed under the GNU GPL version 3 or higher.
 | 
						|
 -}
 | 
						|
 | 
						|
module CmdLine.Option where
 | 
						|
 | 
						|
import Options.Applicative
 | 
						|
 | 
						|
import Common.Annex
 | 
						|
import CmdLine.Usage
 | 
						|
import CmdLine.GlobalSetter
 | 
						|
import qualified Annex
 | 
						|
import Types.Messages
 | 
						|
import Types.DeferredParse
 | 
						|
 | 
						|
-- Global options accepted by both git-annex and git-annex-shell sub-commands.
 | 
						|
commonGlobalOptions :: [GlobalOption]
 | 
						|
commonGlobalOptions =
 | 
						|
	[ globalFlag (setforce True)
 | 
						|
		( long "force" 
 | 
						|
		<> help "allow actions that may lose annexed data"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalFlag (setfast True)
 | 
						|
		( long "fast" <> short 'F'
 | 
						|
		<> help "avoid slow operations"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalFlag (Annex.setOutput QuietOutput)
 | 
						|
		( long "quiet" <> short 'q'
 | 
						|
		<> help "avoid verbose output"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalFlag (Annex.setOutput NormalOutput)
 | 
						|
		( long "verbose" <> short 'v'
 | 
						|
		<> help "allow verbose output (default)"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalFlag setdebug
 | 
						|
		( long "debug" <> short 'd'
 | 
						|
		<> help "show debug messages"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalFlag unsetdebug
 | 
						|
		( long "no-debug"
 | 
						|
		<> help "don't show debug messages"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	, globalSetter setforcebackend $ strOption
 | 
						|
		( long "backend" <> short 'b' <> metavar paramName
 | 
						|
		<> help "specify key-value backend to use"
 | 
						|
		<> hidden
 | 
						|
		)
 | 
						|
	]
 | 
						|
  where
 | 
						|
	setforce v = Annex.changeState $ \s -> s { Annex.force = v }
 | 
						|
	setfast v = Annex.changeState $ \s -> s { Annex.fast = v }
 | 
						|
	setforcebackend v = Annex.changeState $ \s -> s { Annex.forcebackend = Just v }
 | 
						|
	setdebug = Annex.changeGitConfig $ \c -> c { annexDebug = True }
 | 
						|
	unsetdebug = Annex.changeGitConfig $ \c -> c { annexDebug = False }
 |