From 34921eae2dac9f320c446c81991d2e3fe538923c Mon Sep 17 00:00:00 2001 From: Joe Date: Thu, 14 Dec 2023 20:20:20 +0100 Subject: up --- c_init.go | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) (limited to 'c_init.go') diff --git a/c_init.go b/c_init.go index 772b3ee..057d741 100644 --- a/c_init.go +++ b/c_init.go @@ -49,8 +49,10 @@ package main import ( "fmt" - "os" "io/ioutil" + "os" + "path/filepath" + "gopkg.in/yaml.v3" ) // This function will go get the data folder and try to create it if it does @@ -80,6 +82,22 @@ func c_get_data_dir() string { return *ptr } +func c_read_yaml_file(file string) { + var host host + yaml_file, err := ioutil.ReadFile(file) + + if err != nil { + c_die("error reading file " + file, err) + } + if err = yaml.Unmarshal(yaml_file, &host); err != nil { + c_die("error reading yaml file " + file, err) + } + fmt.Println(host) + os.Exit(0) +} + +// This function recurses into the specified root directory in order to load +// every yaml file into memory. func c_recurse_data_dir(dir string, root string) { files, err := ioutil.ReadDir(root + dir) if err != nil { @@ -88,8 +106,9 @@ func c_recurse_data_dir(dir string, root string) { for _, file := range files { if file.IsDir() == true { c_recurse_data_dir(dir + file.Name() + "/", root) - } else { - fmt.Println(dir + file.Name()) + } else if filepath.Ext(file.Name()) == ".yml" { + fmt.Println(root + dir + file.Name()) + c_read_yaml_file(root + dir + file.Name()) } } } -- cgit v1.2.3