blob: fe225e6184cdc30e5841dc6b4937be098b3e39f6 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
package account
import (
"errors"
"reflect"
"git.sr.ht/~rjarry/aerc/app"
"git.sr.ht/~rjarry/aerc/commands"
"git.sr.ht/~rjarry/aerc/lib/state"
"git.sr.ht/~rjarry/aerc/worker/handlers"
"git.sr.ht/~rjarry/aerc/worker/types"
"git.sr.ht/~rjarry/go-opt"
)
var history map[string]string
type ChangeFolder struct {
Folder []string `opt:"..." complete:"CompleteFolder"`
}
func init() {
history = make(map[string]string)
register(ChangeFolder{})
}
func (ChangeFolder) Aliases() []string {
return []string{"cf"}
}
func (*ChangeFolder) CompleteFolder(arg string) []string {
return commands.GetFolders(arg)
}
func (c ChangeFolder) Execute(args []string) error {
acct := app.SelectedAccount()
if acct == nil {
return errors.New("No account selected")
}
var target string
notmuch, _ := handlers.GetHandlerForScheme("notmuch", new(types.Worker))
switch {
case reflect.TypeOf(notmuch) == reflect.TypeOf(acct.Worker().Backend):
// notmuch query may have arguments that require quoting
target = opt.QuoteArgs(c.Folder...).String()
case len(c.Folder) == 1:
target = c.Folder[0]
default:
return errors.New("Unexpected argument(s). Usage: cf <folder>")
}
previous := acct.Directories().Selected()
if target == "-" {
if dir, ok := history[acct.Name()]; ok {
acct.Directories().Select(dir)
} else {
return errors.New("No previous folder to return to")
}
} else {
acct.Directories().Select(target)
}
history[acct.Name()] = previous
// reset store filtering if we switched folders
store := acct.Store()
if store != nil {
store.ApplyClear()
acct.SetStatus(state.SearchFilterClear())
}
return nil
}
|