![Joey Hess](/assets/img/avatar_default.png)
when a git repository is first being created. Clones will automatically notice that git-annex is in use and automatically perform a basic initalization. It's still recommended to run "git annex init" in any clones, to describe them.
40 lines
819 B
Haskell
40 lines
819 B
Haskell
{- git-annex command
|
|
-
|
|
- Copyright 2010 Joey Hess <joey@kitenet.net>
|
|
-
|
|
- Licensed under the GNU GPL version 3 or higher.
|
|
-}
|
|
|
|
module Command.Init where
|
|
|
|
import Control.Monad (when)
|
|
|
|
import Command
|
|
import qualified Annex
|
|
import UUID
|
|
import Messages
|
|
import Init
|
|
|
|
command :: [Command]
|
|
command = [standaloneCommand "init" paramDesc seek
|
|
"initialize git-annex with repository description"]
|
|
|
|
seek :: [CommandSeek]
|
|
seek = [withWords start]
|
|
|
|
start :: CommandStartWords
|
|
start ws = do
|
|
when (null description) $
|
|
error "please specify a description of this repository\n"
|
|
showStart "init" description
|
|
next $ perform description
|
|
where
|
|
description = unwords ws
|
|
|
|
perform :: String -> CommandPerform
|
|
perform description = do
|
|
initialize
|
|
g <- Annex.gitRepo
|
|
u <- getUUID g
|
|
describeUUID u description
|
|
next $ return True
|