rename mark to selection

This commit is contained in:
Gokcehan 2018-07-09 21:22:10 +03:00
parent 552182958a
commit a80900f41e
9 changed files with 75 additions and 75 deletions

6
app.go
View File

@ -149,14 +149,14 @@ func (app *app) exportVars() {
envFile = f.path envFile = f.path
} }
marks := app.nav.currMarks() selections := app.nav.currSelections()
envFiles := strings.Join(marks, gOpts.filesep) envFiles := strings.Join(selections, gOpts.filesep)
os.Setenv("f", envFile) os.Setenv("f", envFile)
os.Setenv("fs", envFiles) os.Setenv("fs", envFiles)
if len(marks) == 0 { if len(selections) == 0 {
os.Setenv("fx", envFile) os.Setenv("fx", envFile)
} else { } else {
os.Setenv("fx", envFiles) os.Setenv("fx", envFiles)

View File

@ -27,7 +27,7 @@ var (
"bottom", "bottom",
"toggle", "toggle",
"invert", "invert",
"unmark", "unselect",
"copy", "copy",
"cut", "cut",
"paste", "paste",

8
doc.go
View File

@ -29,7 +29,7 @@ The following commands are provided by lf with default keybindings:
bottom (default 'G' and '<end>') bottom (default 'G' and '<end>')
toggle (default '<space>') toggle (default '<space>')
invert (default 'v') invert (default 'v')
unmark (default 'u') unselect (default 'u')
copy (default 'y') copy (default 'y')
cut (default 'd') cut (default 'd')
paste (default 'p') paste (default 'p')
@ -114,8 +114,8 @@ The following options can be used to customize the behavior of lf:
The following variables are exported for shell commands: The following variables are exported for shell commands:
$f current file $f current file
$fs marked file(s) separated with 'filesep' $fs selected file(s) separated with 'filesep'
$fx current file or marked file(s) if any $fx current file or selected file(s) if any
$id id number of the client $id id number of the client
The following default values are set to the environmental variables on unix The following default values are set to the environmental variables on unix
@ -340,7 +340,7 @@ trash. A first attempt to write such a command may look like this:
fi fi
}} }}
We check '$fs' to see if there are any marked files. Otherwise we just delete We check '$fs' to see if there are any selected files. Otherwise we just delete
the current file. Since this is such a common pattern, a separate '$fx' the current file. Since this is such a common pattern, a separate '$fx'
variable is provided. We can use this variable to get rid of the conditional: variable is provided. We can use this variable to get rid of the conditional:

View File

@ -32,7 +32,7 @@ The following commands are provided by lf with default keybindings:
bottom (default 'G' and '<end>') bottom (default 'G' and '<end>')
toggle (default '<space>') toggle (default '<space>')
invert (default 'v') invert (default 'v')
unmark (default 'u') unselect (default 'u')
copy (default 'y') copy (default 'y')
cut (default 'd') cut (default 'd')
paste (default 'p') paste (default 'p')
@ -117,8 +117,8 @@ The following options can be used to customize the behavior of lf:
The following variables are exported for shell commands: The following variables are exported for shell commands:
$f current file $f current file
$fs marked file(s) separated with 'filesep' $fs selected file(s) separated with 'filesep'
$fx current file or marked file(s) if any $fx current file or selected file(s) if any
$id id number of the client $id id number of the client
The following default values are set to the environmental variables on unix The following default values are set to the environmental variables on unix
@ -352,7 +352,7 @@ this:
fi fi
}} }}
We check '$fs' to see if there are any marked files. Otherwise we just We check '$fs' to see if there are any selected files. Otherwise we just
delete the current file. Since this is such a common pattern, a separate delete the current file. Since this is such a common pattern, a separate
'$fx' variable is provided. We can use this variable to get rid of the '$fx' variable is provided. We can use this variable to get rid of the
conditional: conditional:

14
eval.go
View File

