diff options
author | Drew DeVault <sir@cmpwn.com> | 2019-03-30 11:58:24 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2019-03-30 11:58:24 -0400 |
commit | 700dea23fa75f213af2f99449db994008eab9d21 (patch) | |
tree | fa142784bf4ccb6aba1cd2b8513228dd4b968b28 /commands/account/pipe.go | |
parent | 4465646fedc5dd3efa680a7cc8d06671350b75b9 (diff) | |
download | aerc-700dea23fa75f213af2f99449db994008eab9d21.tar.gz |
Implement :pipe
Diffstat (limited to 'commands/account/pipe.go')
-rw-r--r-- | commands/account/pipe.go | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/commands/account/pipe.go b/commands/account/pipe.go new file mode 100644 index 0000000..5693d4a --- /dev/null +++ b/commands/account/pipe.go @@ -0,0 +1,73 @@ +package account + +import ( + "bytes" + "errors" + "io" + "os/exec" + "time" + + "git.sr.ht/~sircmpwn/aerc2/widgets" + + "github.com/gdamore/tcell" + "github.com/mohamedattahri/mail" +) + +func init() { + register("pipe", Pipe) +} + +func Pipe(aerc *widgets.Aerc, args []string) error { + if len(args) < 2 { + return errors.New("Usage: :pipe <cmd> [args...]") + } + acct := aerc.SelectedAccount() + if acct == nil { + return errors.New("No account selected") + } + store := acct.Messages().Store() + msg := acct.Messages().Selected() + store.FetchBodies([]uint32{msg.Uid}, func(msg *mail.Message) { + cmd := exec.Command(args[1], args[2:]...) + pipe, err := cmd.StdinPipe() + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorRed, tcell.ColorWhite) + return + } + term, err := widgets.NewTerminal(cmd) + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorRed, tcell.ColorWhite) + return + } + host := widgets.NewTermHost(term, aerc.Config()) + name := msg.Subject() + if len(name) > 12 { + name = name[:12] + } + aerc.NewTab(host, args[1] + " <" + name) + term.OnClose = func(err error) { + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorRed, tcell.ColorWhite) + } else { + // TODO: Tab-specific status stacks + aerc.PushStatus("Process complete, press any key to close.", + 10*time.Second) + } + } + term.OnStart = func() { + go func() { + reader := bytes.NewBuffer(msg.Bytes()) + _, err := io.Copy(pipe, reader) + if err != nil { + aerc.PushStatus(" "+err.Error(), 10*time.Second). + Color(tcell.ColorRed, tcell.ColorWhite) + } + pipe.Close() + }() + } + }) + return nil +} |