aerc/commands/msg/mark.go
Koni Marti 117f99e187 mark: (un)mark message threads
Mark or unmark the shown message threads. Threads must be available in the
message store. Use the -T option for the mark or unmark commands. Can be
used in combination with the toggle flag (-t).

Signed-off-by: Koni Marti <koni.marti@gmail.com>
Acked-by: Robin Jarry <robin@jarry.cc>
2022-08-22 09:30:37 +02:00

138 lines
2.4 KiB
Go

package msg
import (
"fmt"
"git.sr.ht/~rjarry/aerc/widgets"
"git.sr.ht/~sircmpwn/getopt"
)
type Mark struct{}
func init() {
register(Mark{})
}
func (Mark) Aliases() []string {
return []string{"mark", "unmark", "remark"}
}
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
}
marker := store.Marker()
opts, _, err := getopt.Getopts(args, "atvVT")
if err != nil {
return err
}
var all bool
var toggle bool
var visual bool
var clearVisual bool
var thread bool
for _, opt := range opts {
switch opt.Option {
case 'a':
all = true
case 'v':
visual = true
clearVisual = true
case 'V':
visual = true
case 't':
toggle = true
case 'T':
thread = true
}
}
if thread && len(store.Threads()) == 0 {
return fmt.Errorf("No threads found")
}
if thread && all {
return fmt.Errorf("-a and -T are mutually exclusive")
}
if thread && visual {
return fmt.Errorf("-v and -T are mutually exclusive")
}
switch args[0] {
case "mark":
if all && visual {
return fmt.Errorf("-a and -v are mutually exclusive")
}
var modFunc func(uint32)
if toggle {
modFunc = marker.ToggleMark
} else {
modFunc = marker.Mark
}
switch {
case all:
uids := store.Uids()
for _, uid := range uids {
modFunc(uid)
}
return nil
case visual:
marker.ToggleVisualMark(clearVisual)
return nil
default:
if thread {
for _, uid := range store.SelectedThread().Root().Uids() {
modFunc(uid)
}
} else {
modFunc(selected.Uid)
}
return nil
}
case "unmark":
if visual {
return fmt.Errorf("visual mode not supported for this command")
}
switch {
case all && toggle:
uids := store.Uids()
for _, uid := range uids {
marker.ToggleMark(uid)
}
return nil
case all && !toggle:
marker.ClearVisualMark()
return nil
default:
if thread {
for _, uid := range store.SelectedThread().Root().Uids() {
marker.Unmark(uid)
}
} else {
marker.Unmark(selected.Uid)
}
return nil
}
case "remark":
if all || visual || toggle || thread {
return fmt.Errorf("Usage: :remark")
}
marker.Remark()
return nil
}
return nil // never reached
}