From 39307a6fa7e96641b822ed0a9acb75021dcf7fe9 Mon Sep 17 00:00:00 2001 From: Jeffas Date: Fri, 20 Sep 2019 17:16:29 +0100 Subject: 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 --- commands/msg/copy.go | 28 +++++++++++++++------------- commands/msg/move.go | 12 +++++++----- 2 files changed, 22 insertions(+), 18 deletions(-) (limited to 'commands/msg') diff --git a/commands/msg/copy.go b/commands/msg/copy.go index d6b78d3..48b296c 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] ") + } opts, optind, err := getopt.Getopts(args, "p") if err != nil { return err } - if optind != len(args)-1 { - return errors.New("Usage: cp [-p] ") - } 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 } diff --git a/commands/msg/move.go b/commands/msg/move.go index 2f8c61e..d7e1ea9 100644 --- a/commands/msg/move.go +++ b/commands/msg/move.go @@ -2,6 +2,7 @@ package msg import ( "errors" + "strings" "time" "git.sr.ht/~sircmpwn/getopt" @@ -27,13 +28,13 @@ func (Move) Complete(aerc *widgets.Aerc, args []string) []string { } func (Move) Execute(aerc *widgets.Aerc, args []string) error { + if len(args) == 1 { + return errors.New("Usage: mv [-p] ") + } opts, optind, err := getopt.Getopts(args, "p") if err != nil { return err } - if optind != len(args)-1 { - return errors.New("Usage: mv [-p] ") - } var ( createParents bool ) @@ -63,12 +64,13 @@ func (Move) Execute(aerc *widgets.Aerc, args []string) error { } store.Next() acct.Messages().Scroll() - store.Move([]uint32{msg.Uid}, args[optind], createParents, func( + joinedArgs := strings.Join(args[optind:], " ") + store.Move([]uint32{msg.Uid}, joinedArgs, createParents, func( msg types.WorkerMessage) { switch msg := msg.(type) { case *types.Done: - aerc.PushStatus("Message moved to "+args[optind], 10*time.Second) + aerc.PushStatus("Message moved to "+joinedArgs, 10*time.Second) case *types.Error: aerc.PushStatus(" "+msg.Error.Error(), 10*time.Second). Color(tcell.ColorDefault, tcell.ColorRed) -- cgit v1.2.3