@ -314,9 +314,9 @@ func (e *callExpr) eval(app *app, args []string) {
defer out.Close() defer out.Close()
var path string var path string
if len(app.nav.marks) != 0 { if len(app.nav.selections) != 0 {
marks := app.nav.currMarks() selections := app.nav.currSelections()
path = strings.Join(marks, "\n") path = strings.Join(selections, "\n")
} else if curr, err := app.nav.currFile(); err == nil { } else if curr, err := app.nav.currFile(); err == nil {
path = curr.path path = curr.path
} else { } else {
@ -354,14 +354,14 @@ func (e *callExpr) eval(app *app, args []string) {
app.ui.loadFileInfo(app.nav) app.ui.loadFileInfo(app.nav)
case "invert": case "invert":
app.nav.invert() app.nav.invert()
case "unmark": case "unselect":
app.nav.unmark() app.nav.unselect()
case "copy": case "copy":
if err := app.nav.save(true); err != nil { if err := app.nav.save(true); err != nil {
app.ui.printf("copy: %s", err) app.ui.printf("copy: %s", err)
return return
} }
app.nav.unmark() app.nav.unselect()
if err := sendRemote("send sync"); err != nil { if err := sendRemote("send sync"); err != nil {
app.ui.printf("copy: %s", err) app.ui.printf("copy: %s", err)
} }
@ -370,7 +370,7 @@ func (e *callExpr) eval(app *app, args []string) {
app.ui.printf("cut: %s", err) app.ui.printf("cut: %s", err)
return return
} }
app.nav.unmark() app.nav.unselect()
if err := sendRemote("send sync"); err != nil { if err := sendRemote("send sync"); err != nil {
app.ui.printf("cut: %s", err) app.ui.printf("cut: %s", err)
} }

8
lf.1
View File

@ -39,7 +39,7 @@ The following commands are provided by lf with default keybindings:
bottom (default 'G' and '<end>') bottom (default 'G' and '<end>')
toggle (default '<space>') toggle (default '<space>')
invert (default 'v') invert (default 'v')
unmark (default 'u') unselect (default 'u')
copy (default 'y') copy (default 'y')
cut (default 'd') cut (default 'd')
paste (default 'p') paste (default 'p')
@ -131,8 +131,8 @@ The following variables are exported for shell commands:
.PP .PP
.EX .EX
$f current file $f current file
$fs marked file(s) separated with 'filesep' $fs selected file(s) separated with 'filesep'
$fx current file or marked file(s) if any $fx current file or selected file(s) if any
$id id number of the client $id id number of the client
.EE .EE
.PP .PP
@ -371,7 +371,7 @@ Regular shell commands are the most basic command type that is useful for many p
}} }}
.EE .EE
.PP .PP
We check '$fs' to see if there are any marked files. Otherwise we just delete the current file. Since this is such a common pattern, a separate '$fx' variable is provided. We can use this variable to get rid of the conditional: We check '$fs' to see if there are any selected files. Otherwise we just delete the current file. Since this is such a common pattern, a separate '$fx' variable is provided. We can use this variable to get rid of the conditional:
.PP .PP
.EX .EX
cmd trash ${{ cmd trash ${{

94
nav.go
View File

@ -188,16 +188,16 @@ func (dir *dir) find(name string, height int) {
} }
type nav struct { type nav struct {
dirs []*dir dirs []*dir
dirChan chan *dir dirChan chan *dir
regChan chan *reg regChan chan *reg
dirCache map[string]*dir dirCache map[string]*dir
regCache map[string]*reg regCache map[string]*reg
saves map[string]bool saves map[string]bool
marks map[string]int selections map[string]int
markInd int selectionInd int
height int height int
search string search string
} }
func (nav *nav) loadDir(path string) *dir { func (nav *nav) loadDir(path string) *dir {
@ -265,14 +265,14 @@ func newNav(height int) *nav {
} }
nav := &nav{ nav := &nav{
dirChan: make(chan *dir), dirChan: make(chan *dir),
regChan: make(chan *reg), regChan: make(chan *reg),
dirCache: make(map[string]*dir), dirCache: make(map[string]*dir),
regCache: make(map[string]*reg), regCache: make(map[string]*reg),
saves: make(map[string]bool), saves: make(map[string]bool),
marks: make(map[string]int), selections: make(map[string]int),
markInd: 0, selectionInd: 0,
height: height, height: height,
} }
nav.getDirs(wd) nav.getDirs(wd)
@ -297,13 +297,13 @@ func (nav *nav) renew() {
}(d) }(d)
} }
for m := range nav.marks { for m := range nav.selections {
if _, err := os.Stat(m); os.IsNotExist(err) { if _, err := os.Stat(m); os.IsNotExist(err) {
delete(nav.marks, m) delete(nav.selections, m)
} }
} }
if len(nav.marks) == 0 { if len(nav.selections) == 0 {
nav.markInd = 0 nav.selectionInd = 0
} }
} }
@ -504,15 +504,15 @@ func (nav *nav) bottom() {
dir.pos = min(dir.ind, nav.height-1) dir.pos = min(dir.ind, nav.height-1)
} }
func (nav *nav) toggleMark(path string) { func (nav *nav) toggleSelection(path string) {
if _, ok := nav.marks[path]; ok { if _, ok := nav.selections[path]; ok {
delete(nav.marks, path) delete(nav.selections, path)
if len(nav.marks) == 0 { if len(nav.selections) == 0 {
nav.markInd = 0 nav.selectionInd = 0
} }
} else { } else {
nav.marks[path] = nav.markInd nav.selections[path] = nav.selectionInd
nav.markInd = nav.markInd + 1 nav.selectionInd++
} }
} }
@ -522,7 +522,7 @@ func (nav *nav) toggle() {
return return
} }
nav.toggleMark(curr.path) nav.toggleSelection(curr.path)
nav.down(1) nav.down(1)
} }
@ -531,17 +531,17 @@ func (nav *nav) invert() {
last := nav.currDir() last := nav.currDir()
for _, f := range last.files { for _, f := range last.files {
path := filepath.Join(last.path, f.Name()) path := filepath.Join(last.path, f.Name())
nav.toggleMark(path) nav.toggleSelection(path)
} }
} }
func (nav *nav) unmark() { func (nav *nav) unselect() {
nav.marks = make(map[string]int) nav.selections = make(map[string]int)
nav.markInd = 0 nav.selectionInd = 0
} }
func (nav *nav) save(cp bool) error { func (nav *nav) save(cp bool) error {
if len(nav.marks) == 0 { if len(nav.selections) == 0 {
curr, err := nav.currFile() curr, err := nav.currFile()
if err != nil { if err != nil {
return errors.New("no file selected") return errors.New("no file selected")
@ -554,14 +554,14 @@ func (nav *nav) save(cp bool) error {
nav.saves = make(map[string]bool) nav.saves = make(map[string]bool)
nav.saves[curr.path] = cp nav.saves[curr.path] = cp
} else { } else {
marks := nav.currMarks() selections := nav.currSelections()
if err := saveFiles(marks, cp); err != nil { if err := saveFiles(selections, cp); err != nil {
return err return err
} }
nav.saves = make(map[string]bool) nav.saves = make(map[string]bool)
for f := range nav.marks { for f := range nav.selections {
nav.saves[f] = cp nav.saves[f] = cp
} }
} }
@ -730,27 +730,27 @@ func (nav *nav) currFile() (*file, error) {
return last.files[last.ind], nil return last.files[last.ind], nil
} }
type indexedMarks struct { type indexedSelections struct {
paths []string paths []string
indices []int indices []int
} }
func (m indexedMarks) Len() int { return len(m.paths) } func (m indexedSelections) Len() int { return len(m.paths) }
func (m indexedMarks) Swap(i, j int) { func (m indexedSelections) Swap(i, j int) {
m.paths[i], m.paths[j] = m.paths[j], m.paths[i] m.paths[i], m.paths[j] = m.paths[j], m.paths[i]
m.indices[i], m.indices[j] = m.indices[j], m.indices[i] m.indices[i], m.indices[j] = m.indices[j], m.indices[i]
} }
func (m indexedMarks) Less(i, j int) bool { return m.indices[i] < m.indices[j] } func (m indexedSelections) Less(i, j int) bool { return m.indices[i] < m.indices[j] }
func (nav *nav) currMarks() []string { func (nav *nav) currSelections() []string {
paths := make([]string, 0, len(nav.marks)) paths := make([]string, 0, len(nav.selections))
indices := make([]int, 0, len(nav.marks)) indices := make([]int, 0, len(nav.selections))
for path, index := range nav.marks { for path, index := range nav.selections {
paths = append(paths, path) paths = append(paths, path)
indices = append(indices, index) indices = append(indices, index)
} }
sort.Sort(indexedMarks{paths: paths, indices: indices}) sort.Sort(indexedSelections{paths: paths, indices: indices})
return paths return paths
} }

View File

@ -93,7 +93,7 @@ func init() {
gOpts.keys["<end>"] = &callExpr{"bottom", nil, 1} gOpts.keys["<end>"] = &callExpr{"bottom", nil, 1}
gOpts.keys["<space>"] = &callExpr{"toggle", nil, 1} gOpts.keys["<space>"] = &callExpr{"toggle", nil, 1}
gOpts.keys["v"] = &callExpr{"invert", nil, 1} gOpts.keys["v"] = &callExpr{"invert", nil, 1}
gOpts.keys["u"] = &callExpr{"unmark", nil, 1} gOpts.keys["u"] = &callExpr{"unselect", nil, 1}
gOpts.keys["y"] = &callExpr{"copy", nil, 1} gOpts.keys["y"] = &callExpr{"copy", nil, 1}
gOpts.keys["d"] = &callExpr{"cut", nil, 1} gOpts.keys["d"] = &callExpr{"cut", nil, 1}
gOpts.keys["c"] = &callExpr{"clear", nil, 1} gOpts.keys["c"] = &callExpr{"clear", nil, 1}

8
ui.go
View File

@ -241,7 +241,7 @@ func fileInfo(f *file, d *dir) string {
return info return info
} }
func (win *win) printDir(dir *dir, marks map[string]int, saves map[string]bool, colors colorMap) { func (win *win) printDir(dir *dir, selections map[string]int, saves map[string]bool, colors colorMap) {
if win.w < 5 || dir == nil { if win.w < 5 || dir == nil {
return return
} }
@ -272,7 +272,7 @@ func (win *win) printDir(dir *dir, marks map[string]int, saves map[string]bool,
path := filepath.Join(dir.path, f.Name()) path := filepath.Join(dir.path, f.Name())
if _, ok := marks[path]; ok { if _, ok := selections[path]; ok {
win.print(0, i, fg, termbox.ColorMagenta, " ") win.print(0, i, fg, termbox.ColorMagenta, " ")
} else if cp, ok := saves[path]; ok { } else if cp, ok := saves[path]; ok {
if cp { if cp {
@ -602,7 +602,7 @@ func (ui *ui) draw(nav *nav) {
doff := len(nav.dirs) - length doff := len(nav.dirs) - length
for i := 0; i < length; i++ { for i := 0; i < length; i++ {
ui.wins[woff+i].printDir(nav.dirs[doff+i], nav.marks, nav.saves, ui.colors) ui.wins[woff+i].printDir(nav.dirs[doff+i], nav.selections, nav.saves, ui.colors)
} }
switch ui.cmdPrefix { switch ui.cmdPrefix {
@ -628,7 +628,7 @@ func (ui *ui) draw(nav *nav) {
preview := ui.wins[len(ui.wins)-1] preview := ui.wins[len(ui.wins)-1]
if f.IsDir() { if f.IsDir() {
preview.printDir(ui.dirPrev, nav.marks, nav.saves, ui.colors) preview.printDir(ui.dirPrev, nav.selections, nav.saves, ui.colors)
} else if f.Mode().IsRegular() { } else if f.Mode().IsRegular() {
preview.printReg(ui.regPrev) preview.printReg(ui.regPrev)
} }