module Cmd.Commit ( commitPkgs, ) where import Common import Common.System import Git import Package import Prompt -- FIXME reject if nvr ahead of newer branch -- FIXME use branches after all? -- FIXME handle multiline changelog entries with "-m description" -- FIXME --undo last change: eg undo accidential --amend commitPkgs :: Maybe CommitOpt -> Bool -> Bool -> [String] -> IO () commitPkgs mopt firstLine notstaged args = do when (isJust mopt && firstLine) $ error' "--first-line cannot be used with other commit msg options" if null args then commitPkg "." else mapM_ commitPkg args where commitPkg :: FilePath -> IO () commitPkg path = withExistingDirectory path $ unlessM isGitDirClean $ do getPackageName path >>= putPkgHdr opts <- case mopt of Just opt -> return $ case opt of CommitMsg msg -> ["-m", msg] -- FIXME reject amend if already pushed CommitAmend -> ["--amend", "--no-edit"] Nothing -> do changelog <- do spec <- findSpecfile clog <- lines <$> cleanChangelog spec case clog of [] -> readCommitMsg [msg] -> putStrLn msg >> return msg msgs -> if firstLine then return $ removePrefix "- " $ head msgs else do diff <- git "diff" ["-U0", "HEAD"] let newlogs = filter (\c -> ("+- " ++ c) `elem` lines diff) clog case newlogs of [] -> putStrLn diff >> readCommitMsg [msg] -> putStrLn msg >> return (removePrefix "- " msg) _ -> mapM_ putStrLn newlogs >> readCommitMsg return ["-m", changelog] git_ "commit" $ ["-a" | notstaged] ++ opts readCommitMsg :: IO String readCommitMsg = do tty <- isTty if tty then do clog <- prompt "\nPlease input the commit message" if null clog then readCommitMsg else return clog else error' "please input commit message in a terminal"