add mark command
This commit is contained in:
parent
881a9081a8
commit
5da58c669c
1 changed files with 98 additions and 0 deletions
98
commands/msg/mark.go
Normal file
98
commands/msg/mark.go
Normal file
|
@ -0,0 +1,98 @@
|
||||||
|
package msg
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"git.sr.ht/~sircmpwn/aerc/widgets"
|
||||||
|
"git.sr.ht/~sircmpwn/getopt"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Mark struct{}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
register(Mark{})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (Mark) Aliases() []string {
|
||||||
|
return []string{"mark", "unmark"}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (Mark) Complete(aerc *widgets.Aerc, args []string) []string {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (Mark) Execute(aerc *widgets.Aerc, args []string) error {
|
||||||
|
h := newHelper(aerc)
|
||||||
|
selected, err := h.msgProvider.SelectedMessage()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
store, err := h.store()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
opts, _, err := getopt.Getopts(args, "atv")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
var all bool
|
||||||
|
var toggle bool
|
||||||
|
var visual bool
|
||||||
|
for _, opt := range opts {
|
||||||
|
switch opt.Option {
|
||||||
|
case 'a':
|
||||||
|
all = true
|
||||||
|
case 'v':
|
||||||
|
visual = true
|
||||||
|
case 't':
|
||||||
|
toggle = true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch args[0] {
|
||||||
|
case "mark":
|
||||||
|
if all && visual {
|
||||||
|
return fmt.Errorf("-a and -v are mutually exclusive")
|
||||||
|
}
|
||||||
|
|
||||||
|
var modFunc func(uint32)
|
||||||
|
if toggle {
|
||||||
|
modFunc = store.ToggleMark
|
||||||
|
} else {
|
||||||
|
modFunc = store.Mark
|
||||||
|
}
|
||||||
|
if all {
|
||||||
|
uids := store.Uids()
|
||||||
|
for _, uid := range uids {
|
||||||
|
modFunc(uid)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
} else if visual {
|
||||||
|
store.ToggleVisualMark()
|
||||||
|
return nil
|
||||||
|
} else {
|
||||||
|
modFunc(selected.Uid)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
case "unmark":
|
||||||
|
if visual {
|
||||||
|
return fmt.Errorf("visual mode not suported for this command")
|
||||||
|
}
|
||||||
|
|
||||||
|
if all && toggle {
|
||||||
|
uids := store.Uids()
|
||||||
|
for _, uid := range uids {
|
||||||
|
store.ToggleMark(uid)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
} else if all && !toggle {
|
||||||
|
store.ClearVisualMark()
|
||||||
|
return nil
|
||||||
|
} else {
|
||||||
|
store.Unmark(selected.Uid)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil // never reached
|
||||||
|
}
|
Loading…
Reference in a new issue