diff options
author | Joe <rbo@gmx.us> | 2024-01-23 20:20:20 +0100 |
---|---|---|
committer | Joe <rbo@gmx.us> | 2024-01-23 20:20:20 +0100 |
commit | 730bbd15c64cf8324267176dc6ced128559ad4cd (patch) | |
tree | 8aac0527cf3616f04624ebf14e552d07396ae080 /c_init.go | |
parent | go (diff) | |
download | hardflip-730bbd15c64cf8324267176dc6ced128559ad4cd.tar.gz hardflip-730bbd15c64cf8324267176dc6ced128559ad4cd.tar.bz2 hardflip-730bbd15c64cf8324267176dc6ced128559ad4cd.tar.xz hardflip-730bbd15c64cf8324267176dc6ced128559ad4cd.tar.zst hardflip-730bbd15c64cf8324267176dc6ced128559ad4cd.zip |
better org
Diffstat (limited to 'c_init.go')
-rw-r--r-- | c_init.go | 132 |
1 files changed, 0 insertions, 132 deletions
diff --git a/c_init.go b/c_init.go deleted file mode 100644 index 6355d94..0000000 --- a/c_init.go +++ /dev/null @@ -1,132 +0,0 @@ -/* - * ======================== - * ===== =============== - * ====== ================ - * ====== ================ - * ====== ==== ==== == - * ====== === == = = - * ====== === = == = - * = === === = == ==== - * = === === = == = = - * == ===== ==== == - * ======================== - * - * SPDX-License-Identifier: BSD-3-Clause - * - * Copyright (c) 2023-2024, Joe - * All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions are met: - * - * 1. Redistributions of source code must retain the above copyright notice, - * this list of conditions and the following disclaimer. - * - * 2. Redistributions in binary form must reproduce the above copyright notice, - * this list of conditions and the following disclaimer in the documentation - * and/or other materials provided with the distribution. - * - * 3. Neither the name of the organization nor the names of its - * contributors may be used to endorse or promote products derived from - * this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ''AS IS'' - * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE - * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR - * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF - * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS - * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN - * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE - * POSSIBILITY OF SUCH DAMAGE. - * - * hardflip: src/c_init.go - * Thu Jan 18 16:23:10 2024 - * Joe - * - * init functions - */ - -package main - -import ( - "os" - "path/filepath" -) - -type HardOpts struct { - Icon bool - Loop bool - Perc bool - Term string -} - -// this function recurses into the specified root directory in order to load -// every yaml file into memory -func c_recurse_data_dir(dir, root string, opts HardOpts, - ldirs *DirsList, - name string, parent *DirsNode, depth uint16, - ui *HardUI) { - files, err := os.ReadDir(root + dir) - if err != nil { - c_die("could not read data directory", err) - } - dir_node := DirsNode{ - name, - parent, - depth, - &HostList{}, - nil, - } - ldirs.add_back(&dir_node) - i_draw_load_ui(ui) - for _, file := range files { - filename := file.Name() - if file.IsDir() == true { - c_recurse_data_dir(dir + filename + "/", root, opts, ldirs, - file.Name(), &dir_node, depth + 1, ui) - } else if filepath.Ext(filename) == ".yml" { - host_node := c_read_yaml_file(root + dir + filename) - if host_node == nil { - return - } - host_node.Filename = filename - host_node.Parent = &dir_node - dir_node.lhost.add_back(host_node) - i_draw_load_ui(ui) - } - } -} - -func c_load_data_dir(dir string, opts HardOpts, ui *HardUI) *DirsList { - ldirs := DirsList{} - - c_recurse_data_dir("", dir + "/", opts, &ldirs, "", nil, 1, ui) - return &ldirs -} - -// fills litems sorting with dirs last -// other sorting algos are concievable -// this func also sets the root folder to unfolded as it may never be folded -// this func also sets the default litems.curr -func c_load_litems(ldirs *DirsList) *ItemsList { - litems := ItemsList{} - - 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) - } - } - litems.head = litems.head.next - if litems.head != nil { - litems.head.prev = nil - } - litems.curr = litems.head - litems.draw = litems.head - return &litems -} |