1
0
mirror of https://git.sr.ht/~sircmpwn/aerc synced 2025-01-24 06:40:25 +01:00
aerc/commands/compose/attach.go
Reto Brunner 8ea86cea41 Get rid of the aerc.PushError(" " + $string) idiom
The individual callers should not be responsible for padding
2021-01-30 14:04:23 +01:00

57 lines
1.0 KiB
Go

package compose
import (
"fmt"
"os"
"strings"
"git.sr.ht/~sircmpwn/aerc/commands"
"git.sr.ht/~sircmpwn/aerc/widgets"
"github.com/mitchellh/go-homedir"
)
type Attach struct{}
func init() {
register(Attach{})
}
func (Attach) Aliases() []string {
return []string{"attach"}
}
func (Attach) Complete(aerc *widgets.Aerc, args []string) []string {
path := strings.Join(args, " ")
return commands.CompletePath(path)
}
func (Attach) Execute(aerc *widgets.Aerc, args []string) error {
if len(args) == 1 {
return fmt.Errorf("Usage: :attach <path>")
}
path := strings.Join(args[1:], " ")
path, err := homedir.Expand(path)
if err != nil {
aerc.PushError(err.Error())
return err
}
pathinfo, err := os.Stat(path)
if err != nil {
aerc.PushError(err.Error())
return err
} else if pathinfo.IsDir() {
aerc.PushError("Attachment must be a file, not a directory")
return nil
}
composer, _ := aerc.SelectedTab().(*widgets.Composer)
composer.AddAttachment(path)
aerc.PushSuccess(fmt.Sprintf("Attached %s", pathinfo.Name()))
return nil
}