From c2774dcf23d94a187f6679395e373c6fa1c627e1 Mon Sep 17 00:00:00 2001 From: Michael Muré Date: Sun, 15 Jul 2018 09:26:11 +0200 Subject: add a "comment" command --- commands/commands.go | 9 ++++--- commands/comment.go | 73 ++++++++++++++++++++++++++++++++++++++++++++++++++++ commands/ls.go | 6 ++--- commands/new.go | 5 ++-- commands/pull.go | 4 +-- commands/push.go | 4 +-- 6 files changed, 87 insertions(+), 14 deletions(-) create mode 100644 commands/comment.go diff --git a/commands/commands.go b/commands/commands.go index 7c4e3ab9..faca02ab 100644 --- a/commands/commands.go +++ b/commands/commands.go @@ -23,8 +23,9 @@ func (cmd *Command) Run(repo repository.Repo, args []string) error { // CommandMap defines all of the available (sub)commands. var CommandMap = map[string]*Command{ - "ls": lsCmd, - "new": newCmd, - "pull": pullCmd, - "push": pushCmd, + "comment": commentCmd, + "ls": lsCmd, + "new": newCmd, + "pull": pullCmd, + "push": pushCmd, } diff --git a/commands/comment.go b/commands/comment.go new file mode 100644 index 00000000..27908793 --- /dev/null +++ b/commands/comment.go @@ -0,0 +1,73 @@ +package commands + +import ( + "errors" + "flag" + "fmt" + "github.com/MichaelMure/git-bug/bug" + "github.com/MichaelMure/git-bug/bug/operations" + "github.com/MichaelMure/git-bug/commands/input" + "github.com/MichaelMure/git-bug/repository" +) + +var commentFlagSet = flag.NewFlagSet("comment", flag.ExitOnError) + +var ( + commentMessageFile = commentFlagSet.String("F", "", "Take the message from the given file. Use - to read the message from the standard input") + commentMessage = commentFlagSet.String("m", "", "Provide the new message from the command line") +) + +func runComment(repo repository.Repo, args []string) error { + commentFlagSet.Parse(args) + args = commentFlagSet.Args() + + var err error + + if len(args) == 0 { + return errors.New("No bug id provided") + } + if len(args) > 1 { + return errors.New("Only accepting one bug id is supported") + } + + prefix := args[0] + + if *commentMessageFile != "" && *commentMessage == "" { + *commentMessage, err = input.FromFile(*commentMessageFile) + if err != nil { + return err + } + } + if *commentMessageFile == "" && *commentMessage == "" { + *commentMessage, err = input.LaunchEditor(repo, messageFilename) + if err != nil { + return err + } + } + + author, err := bug.GetUser(repo) + if err != nil { + return err + } + + bug, err := bug.FindBug(repo, prefix) + if err != nil { + return err + } + + addCommentOp := operations.NewAddCommentOp(author, *commentMessage) + + bug.Append(addCommentOp) + + err = bug.Commit(repo) + + return err +} + +var commentCmd = &Command{ + Usage: func(arg0 string) { + fmt.Printf("Usage: %s comment [