From acc9a6f3a6df2961c3ae44352216d915cb9b5315 Mon Sep 17 00:00:00 2001 From: Michael Muré Date: Sat, 10 Sep 2022 11:09:19 +0200 Subject: commands: reorg into different packages --- commands/bug/bug_comment_add.go | 80 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 80 insertions(+) create mode 100644 commands/bug/bug_comment_add.go (limited to 'commands/bug/bug_comment_add.go') diff --git a/commands/bug/bug_comment_add.go b/commands/bug/bug_comment_add.go new file mode 100644 index 00000000..b676db3a --- /dev/null +++ b/commands/bug/bug_comment_add.go @@ -0,0 +1,80 @@ +package bugcmd + +import ( + "github.com/spf13/cobra" + + "github.com/MichaelMure/git-bug/commands/bug/select" + "github.com/MichaelMure/git-bug/commands/completion" + "github.com/MichaelMure/git-bug/commands/execenv" + "github.com/MichaelMure/git-bug/commands/input" + "github.com/MichaelMure/git-bug/util/text" +) + +type bugCommentNewOptions struct { + messageFile string + message string + nonInteractive bool +} + +func newBugCommentNewCommand() *cobra.Command { + env := execenv.NewEnv() + options := bugCommentNewOptions{} + + cmd := &cobra.Command{ + Use: "new [BUG_ID]", + Short: "Add a new comment to a bug", + PreRunE: execenv.LoadBackendEnsureUser(env), + RunE: execenv.CloseBackend(env, func(cmd *cobra.Command, args []string) error { + return runBugCommentNew(env, options, args) + }), + ValidArgsFunction: completion.Bug(env), + } + + flags := cmd.Flags() + flags.SortFlags = false + + flags.StringVarP(&options.messageFile, "file", "F", "", + "Take the message from the given file. Use - to read the message from the standard input") + + flags.StringVarP(&options.message, "message", "m", "", + "Provide the new message from the command line") + flags.BoolVar(&options.nonInteractive, "non-interactive", false, "Do not ask for user input") + + return cmd +} + +func runBugCommentNew(env *execenv.Env, opts bugCommentNewOptions, args []string) error { + b, args, err := _select.ResolveBug(env.Backend, args) + if err != nil { + return err + } + + if opts.messageFile != "" && opts.message == "" { + opts.message, err = input.BugCommentFileInput(opts.messageFile) + if err != nil { + return err + } + } + + if opts.messageFile == "" && opts.message == "" { + if opts.nonInteractive { + env.Err.Println("No message given. Use -m or -F option to specify a message. Aborting.") + return nil + } + opts.message, err = input.BugCommentEditorInput(env.Backend, "") + if err == input.ErrEmptyMessage { + env.Err.Println("Empty message, aborting.") + return nil + } + if err != nil { + return err + } + } + + _, _, err = b.AddComment(text.Cleanup(opts.message)) + if err != nil { + return err + } + + return b.Commit() +} -- cgit