978d35d356
Apply GoDoc comment policy (comments for humans should have a space after the //; machine-readable comments shouldn't) Use strings.ReplaceAll instead of strings.Replace when appropriate Remove if/else chains by replacing them with switches Use short assignment/increment notation Replace single case switches with if statements Combine else and if when appropriate Signed-off-by: Moritz Poldrack <moritz@poldrack.dev> Acked-by: Robin Jarry <robin@jarry.cc>
37 lines
722 B
Go
37 lines
722 B
Go
package commands
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"git.sr.ht/~rjarry/aerc/widgets"
|
|
"git.sr.ht/~sircmpwn/getopt"
|
|
)
|
|
|
|
type NewAccount struct{}
|
|
|
|
func init() {
|
|
register(NewAccount{})
|
|
}
|
|
|
|
func (NewAccount) Aliases() []string {
|
|
return []string{"new-account"}
|
|
}
|
|
|
|
func (NewAccount) Complete(aerc *widgets.Aerc, args []string) []string {
|
|
return nil
|
|
}
|
|
|
|
func (NewAccount) Execute(aerc *widgets.Aerc, args []string) error {
|
|
opts, _, err := getopt.Getopts(args, "t")
|
|
if err != nil {
|
|
return errors.New("Usage: new-account [-t]")
|
|
}
|
|
wizard := widgets.NewAccountWizard(aerc.Config(), aerc)
|
|
for _, opt := range opts {
|
|
if opt.Option == 't' {
|
|
wizard.ConfigureTemporaryAccount(true)
|
|
}
|
|
}
|
|
aerc.NewTab(wizard, "New account")
|
|
return nil
|
|
}
|