diff options
author | Drew DeVault <sir@cmpwn.com> | 2019-07-08 18:19:08 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-07-08 18:19:08 -0400 |
commit | 7ecc6f96de5864d76ea2a94123b11c9258791cc9 (patch) | |
tree | 338f4a6b747a67b0321cc746f8a7377ddc60af38 /commands | |
parent | c610c3cd9dd47c400e52c1858e987f5f32a7a45b (diff) |
Add :exec and :pipe -b(ackground)
Diffstat (limited to 'commands')
-rw-r--r-- | commands/exec.go | 45 | ||||
-rw-r--r-- | commands/msg/pipe.go | 61 |
2 files changed, 89 insertions, 17 deletions
diff --git a/commands/exec.go b/commands/exec.go new file mode 100644 index 0000000..72a563d --- /dev/null +++ b/commands/exec.go @@ -0,0 +1,45 @@ +package commands + +import ( + "errors" + "fmt" + "os/exec" + "time" + + "git.sr.ht/~sircmpwn/aerc/widgets" + + "github.com/gdamore/tcell" +) + +type ExecCmd struct{} + +func init() { + register(ExecCmd{}) +} + +func (_ ExecCmd) Aliases() []string { + return []string{"exec"} +} + +func (_ ExecCmd) Complete(aerc *widgets.Aerc, args []string) []string { + return nil +} + +func (_ ExecCmd) Execute(aerc *widgets.Aerc, args []string) error { + if len(args) < 2 { + return errors.New("Usage: exec [cmd...]") + } + cmd := exec.Command(args[1], args[2:]...) + go func() { + err := cmd.Run() + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorDefault, tcell.ColorRed) + } else { + aerc.PushStatus(fmt.Sprintf( + "%s: complete", args[0]), 10*time.Second). + Color(tcell.ColorDefault, tcell.ColorDefault) + } + }() + return nil +} diff --git a/commands/msg/pipe.go b/commands/msg/pipe.go index 949bc95..9001563 100644 --- a/commands/msg/pipe.go +++ b/commands/msg/pipe.go @@ -6,12 +6,15 @@ import ( "fmt" "io" "mime/quotedprintable" + "os/exec" "strings" - - "git.sr.ht/~sircmpwn/getopt" + "time" "git.sr.ht/~sircmpwn/aerc/commands" "git.sr.ht/~sircmpwn/aerc/widgets" + + "git.sr.ht/~sircmpwn/getopt" + "github.com/gdamore/tcell" ) type Pipe struct{} @@ -30,16 +33,19 @@ func (_ Pipe) Complete(aerc *widgets.Aerc, args []string) []string { func (_ Pipe) Execute(aerc *widgets.Aerc, args []string) error { var ( - pipeFull bool - pipePart bool + background bool + pipeFull bool + pipePart bool ) // TODO: let user specify part by index or preferred mimetype - opts, optind, err := getopt.Getopts(args, "mp") + opts, optind, err := getopt.Getopts(args, "bmp") if err != nil { return err } for _, opt := range opts { switch opt.Option { + case 'b': + background = true case 'm': if pipePart { return errors.New("-m and -p are mutually exclusive") @@ -69,17 +75,38 @@ func (_ Pipe) Execute(aerc *widgets.Aerc, args []string) error { } } + doTerm := func(reader io.Reader, name string) { + term, err := commands.QuickTerm(aerc, cmd, reader) + if err != nil { + aerc.PushError(" " + err.Error()) + return + } + aerc.NewTab(term, name) + } + + doExec := func(reader io.Reader) { + ecmd := exec.Command(cmd[0], cmd[1:]...) + err := ecmd.Run() + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorDefault, tcell.ColorRed) + } else { + aerc.PushStatus(fmt.Sprintf( + "%s: complete", args[0]), 10*time.Second). + Color(tcell.ColorDefault, tcell.ColorDefault) + } + } + if pipeFull { store := provider.Store() msg := provider.SelectedMessage() store.FetchFull([]uint32{msg.Uid}, func(reader io.Reader) { - term, err := commands.QuickTerm(aerc, cmd, reader) - if err != nil { - aerc.PushError(" " + err.Error()) - return + if background { + doExec(reader) + } else { + doTerm(reader, fmt.Sprintf( + "%s <%s", cmd[0], msg.Envelope.Subject)) } - name := cmd[0] + " <" + msg.Envelope.Subject - aerc.NewTab(term, name) }) } else if pipePart { p := provider.SelectedMessagePart() @@ -91,13 +118,13 @@ func (_ Pipe) Execute(aerc *widgets.Aerc, args []string) error { reader = quotedprintable.NewReader(reader) } - term, err := commands.QuickTerm(aerc, cmd, reader) - if err != nil { - aerc.PushError(" " + err.Error()) - return + if background { + doExec(reader) + } else { + name := fmt.Sprintf("%s <%s/[%d]", + cmd[0], p.Msg.Envelope.Subject, p.Index) + doTerm(reader, name) } - name := fmt.Sprintf("%s <%s/[%d]", cmd[0], p.Msg.Envelope.Subject, p.Index) - aerc.NewTab(term, name) }) } |