diff options
-rw-r--r-- | c_hardflip.go | 4 | ||||
-rw-r--r-- | c_init.go | 10 | ||||
-rw-r--r-- | c_litems.go | 18 |
3 files changed, 11 insertions, 21 deletions
diff --git a/c_hardflip.go b/c_hardflip.go index e6bdbe0..c3945c1 100644 --- a/c_hardflip.go +++ b/c_hardflip.go @@ -94,8 +94,7 @@ func (data *HardData) sel_unique_id(id int) { } func main() { - // TODO: fill litems - // TODO: delete data.ptr | replace with litems + // TODO: delete data.ptr | replace everything ui with litems data_dir := c_get_data_dir() opts := HardOpts{true, true, false} ldirs := c_load_data_dir(data_dir, opts) @@ -144,6 +143,7 @@ func main() { } } + return // PERF: test performance over a large amount of hosts with litems i_ui(&data) } @@ -113,10 +113,18 @@ func c_load_data_dir(dir string, opts HardOpts) *DirsList { return &ldirs } +// fills litems sorting with dirs last +// other sorting algos are concievable func c_load_litems(ldirs *DirsList) *ItemsList { litems := ItemsList{} - for dir := ldirs.head; dir != nil; dir = dir.next { + for ptr := ldirs.head; ptr != nil; ptr = ptr.next { + item := ItemsNode{ Dirs: ptr, Host: nil } + litems.add_back(&item) + for ptr := ptr.lhost.head; ptr != nil; ptr = ptr.next { + item := ItemsNode{ Dirs: nil, Host: ptr } + litems.add_back(&item) + } } return &litems } diff --git a/c_litems.go b/c_litems.go index 7fa93c3..44831ff 100644 --- a/c_litems.go +++ b/c_litems.go @@ -64,24 +64,6 @@ type ItemsList struct { last *ItemsNode } -func (litems *ItemsList) is_dir(id int) bool { - curr := litems.head - - if curr == nil { - return false - } - for curr.next != nil && curr.ID != id { - curr = curr.next - } - if curr.ID != id { - return false - } - if curr.Dirs != nil { - return true - } - return false -} - func (litems *ItemsList) add_back(node *ItemsNode) { if litems.head == nil { litems.head = node |