Rename :cd -> :cf, add :cd

This commit is contained in:
Drew DeVault 2019-03-15 10:47:09 -04:00
parent 9e3b602ce7
commit 513e8aa94b
5 changed files with 60 additions and 12 deletions

View File

@ -2,34 +2,44 @@ package commands
import ( import (
"errors" "errors"
"os"
"git.sr.ht/~sircmpwn/aerc2/widgets" "git.sr.ht/~sircmpwn/aerc2/widgets"
"github.com/mitchellh/go-homedir"
) )
var ( var (
history map[string]string previousDir string
) )
func init() { func init() {
history = make(map[string]string)
Register("cd", ChangeDirectory) Register("cd", ChangeDirectory)
} }
func ChangeDirectory(aerc *widgets.Aerc, args []string) error { func ChangeDirectory(aerc *widgets.Aerc, args []string) error {
if len(args) != 2 { if len(args) != 2 {
return errors.New("Usage: cd <directory>") return errors.New("Usage: cf <directory>")
} }
acct := aerc.SelectedAccount() cwd, err := os.Getwd()
previous := acct.Directories().Selected() if err != nil {
return err
}
var target string
if args[1] == "-" { if args[1] == "-" {
if dir, ok := history[acct.Name()]; ok { if previousDir == "" {
acct.Directories().Select(dir) return errors.New("No previous folder to return to")
} else { } else {
return errors.New("No previous directory to return to") target = previousDir
} }
} else { } else {
acct.Directories().Select(args[1]) target = args[1]
} }
history[acct.Name()] = previous target, err = homedir.Expand(target)
return nil if err != nil {
return err
}
if err := os.Chdir(target); err == nil {
previousDir = cwd
}
return err
} }

35
commands/cf.go Normal file
View File

@ -0,0 +1,35 @@
package commands
import (
"errors"
"git.sr.ht/~sircmpwn/aerc2/widgets"
)
var (
history map[string]string
)
func init() {
history = make(map[string]string)
Register("cf", ChangeFolder)
}
func ChangeFolder(aerc *widgets.Aerc, args []string) error {
if len(args) != 2 {
return errors.New("Usage: cf <folder>")
}
acct := aerc.SelectedAccount()
previous := acct.Directories().Selected()
if args[1] == "-" {
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(args[1])
}
history[acct.Name()] = previous
return nil
}

View File

@ -125,7 +125,7 @@ h = :prev-account<Enter>
<Enter> = :view-message<Enter> <Enter> = :view-message<Enter>
d = :confirm 'Really delete this message?' ':delete-message<Enter>'<Enter> d = :confirm 'Really delete this message?' ':delete-message<Enter>'<Enter>
c = :cd<space> c = :cf<space>
$ = :term-exec $ = :term-exec
[mbinds] [mbinds]

1
go.mod
View File

@ -12,6 +12,7 @@ require (
github.com/lucasb-eyer/go-colorful v0.0.0-20180531031333-d9cec903b20c github.com/lucasb-eyer/go-colorful v0.0.0-20180531031333-d9cec903b20c
github.com/mattn/go-isatty v0.0.3 github.com/mattn/go-isatty v0.0.3
github.com/mattn/go-runewidth v0.0.2 github.com/mattn/go-runewidth v0.0.2
github.com/mitchellh/go-homedir v1.1.0
github.com/nsf/termbox-go v0.0.0-20180129072728-88b7b944be8b github.com/nsf/termbox-go v0.0.0-20180129072728-88b7b944be8b
github.com/stretchr/testify v1.3.0 github.com/stretchr/testify v1.3.0
golang.org/x/text v0.3.0 golang.org/x/text v0.3.0

2
go.sum
View File

@ -24,6 +24,8 @@ github.com/mattn/go-isatty v0.0.3 h1:ns/ykhmWi7G9O+8a448SecJU3nSMBXJfqQkl0upE1jI
github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4= github.com/mattn/go-isatty v0.0.3/go.mod h1:M+lRXTBqGeGNdLjl/ufCoiOlB5xdOkqRJdNxMWT7Zi4=
github.com/mattn/go-runewidth v0.0.2 h1:UnlwIPBGaTZfPQ6T1IGzPI0EkYAQmT9fAEJ/poFC63o= github.com/mattn/go-runewidth v0.0.2 h1:UnlwIPBGaTZfPQ6T1IGzPI0EkYAQmT9fAEJ/poFC63o=
github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU= github.com/mattn/go-runewidth v0.0.2/go.mod h1:LwmH8dsx7+W8Uxz3IHJYH5QSwggIsqBzpuz5H//U1FU=
github.com/mitchellh/go-homedir v1.1.0 h1:lukF9ziXFxDFPkA1vsr5zpc1XuPDn/wFntq5mG+4E0Y=
github.com/mitchellh/go-homedir v1.1.0/go.mod h1:SfyaCUpYCn1Vlf4IUYiD9fPX4A5wJrkLzIz1N1q0pr0=
github.com/nsf/termbox-go v0.0.0-20180129072728-88b7b944be8b/go.mod h1:IuKpRQcYE1Tfu+oAQqaLisqDeXgjyyltCfsaoYN18NQ= github.com/nsf/termbox-go v0.0.0-20180129072728-88b7b944be8b/go.mod h1:IuKpRQcYE1Tfu+oAQqaLisqDeXgjyyltCfsaoYN18NQ=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=