From 1939949fcdd5d540fd20ead79b9c5d27e85e8f9d Mon Sep 17 00:00:00 2001 From: Sascha Date: Sun, 9 May 2021 11:14:45 +0200 Subject: CLI: Add non-interactive option to interactive commands (#651) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Add option to skip the AvatarURL input request Using an empty string for the avatar cli flag e.g. `git-bug user create -a ""` will still result in a prompt. As the avatar URL is an optional option, it should be possible to skip asking for it entirely. Otherwise automated user creation via a script must make use of pipe hacks. * Add global --non-interactive cmdline option * Replace --skipAvatar for --non-interactive option * Cmd BugAdd: respect non-interactive option * Cmd bridge configure: respect non-interactive opt * Cmd CommentAdd: respect non-interactive option * Cmd CommentEdit: respect non-interactive option * Cmd TermUI: respect non-interactive option * Cmd TitleEdit: respect non-interactive option * Remove global non-interactive option * Cmd UserCreate: Use local non-interactive option * Cmd BugAdd: Use local non-interactive option * Cmd BridgeConfigure: Use local non-interactive option * Cmd CommentAdd: Use local non-interactive option * Cmd CommentEdit: Use local non-interactive option * Cmd TermUI: Drop non-interactive option It should be obviouse that the termui is an interactive command. * Cmd TitleEdit: Use local non-interactive option * Update docs * Bridge GitHub: respect non-interactive option * Bridge GitLab: respect non-interactive option * Bridge Jira: respect non-interactive and token opt * Fix failing compilation * Bridge launchpad: respect non-interactive option * bridge: isNonInteractive --> interactive Co-authored-by: Michael Muré --- commands/add.go | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'commands/add.go') diff --git a/commands/add.go b/commands/add.go index ad3b164b..3a28c424 100644 --- a/commands/add.go +++ b/commands/add.go @@ -8,9 +8,10 @@ import ( ) type addOptions struct { - title string - message string - messageFile string + title string + message string + messageFile string + nonInteractive bool } func newAddCommand() *cobra.Command { @@ -36,6 +37,7 @@ func newAddCommand() *cobra.Command { "Provide a message to describe the issue") flags.StringVarP(&options.messageFile, "file", "F", "", "Take the message from the given file. Use - to read the message from the standard input") + flags.BoolVar(&options.nonInteractive, "non-interactive", false, "Do not ask for user input") return cmd } @@ -49,7 +51,7 @@ func runAdd(env *Env, opts addOptions) error { } } - if opts.messageFile == "" && (opts.message == "" || opts.title == "") { + if !opts.nonInteractive && opts.messageFile == "" && (opts.message == "" || opts.title == "") { opts.title, opts.message, err = input.BugCreateEditorInput(env.backend, opts.title, opts.message) if err == input.ErrEmptyTitle { -- cgit