summaryrefslogtreecommitdiff
path: root/Command/NumCopies.hs
blob: 804faff58c1ef28a780e258b57ca8e22a4001196 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
{- git-annex command
 -
 - Copyright 2014 Joey Hess <joey@kitenet.net>
 -
 - Licensed under the GNU GPL version 3 or higher.
 -}

module Command.NumCopies where

import Common.Annex
import qualified Annex
import Command
import Logs.NumCopies
import Types.Messages

def :: [Command]
def = [command "numcopies" paramNumber seek
	SectionSetup "configure desired number of copies"]

seek :: CommandSeek
seek = withWords start

start :: [String] -> CommandStart
start [] = startGet
start [s] = do
	case readish s of
		Nothing -> error $ "Bad number: " ++ s
		Just n
			| n > 0 -> startSet n
			| n == 0 -> ifM (Annex.getState Annex.force)
				( startSet n
				, error "Setting numcopies to 0 is very unsafe. You will lose data! If you really want to do that, specify --force."
				)
			| otherwise -> error "Number cannot be negative!"
start _ = error "Specify a single number."

startGet :: CommandStart
startGet = next $ next $ do
	Annex.setOutput QuietOutput
	v <- getGlobalNumCopies
	case v of
		Just n -> liftIO $ putStrLn $ show n
		Nothing -> do
			liftIO $ putStrLn $ "global numcopies is not set"
			old <- annexNumCopies <$> Annex.getGitConfig
			case old of
				Nothing -> liftIO $ putStrLn "(default is 1)"
				Just n -> liftIO $ putStrLn $ "(deprecated git config annex.numcopies is set to " ++ show n ++ " locally)"
	return True

startSet :: Int -> CommandStart
startSet n = do
	showStart "numcopies" (show n)
	next $ next $ do
		setGlobalNumCopies n
		return True