From 00daa226f4c4ee6ae86264e069ba56c923f40977 Mon Sep 17 00:00:00 2001 From: Robin Jarry Date: Thu, 13 Oct 2022 12:52:21 +0200 Subject: commands: split open-link in separate file These two commands have virtually zero in common. Move open-link in its own file. Signed-off-by: Robin Jarry Tested-by: Inwit Acked-by: Moritz Poldrack --- commands/msgview/open-link.go | 41 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 41 insertions(+) create mode 100644 commands/msgview/open-link.go (limited to 'commands/msgview/open-link.go') diff --git a/commands/msgview/open-link.go b/commands/msgview/open-link.go new file mode 100644 index 00000000..d19dfae0 --- /dev/null +++ b/commands/msgview/open-link.go @@ -0,0 +1,41 @@ +package msgview + +import ( + "errors" + + "git.sr.ht/~rjarry/aerc/commands" + "git.sr.ht/~rjarry/aerc/lib" + "git.sr.ht/~rjarry/aerc/widgets" +) + +type OpenLink struct{} + +func init() { + register(OpenLink{}) +} + +func (OpenLink) Aliases() []string { + return []string{"open-link"} +} + +func (OpenLink) Complete(aerc *widgets.Aerc, args []string) []string { + mv := aerc.SelectedTabContent().(*widgets.MessageViewer) + if mv != nil { + if p := mv.SelectedMessagePart(); p != nil { + return commands.CompletionFromList(aerc, p.Links, args) + } + } + return nil +} + +func (OpenLink) Execute(aerc *widgets.Aerc, args []string) error { + if len(args) != 2 { + return errors.New("Usage: open-link ") + } + go func() { + if err := lib.XDGOpen(args[1]); err != nil { + aerc.PushError("open-link: " + err.Error()) + } + }() + return nil +} -- cgit