diff options
author | Jeffas <dev@jeffas.io> | 2019-09-20 17:16:29 +0100 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-09-20 15:06:34 -0400 |
commit | 39307a6fa7e96641b822ed0a9acb75021dcf7fe9 (patch) | |
tree | 683aec09eb86e2077148a53429681aa39776449b /commands/msg/copy.go | |
parent | 3ec9fd216d9e3b38d1d5abb5fba24199185f7054 (diff) | |
download | aerc-39307a6fa7e96641b822ed0a9acb75021dcf7fe9.tar.gz |
Make commands join args with spaces
This patch ensures the following commands join their arguments with
spaces to make it easier to interact with:
- cf
- mkdir
- cd
- attach
- detach
- ct
- copy
- move
- save
Diffstat (limited to 'commands/msg/copy.go')
-rw-r--r-- | commands/msg/copy.go | 28 |
1 files changed, 15 insertions, 13 deletions
diff --git a/commands/msg/copy.go b/commands/msg/copy.go index d6b78d3d..48b296c4 100644 --- a/commands/msg/copy.go +++ b/commands/msg/copy.go @@ -2,6 +2,7 @@ package msg import ( "errors" + "strings" "time" "git.sr.ht/~sircmpwn/getopt" @@ -27,13 +28,13 @@ func (Copy) Complete(aerc *widgets.Aerc, args []string) []string { } func (Copy) Execute(aerc *widgets.Aerc, args []string) error { + if len(args) == 1 { + return errors.New("Usage: cp [-p] <folder>") + } opts, optind, err := getopt.Getopts(args, "p") if err != nil { return err } - if optind != len(args)-1 { - return errors.New("Usage: cp [-p] <folder>") - } var ( createParents bool ) @@ -53,16 +54,17 @@ func (Copy) Execute(aerc *widgets.Aerc, args []string) error { if err != nil { return err } - store.Copy([]uint32{msg.Uid}, args[optind], createParents, func( - msg types.WorkerMessage) { + store.Copy([]uint32{msg.Uid}, strings.Join(args[optind:], " "), + createParents, func( + msg types.WorkerMessage) { - switch msg := msg.(type) { - case *types.Done: - aerc.PushStatus("Messages copied.", 10*time.Second) - case *types.Error: - aerc.PushStatus(" "+msg.Error.Error(), 10*time.Second). - Color(tcell.ColorDefault, tcell.ColorRed) - } - }) + switch msg := msg.(type) { + case *types.Done: + aerc.PushStatus("Messages copied.", 10*time.Second) + case *types.Error: + aerc.PushStatus(" "+msg.Error.Error(), 10*time.Second). + Color(tcell.ColorDefault, tcell.ColorRed) + } + }) return nil } |