aboutsummaryrefslogtreecommitdiffstats
path: root/i_events.go
diff options
context:
space:
mode:
Diffstat (limited to 'i_events.go')
-rw-r--r--i_events.go31
1 files changed, 23 insertions, 8 deletions
diff --git a/i_events.go b/i_events.go
index f52e9fe..d54e9f7 100644
--- a/i_events.go
+++ b/i_events.go
@@ -43,7 +43,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/i_events.go
- * Mon Jan 15 11:40:10 2024
+ * Mon Jan 15 13:54:57 2024
* Joe
*
* events in the code
@@ -181,12 +181,17 @@ func i_delete_dir(data *HardData) {
if data.folds[data.litems.curr.Dirs] == nil {
i_fold_dir(data, data.litems.curr)
}
- delete(data.folds, data.litems.curr.Dirs)
+ delete(data.folds,data.litems.curr.Dirs)
if data.litems.last == data.litems.curr {
data.litems.last = data.litems.curr.prev
}
- data.litems.curr.prev = data.litems.curr.next
- data.litems.curr.next = data.litems.curr.prev
+ data.litems.curr.prev.next = data.litems.curr.next
+ data.litems.curr.next.prev = data.litems.curr.prev
+ prev_dir := data.ldirs.prev(data.litems.curr.Dirs)
+ if data.ldirs.last == data.litems.curr.Dirs {
+ data.ldirs.last = prev_dir
+ }
+ prev_dir.next = data.litems.curr.Dirs.next
data.litems.curr = data.litems.curr.next
for ptr := data.litems.head; ptr.next != nil; ptr = ptr.next {
ptr.next.ID = ptr.ID + 1
@@ -260,14 +265,24 @@ func i_events(data *HardData) {
} else if event.Rune() == 'k' ||
event.Key() == tcell.KeyUp {
data.litems.inc(-1)
- } else if event.Key() == tcell.KeyCtrlD {
+ } else if event.Key() == tcell.KeyCtrlD ||
+ event.Key() == tcell.KeyPgDn {
data.litems.inc(+(ui.dim[H] / 3))
- } else if event.Key() == tcell.KeyCtrlU {
+ } else if event.Key() == tcell.KeyCtrlU ||
+ event.Key() == tcell.KeyPgUp {
data.litems.inc(-(ui.dim[H] / 3))
- } else if event.Rune() == 'g' {
+ } else if event.Rune() == '}' ||
+ event.Rune() == ']' {
+ // TODO: next dir
+ } else if event.Rune() == '{' ||
+ event.Rune() == '[' {
+ // TODO: prev dir
+ } else if event.Rune() == 'g' ||
+ event.Key() == tcell.KeyHome {
data.litems.curr = data.litems.head
data.litems.draw_start = data.litems.head
- } else if event.Rune() == 'G' {
+ } else if event.Rune() == 'G' ||
+ event.Key() == tcell.KeyEnd {
data.litems.curr = data.litems.last
} else if event.Rune() == 'D' &&
data.ldirs.head != nil &&