diff options
author | Joe <rbo@gmx.us> | 2024-05-15 20:20:20 +0200 |
---|---|---|
committer | Joe <rbo@gmx.us> | 2024-05-15 20:20:20 +0200 |
commit | a98e185fc9467a70e651860d7ccddc96fb0de8b7 (patch) | |
tree | 55ce0c0c00e15b1684ac40c72aef49b8af0451bd | |
parent | fucking hard (diff) | |
download | hardflip-a98e185fc9467a70e651860d7ccddc96fb0de8b7.tar.gz hardflip-a98e185fc9467a70e651860d7ccddc96fb0de8b7.tar.bz2 hardflip-a98e185fc9467a70e651860d7ccddc96fb0de8b7.tar.xz hardflip-a98e185fc9467a70e651860d7ccddc96fb0de8b7.tar.zst hardflip-a98e185fc9467a70e651860d7ccddc96fb0de8b7.zip |
go
Diffstat (limited to '')
-rw-r--r-- | src/e_events.go | 23 |
1 files changed, 12 insertions, 11 deletions
diff --git a/src/e_events.go b/src/e_events.go index 5294351..9c4fd92 100644 --- a/src/e_events.go +++ b/src/e_events.go @@ -279,10 +279,11 @@ func e_delete_host(data *HardData) error { return nil } -func e_tab_complete_get_current_dir(str, home_dir string) string { +func e_tab_complete_get_current_dir(str, home_dir string) (string, string) { dir := "./" + file := "" if len(str) == 0 { - return "./" + return dir, file } else if str[0] == '~' { dir = home_dir + str[1:] } else { @@ -292,28 +293,28 @@ func e_tab_complete_get_current_dir(str, home_dir string) string { if dir[i] == '/' { break } + file += string(dir[i]) dir = dir[:i] } + // TODO: file is reversed oh no if stat, err := os.Stat(dir); err == nil && dir[len(dir) - 1] == '/' && stat.IsDir() == true { - return dir + return dir, file } - return "./" + return "./", file } func e_tab_complete(buffer *Buffer, home_dir string) { - dir := e_tab_complete_get_current_dir(buffer.str(), home_dir) - log.Println("cwd:", dir) + dir, file := e_tab_complete_get_current_dir(buffer.str(), home_dir) + log.Println("cwd:", dir, "file:", file) entries, err := os.ReadDir(dir) if err != nil { return } var match []string for _, v := range entries { - log.Println("entry:", v.Name()) - // TODO: its all here - if len(v.Name()) >= buffer.len() - len(dir) && - v.Name()[:buffer.len()] == buffer.str() { + if len(v.Name()) >= len(file) && + v.Name()[:len(file)] == file { match = append(match, v.Name()) } } @@ -321,7 +322,7 @@ func e_tab_complete(buffer *Buffer, home_dir string) { if len(match) == 0 { return } else if len(match) == 1 { - buffer.insert(match[0]) + buffer.insert(dir + match[0]) if stat, err := os.Stat(match[0]); err == nil && stat.IsDir() == true { buffer.insert(match[0] + "/") } |