parent
ce508d7ed3
commit
2c63096d3b
6
eval.go
6
eval.go
@ -33,13 +33,13 @@ func (e *setExpr) eval(app *app, args []string) {
|
|||||||
gOpts.globsearch = !gOpts.globsearch
|
gOpts.globsearch = !gOpts.globsearch
|
||||||
case "hidden":
|
case "hidden":
|
||||||
gOpts.hidden = true
|
gOpts.hidden = true
|
||||||
app.nav.renew(app.nav.height)
|
app.nav.sort()
|
||||||
case "nohidden":
|
case "nohidden":
|
||||||
gOpts.hidden = false
|
gOpts.hidden = false
|
||||||
app.nav.renew(app.nav.height)
|
app.nav.sort()
|
||||||
case "hidden!":
|
case "hidden!":
|
||||||
gOpts.hidden = !gOpts.hidden
|
gOpts.hidden = !gOpts.hidden
|
||||||
app.nav.renew(app.nav.height)
|
app.nav.sort()
|
||||||
case "ignorecase":
|
case "ignorecase":
|
||||||
gOpts.ignorecase = true
|
gOpts.ignorecase = true
|
||||||
case "noignorecase":
|
case "noignorecase":
|
||||||
|
38
nav.go
38
nav.go
@ -50,10 +50,6 @@ func readdir(path string) ([]*file, error) {
|
|||||||
|
|
||||||
fi := make([]*file, 0, len(names))
|
fi := make([]*file, 0, len(names))
|
||||||
for _, filename := range names {
|
for _, filename := range names {
|
||||||
if !gOpts.hidden && filename[0] == '.' {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
fpath := filepath.Join(path, filename)
|
fpath := filepath.Join(path, filename)
|
||||||
|
|
||||||
lstat, lerr := os.Lstat(fpath)
|
lstat, lerr := os.Lstat(fpath)
|
||||||
@ -89,10 +85,11 @@ func readdir(path string) ([]*file, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type dir struct {
|
type dir struct {
|
||||||
ind int // which entry is highlighted
|
ind int // index of current entry in fi
|
||||||
pos int // which line in the ui highlighted entry is
|
pos int // position of current entry in ui
|
||||||
path string
|
path string // full path of directory
|
||||||
fi []*file
|
fi []*file // displayed files in directory including or excluding hidden ones
|
||||||
|
all []*file // all files in directory including hidden ones (same array as fi)
|
||||||
}
|
}
|
||||||
|
|
||||||
func newDir(path string) *dir {
|
func newDir(path string) *dir {
|
||||||
@ -104,6 +101,7 @@ func newDir(path string) *dir {
|
|||||||
return &dir{
|
return &dir{
|
||||||
path: path,
|
path: path,
|
||||||
fi: fi,
|
fi: fi,
|
||||||
|
all: fi,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -114,9 +112,12 @@ func (dir *dir) renew() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dir.fi = fi
|
dir.fi = fi
|
||||||
|
dir.all = fi
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dir *dir) sort() {
|
func (dir *dir) sort() {
|
||||||
|
dir.fi = dir.all
|
||||||
|
|
||||||
switch gOpts.sortby {
|
switch gOpts.sortby {
|
||||||
case "natural":
|
case "natural":
|
||||||
sortFilesStable(dir.fi, func(i, j int) bool {
|
sortFilesStable(dir.fi, func(i, j int) bool {
|
||||||
@ -152,6 +153,25 @@ func (dir *dir) sort() {
|
|||||||
return dir.fi[i].IsDir()
|
return dir.fi[i].IsDir()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// when hidden option is disabled, we move hidden files to the
|
||||||
|
// beginning of our file list and then set the beginning of displayed
|
||||||
|
// files to the first non-hidden file in the list
|
||||||
|
if !gOpts.hidden {
|
||||||
|
sortFilesStable(dir.fi, func(i, j int) bool {
|
||||||
|
if dir.fi[i].Name()[0] == '.' && dir.fi[j].Name()[0] == '.' {
|
||||||
|
return i < j
|
||||||
|
}
|
||||||
|
return dir.fi[i].Name()[0] == '.'
|
||||||
|
})
|
||||||
|
for i, f := range dir.fi {
|
||||||
|
if f.Name()[0] != '.' {
|
||||||
|
dir.fi = dir.fi[i:]
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
dir.fi = dir.fi[len(dir.fi):]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dir *dir) name() string {
|
func (dir *dir) name() string {
|
||||||
@ -176,11 +196,11 @@ func (dir *dir) find(name string, height int) {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
edge := min(gOpts.scrolloff, len(dir.fi)-dir.ind-1)
|
edge := min(gOpts.scrolloff, len(dir.fi)-dir.ind-1)
|
||||||
dir.pos = min(dir.ind, height-edge-1)
|
dir.pos = min(dir.ind, height-edge-1)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
type nav struct {
|
type nav struct {
|
||||||
dirs []*dir
|
dirs []*dir
|
||||||
|
Loading…
Reference in New Issue
Block a user