aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--ROADMAP.md4
-rw-r--r--src/c_litems.go32
-rw-r--r--src/e_events.go49
-rw-r--r--src/e_keys.go10
-rw-r--r--src/i_help.go1
-rw-r--r--src/i_insert.go11
-rw-r--r--src/i_ui.go6
7 files changed, 73 insertions, 40 deletions
diff --git a/ROADMAP.md b/ROADMAP.md
index 6a2ccac..30fc285 100644
--- a/ROADMAP.md
+++ b/ROADMAP.md
@@ -40,8 +40,8 @@
## v0.7
- [x] scroll insert
-- [ ] help
-- [ ] rename dirs
+- [x] help
+- [x] rename dirs
- [ ] better readline
## v0.8
diff --git a/src/c_litems.go b/src/c_litems.go
index 3f5a654..2b92816 100644
--- a/src/c_litems.go
+++ b/src/c_litems.go
@@ -82,6 +82,22 @@ func (litems *ItemsList) add_back(node *ItemsNode) {
litems.last = last.next
}
+// adds an item node to the list after the current selected item
+func (litems *ItemsList) add_after(node *ItemsNode) {
+ if litems.head == nil || litems.curr == nil {
+ litems.add_back(node)
+ return
+ }
+ curr := litems.curr
+ node.prev = curr
+ node.next = curr.next
+ curr.next = node
+ if litems.last == curr {
+ litems.last = node
+ }
+ litems.curr = node
+}
+
// removes an item node from the list and resets the ids
func (litems *ItemsList) del(item *ItemsNode) {
if litems.head == nil {
@@ -122,22 +138,6 @@ func (litems *ItemsList) del(item *ItemsNode) {
}
}
-// sets litems.curr to be used
-func (litems *ItemsList) sel(id int) {
- curr := litems.head
-
- if curr == nil {
- litems.curr = nil
- }
- for curr.next != nil && curr.ID != id {
- curr = curr.next
- }
- if curr.ID != id {
- litems.curr = nil
- }
- litems.curr = curr
-}
-
func (item *ItemsNode) is_dir() bool {
if item.Dirs == nil {
return false
diff --git a/src/e_events.go b/src/e_events.go
index 783e707..d954837 100644
--- a/src/e_events.go
+++ b/src/e_events.go
@@ -318,22 +318,47 @@ func e_mkdir(data *HardData, ui *HardUI) {
func e_rename(data *HardData, ui *HardUI) error {
tmp := data.litems.curr
+ name := ""
+ if tmp.is_dir() == false {
+ name = tmp.Host.Name
+ } else {
+ name = tmp.Dirs.Name
+ }
- if len(ui.buff) == 0 || tmp == nil || tmp.is_dir() == true ||
- ui.buff == tmp.Host.Name {
+ if len(ui.buff) == 0 || tmp == nil || ui.buff == name {
return nil
}
- new_host := e_deep_copy_host(data.litems.curr.Host)
- new_host.Name = ui.buff
- ui.insert_method = INSERT_MOVE
- i_insert_host(data, &new_host)
- data.litems.del(tmp)
- file_path := data.data_dir + tmp.Host.parent.path() + tmp.Host.filename
- if err := os.Remove(file_path); err != nil {
- c_error_mode("can't remove " + file_path, err, &data.ui)
- return err
+ if tmp.is_dir() == false {
+ new_host := e_deep_copy_host(data.litems.curr.Host)
+ new_host.Name = ui.buff
+ ui.insert_method = INSERT_MOVE
+ i_insert_host(data, &new_host)
+ data.litems.del(tmp)
+ file_path := data.data_dir + tmp.Host.parent.path() + tmp.Host.filename
+ if err := os.Remove(file_path); err != nil {
+ c_error_mode("can't remove " + file_path, err, &data.ui)
+ return err
+ }
+ return nil
+ } else {
+ old_path := data.data_dir + tmp.Dirs.path()
+ new_path := data.data_dir + tmp.Dirs.Parent.path() + data.ui.buff
+ if err := os.Rename(old_path, new_path); err != nil {
+ c_error_mode("can't rename " + old_path, err, &data.ui)
+ return err
+ }
+ path := tmp.Dirs.Parent.path()
+ e_reload_data(data)
+ for curr := data.litems.head; curr != nil; curr = curr.next {
+ if curr.is_dir() == true &&
+ curr.Dirs.Name == ui.buff &&
+ curr.Dirs.Parent.path() == path {
+ data.litems.curr = curr
+ return nil
+ }
+ }
+ return nil
}
- return nil
}
func e_set_drive_keys(data *HardData) {
diff --git a/src/e_keys.go b/src/e_keys.go
index 3fe9d6c..2d05380 100644
--- a/src/e_keys.go
+++ b/src/e_keys.go
@@ -242,10 +242,13 @@ func e_normal_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
} else if (event.Rune() == 'c' ||
event.Rune() == 'C' ||
event.Rune() == 'A') &&
- data.litems.curr != nil &&
- data.litems.curr.is_dir() == false {
+ data.litems.curr != nil {
ui.mode = RENAME_MODE
- ui.buff = data.litems.curr.Host.Name
+ if data.litems.curr.is_dir() == false {
+ ui.buff = data.litems.curr.Host.Name
+ } else {
+ ui.buff = data.litems.curr.Dirs.Name
+ }
} else if event.Rune() == '?' {
ui.mode = HELP_MODE
ui.help_scroll = 0
@@ -821,6 +824,7 @@ func e_rename_events(data *HardData, ui *HardUI, event tcell.EventKey) bool {
if err := e_rename(data, ui); err != nil {
ui.s.HideCursor()
ui.buff = ""
+ return true
}
} else {
e_readline(event, &ui.buff)
diff --git a/src/i_help.go b/src/i_help.go
index c13b0b7..fa3852f 100644
--- a/src/i_help.go
+++ b/src/i_help.go
@@ -79,7 +79,6 @@ func i_draw_help(ui *HardUI) {
ui.s.SetContent(win.L, win.B - 1, '▼',
nil, ui.style[BOX_STYLE])
}
- // TODO: here
}
func i_help_normal(ui HardUI, win Quad, line *int) bool {
diff --git a/src/i_insert.go b/src/i_insert.go
index e191bc4..09e1537 100644
--- a/src/i_insert.go
+++ b/src/i_insert.go
@@ -188,11 +188,12 @@ func i_insert_host(data *HardData, insert *HostNode) error {
}
curr := data.litems.curr
if curr != nil {
- curr.next = item
- if curr.next.next != nil {
- data.litems.curr.next.next.prev = item
- }
- data.litems.curr = data.litems.curr.next
+ data.litems.add_after(item)
+ // curr.next = item
+ // if curr.next.next != nil {
+ // data.litems.curr.next.next.prev = item
+ // }
+ // data.litems.curr = data.litems.curr.next
} else {
data.litems.add_back(item)
data.litems.curr = data.litems.head
diff --git a/src/i_ui.go b/src/i_ui.go
index 3e0de04..82e6878 100644
--- a/src/i_ui.go
+++ b/src/i_ui.go
@@ -445,7 +445,11 @@ func i_prompt_dir(ui HardUI, prompt string, home_dir string) {
func i_prompt_insert(ui HardUI, curr *ItemsNode) {
path := "/"
if curr != nil {
- path = curr.path()
+ if curr.is_dir() == false {
+ path = curr.path()
+ } else {
+ path = curr.Dirs.Parent.path()
+ }
}
path = path[1:]
prompt := "Name: "