diff options
Diffstat (limited to '')
-rw-r--r-- | conf/config.sample.yml | 7 | ||||
-rw-r--r-- | src/c_defs.go | 39 | ||||
-rw-r--r-- | src/c_exec.go | 2 | ||||
-rw-r--r-- | src/c_hardflip.go | 1 | ||||
-rw-r--r-- | src/c_init.go | 20 | ||||
-rw-r--r-- | src/c_parse.go | 11 | ||||
-rw-r--r-- | src/c_utils.go | 41 | ||||
-rw-r--r-- | src/i_host.go | 6 | ||||
-rw-r--r-- | src/i_info.go | 92 | ||||
-rw-r--r-- | src/i_ui.go | 50 |
10 files changed, 176 insertions, 93 deletions
diff --git a/conf/config.sample.yml b/conf/config.sample.yml index d4c27c7..48d3821 100644 --- a/conf/config.sample.yml +++ b/conf/config.sample.yml @@ -4,18 +4,17 @@ icons: true # keeps going after a successful login loop: true -# gnupg public key id used for encrypting/decrypting passwords. -# if not set, passwords will be disabled. session programs will most likely -# prompt you then. +# gnupg public key id used for encrypting/decrypting passwords # set it to 'plain' for saving passwords in plain text (not recommended # but still) +# if not set, the program will prompt your for a key or plain gpg: plain # displays the percentage in the bottom right percent: false # if set, will open your command in the specified terminal emulator. works great -# with loop set to true. will handle the env variable $TERMINAL if set as such. +# with loop set to true. will handle the env variable $TERMINAL if set as such # if commented or unset, # the command will replace hardflip #terminal: alacritty diff --git a/src/c_defs.go b/src/c_defs.go index 2662009..da3ab77 100644 --- a/src/c_defs.go +++ b/src/c_defs.go @@ -43,7 +43,7 @@ * POSSIBILITY OF SUCH DAMAGE. * * hardflip: src/c_defs.go - * Wed Jan 10 17:11:42 2024 + * Wed Jan 31 16:40:52 2024 * Joe * * constants @@ -52,12 +52,10 @@ package main const ( - W = 0 - H = 1 - ERROR_MSG = 0 - ERROR_ERR = 1 - DATA_DIR_NAME = "hardflip" - VERSION = "v0.2" + CONF_FILE_NAME = "hf.yml" + CONF_DIR_NAME = "hf" + DATA_DIR_NAME = "hf" + VERSION = "v0.2" ) const ( @@ -79,16 +77,29 @@ const ( ) const ( - DEF_STYLE = 0 - DIR_STYLE = 1 - BOX_STYLE = 2 - HEAD_STYLE = 3 - ERR_STYLE = 4 - TITLE_STYLE = 5 - BOT_STYLE = 6 + W = 0 + H = 1 + ERROR_MSG = 0 + ERROR_ERR = 1 + STYLE_DEF = 0 + STYLE_DIR = 1 + STYLE_BOX = 2 + STYLE_HEAD = 3 + STYLE_ERR = 4 + STYLE_TITLE = 5 + STYLE_BOT = 6 ) var ( HOST_ICONS = [2]string{" ", " "} DIRS_ICONS = [2]string{" ", " "} ) + +var DEFAULT_OPS = HardOpts{ + true, + true, + "", + false, + "", +} + diff --git a/src/c_exec.go b/src/c_exec.go index c1dd6aa..7bfcbc9 100644 --- a/src/c_exec.go +++ b/src/c_exec.go @@ -196,6 +196,6 @@ func c_exec(host *HostNode, opts HardOpts, ui *HardUI) { if err := ui.s.Init(); err != nil { c_die("view", err) } - ui.s.SetStyle(ui.style[DEF_STYLE]) + ui.s.SetStyle(ui.style[STYLE_DEF]) } } diff --git a/src/c_hardflip.go b/src/c_hardflip.go index 1075f19..e4eec84 100644 --- a/src/c_hardflip.go +++ b/src/c_hardflip.go @@ -63,6 +63,7 @@ type HardData struct { } func main() { + c_get_options(c_get_conf_dir(nil)) data_dir := c_get_data_dir(nil) opts := HardOpts{ true, diff --git a/src/c_init.go b/src/c_init.go index f89ce47..e377053 100644 --- a/src/c_init.go +++ b/src/c_init.go @@ -138,3 +138,23 @@ func c_load_litems(ldirs *DirsList) *ItemsList { litems.draw = litems.head return &litems } + +func c_write_options(dir string) { + // TODO: this +} + +func c_get_options(dir string) HardOpts { + opts := HardOpts{} + file := dir + "/" + CONF_FILE_NAME + + if _, err := os.Stat(file); os.IsNotExist(err) { + c_write_options(file) + return DEFAULT_OPS + } + opts, err := c_parse_opts(file) + if err != nil { + // TODO: this + } + return opts +} + diff --git a/src/c_parse.go b/src/c_parse.go index faa8223..53249cf 100644 --- a/src/c_parse.go +++ b/src/c_parse.go @@ -58,6 +58,17 @@ import ( "gopkg.in/yaml.v3" ) +func c_parse_opts(file string) (HardOpts, error) { + var opts HardOpts + + yaml_file, err := os.ReadFile(file) + if err != nil { + return opts, err + } + err = yaml.Unmarshal(yaml_file, opts) + return opts, err +} + func c_read_yaml_file(file string, ui *HardUI) (*HostNode, error) { var host HostNode yaml_file, err := os.ReadFile(file) diff --git a/src/c_utils.go b/src/c_utils.go index 01c8665..7ec70c0 100644 --- a/src/c_utils.go +++ b/src/c_utils.go @@ -60,11 +60,52 @@ import ( // this function will go get the data folder and try to create it if it does // not exist +// the first path being checked is $XDG_CONFIG_HOME then $HOME/.config +// it returns the full data directory path +func c_get_conf_dir(ui *HardUI) string { + var ptr string + var home string + + if home = os.Getenv("HOME"); len(home) == 0 { + if ui == nil { + c_die("env variable HOME not defined", nil) + } + c_error_mode("env variable HOME not defined", nil, ui) + return "" + } + xdg_home := os.Getenv("XDG_CONFIG_HOME") + + if len(xdg_home) > 0 { + ptr = xdg_home + } else { + ptr = home + "/.config" + } + ptr += "/" + CONF_DIR_NAME + if _, err := os.Stat(ptr); os.IsNotExist(err) { + if err := os.MkdirAll(ptr, os.ModePerm); err != nil { + if ui == nil { + c_die("could not create path " + ptr, err) + } + c_error_mode("could not create path" + ptr, err, ui) + } + } else if err != nil { + if ui == nil { + c_die("could read path " + ptr, err) + } + c_error_mode("could read path" + ptr, err, ui) + return "" + } + return ptr +} + +// this function will go get the data folder and try to create it if it does +// not exist // the first path being checked is $XDG_DATA_HOME then $HOME/.local/share // it returns the full data directory path func c_get_data_dir(ui *HardUI) string { var ptr string var home string + if home = os.Getenv("HOME"); len(home) == 0 { if ui == nil { c_die("env variable HOME not defined", nil) diff --git a/src/i_host.go b/src/i_host.go index 76334e1..9afb352 100644 --- a/src/i_host.go +++ b/src/i_host.go @@ -53,7 +53,7 @@ package main func i_host_panel_dirs(ui HardUI, icons bool, dir_icon uint8, dir *DirsNode, curr *DirsNode, line int) { - style := ui.style[DIR_STYLE] + style := ui.style[STYLE_DIR] if dir == curr { // style = style.Background(tcell.ColorBlack) style = style.Reverse(true) @@ -78,7 +78,7 @@ func i_host_panel_dirs(ui HardUI, icons bool, dir_icon uint8, func i_host_panel_host(ui HardUI, icons bool, depth uint16, host *HostNode, curr *HostNode, line int) { - style := ui.style[DEF_STYLE] + style := ui.style[STYLE_DEF] if host == curr { // style = style.Background(tcell.ColorBlack) style = style.Reverse(true) @@ -105,7 +105,7 @@ func i_draw_host_panel(ui HardUI, icons bool, litems *ItemsList, data *HardData) { i_draw_box(ui.s, 0, 0, ui.dim[W] / 3, ui.dim[H] - 2, - ui.style[BOX_STYLE], ui.style[HEAD_STYLE], " Hosts ", false) + ui.style[STYLE_BOX], ui.style[STYLE_HEAD], " Hosts ", false) line := 1 if litems == nil || litems.head == nil { return diff --git a/src/i_info.go b/src/i_info.go index 21bc670..41acce7 100644 --- a/src/i_info.go +++ b/src/i_info.go @@ -65,28 +65,28 @@ func i_info_panel_dirs(ui HardUI, dir *DirsNode) { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Name: ") + ui.style[STYLE_TITLE], "Name: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], dir.Name) + ui.style[STYLE_DEF], dir.Name) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Type: ") + ui.style[STYLE_TITLE], "Type: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], "Directory") + ui.style[STYLE_DEF], "Directory") if line += 2; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Path: ") + ui.style[STYLE_TITLE], "Path: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], dir.path()[1:]) + ui.style[STYLE_DEF], dir.path()[1:]) } func i_info_panel_host(ui HardUI, host *HostNode) { @@ -98,19 +98,19 @@ func i_info_panel_host(ui HardUI, host *HostNode) { // name, type i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Name: ") + ui.style[STYLE_TITLE], "Name: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Name) + ui.style[STYLE_DEF], host.Name) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Type: ") + ui.style[STYLE_TITLE], "Type: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host_type) + ui.style[STYLE_DEF], host_type) if line += 2; line > ui.dim[H] - 3 { return } @@ -120,19 +120,19 @@ func i_info_panel_host(ui HardUI, host *HostNode) { // host, port i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Host: ") + ui.style[STYLE_TITLE], "Host: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Host) + ui.style[STYLE_DEF], host.Host) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Port: ") + ui.style[STYLE_TITLE], "Port: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], strconv.Itoa(int(host.Port))) + ui.style[STYLE_DEF], strconv.Itoa(int(host.Port))) if line += 1; line > ui.dim[H] - 3 { return } @@ -141,10 +141,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { if len(host.Domain) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Domain: ") + ui.style[STYLE_TITLE], "Domain: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 11, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Domain) + ui.style[STYLE_DEF], host.Domain) if line += 1; line > ui.dim[H] - 3 { return } @@ -156,20 +156,20 @@ func i_info_panel_host(ui HardUI, host *HostNode) { // user infos i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "User: ") + ui.style[STYLE_TITLE], "User: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.User) + ui.style[STYLE_DEF], host.User) if line += 1; line > ui.dim[H] - 3 { return } if len(host.Pass) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Pass: ") + ui.style[STYLE_TITLE], "Pass: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], "***") + ui.style[STYLE_DEF], "***") if line += 1; line > ui.dim[H] - 3 { return } @@ -177,10 +177,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { if host.Protocol == 0 && len(host.Priv) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Privkey: ") + ui.style[STYLE_TITLE], "Privkey: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Priv) + ui.style[STYLE_DEF], host.Priv) if line += 1; line > ui.dim[H] - 3 { return } @@ -192,44 +192,44 @@ func i_info_panel_host(ui HardUI, host *HostNode) { if host.Protocol == 0 && len(host.Jump) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Jump settings: ") + ui.style[STYLE_TITLE], "Jump settings: ") if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Host: ") + ui.style[STYLE_TITLE], "Host: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Jump) + ui.style[STYLE_DEF], host.Jump) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Port: ") + ui.style[STYLE_TITLE], "Port: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], strconv.Itoa(int(host.JumpPort))) + ui.style[STYLE_DEF], strconv.Itoa(int(host.JumpPort))) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "User: ") + ui.style[STYLE_TITLE], "User: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.JumpUser) + ui.style[STYLE_DEF], host.JumpUser) if line += 1; line > ui.dim[H] - 3 { return } if len(host.JumpPass) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Pass: ") + ui.style[STYLE_TITLE], "Pass: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], "***") + ui.style[STYLE_DEF], "***") if line += 1; line > ui.dim[H] - 3 { return } @@ -237,10 +237,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { if host.Protocol == 0 && len(host.JumpPriv) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Privkey: ") + ui.style[STYLE_TITLE], "Privkey: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 13, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.JumpPriv) + ui.style[STYLE_DEF], host.JumpPriv) if line += 1; line > ui.dim[H] - 3 { return } @@ -254,10 +254,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { qual := [3]string{"Low", "Medium", "High"} i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Screen size: ") + ui.style[STYLE_TITLE], "Screen size: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 16, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], + ui.style[STYLE_DEF], strconv.Itoa(int(host.Width)) + "x" + strconv.Itoa(int(host.Height))) if line += 1; line > ui.dim[H] - 3 { @@ -265,19 +265,19 @@ func i_info_panel_host(ui HardUI, host *HostNode) { } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Dynamic window: ") + ui.style[STYLE_TITLE], "Dynamic window: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 19, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], strconv.FormatBool(host.Dynamic)) + ui.style[STYLE_DEF], strconv.FormatBool(host.Dynamic)) if line += 1; line > ui.dim[H] - 3 { return } i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Quality: ") + ui.style[STYLE_TITLE], "Quality: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], qual[host.Quality]) + ui.style[STYLE_DEF], qual[host.Quality]) line += 1 if line += 1; line > ui.dim[H] - 3 { return @@ -287,10 +287,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { if len(host.Note) > 0 { i_draw_text(ui.s, (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line, - ui.style[TITLE_STYLE], "Note: ") + ui.style[STYLE_TITLE], "Note: ") i_draw_text(ui.s, (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line, - ui.style[DEF_STYLE], host.Note) + ui.style[STYLE_DEF], host.Note) if line += 1; line > ui.dim[H] - 3 { return } @@ -300,10 +300,10 @@ func i_info_panel_host(ui HardUI, host *HostNode) { func i_draw_info_panel(ui HardUI, percent bool, litems *ItemsList) { i_draw_box(ui.s, (ui.dim[W] / 3), 0, ui.dim[W] - 1, ui.dim[H] - 2, - ui.style[BOX_STYLE], ui.style[HEAD_STYLE], " Infos ", false) - ui.s.SetContent(ui.dim[W] / 3, 0, tcell.RuneTTee, nil, ui.style[BOX_STYLE]) + ui.style[STYLE_BOX], ui.style[STYLE_HEAD], " Infos ", false) + ui.s.SetContent(ui.dim[W] / 3, 0, tcell.RuneTTee, nil, ui.style[STYLE_BOX]) ui.s.SetContent(ui.dim[W] / 3, ui.dim[H] - 2, - tcell.RuneBTee, nil, ui.style[BOX_STYLE]) + tcell.RuneBTee, nil, ui.style[STYLE_BOX]) if litems == nil { return } @@ -320,7 +320,7 @@ func i_draw_info_panel(ui HardUI, percent bool, litems *ItemsList) { ui.dim[H] - 2, (ui.dim[W] - 1) - 1, ui.dim[H] - 2, - ui.style[DEF_STYLE], + ui.style[STYLE_DEF], text) } else { text := " 0 hosts " @@ -329,7 +329,7 @@ func i_draw_info_panel(ui HardUI, percent bool, litems *ItemsList) { ui.dim[H] - 2, (ui.dim[W] - 1) - 1, ui.dim[H] - 2, - ui.style[DEF_STYLE], + ui.style[STYLE_DEF], text) } // panel diff --git a/src/i_ui.go b/src/i_ui.go index b7b83a9..69563e0 100644 --- a/src/i_ui.go +++ b/src/i_ui.go @@ -180,18 +180,18 @@ func i_draw_bottom_text(ui HardUI) { } i_draw_text(ui.s, 1, ui.dim[H] - 1, ui.dim[W] - 1, ui.dim[H] - 1, - ui.style[BOT_STYLE], text) + ui.style[STYLE_BOT], text) i_draw_text(ui.s, ui.dim[W] - len(VERSION) - 2, ui.dim[H] - 1, - ui.dim[W] - 1, ui.dim[H] - 1, ui.style[BOT_STYLE], " " + VERSION) + ui.dim[W] - 1, ui.dim[H] - 1, ui.style[STYLE_BOT], " " + VERSION) } func i_draw_zhosts_box(ui HardUI) { - i_draw_msg(ui.s, 1, ui.style[BOX_STYLE], ui.dim, " No hosts ") + i_draw_msg(ui.s, 1, ui.style[STYLE_BOX], ui.dim, " No hosts ") text := "Hosts list empty. Add hosts/folders by pressing (a/m)" left, right := i_left_right(len(text), &ui) i_draw_text(ui.s, left, ui.dim[H] - 2 - 1, right, ui.dim[H] - 2 - 1, - ui.style[DEF_STYLE], text) + ui.style[STYLE_DEF], text) } func i_draw_delete_msg(ui HardUI, item *ItemsNode) { @@ -207,20 +207,20 @@ func i_draw_delete_msg(ui HardUI, item *ItemsNode) { file = host.Parent.path() + host.Filename } file = file[1:] - i_draw_msg(ui.s, 2, ui.style[BOX_STYLE], ui.dim, " Delete ") + i_draw_msg(ui.s, 2, ui.style[STYLE_BOX], ui.dim, " Delete ") left, right := i_left_right(len(text), &ui) line := ui.dim[H] - 2 - 2 - i_draw_text(ui.s, left, line, right, line, ui.style[DEF_STYLE], text) + i_draw_text(ui.s, left, line, right, line, ui.style[STYLE_DEF], text) left, right = i_left_right(len(file), &ui) line += 1 i_draw_text(ui.s, left, line, right, line, - ui.style[DEF_STYLE].Bold(true), file) + ui.style[STYLE_DEF].Bold(true), file) } func i_draw_load_error_msg(ui HardUI, load_err []error) { lines := len(load_err) - i_draw_msg(ui.s, lines, ui.style[BOX_STYLE], ui.dim, " Load time errors ") + i_draw_msg(ui.s, lines, ui.style[STYLE_BOX], ui.dim, " Load time errors ") left, right := 1, ui.dim[W] - 1 line := ui.dim[H] - 2 - 1 - len(load_err) if line < 0 { @@ -230,7 +230,7 @@ func i_draw_load_error_msg(ui HardUI, load_err []error) { line += 1 err_str := fmt.Sprintf("%v", err) i_draw_text(ui.s, left, line, right, line, - ui.style[ERR_STYLE], err_str) + ui.style[STYLE_ERR], err_str) } } @@ -243,18 +243,18 @@ func i_draw_error_msg(ui HardUI, load_err []error) { if len(ui.err[ERROR_ERR]) == 0 { lines = 1 } - i_draw_msg(ui.s, lines, ui.style[BOX_STYLE], ui.dim, " Error ") + i_draw_msg(ui.s, lines, ui.style[STYLE_BOX], ui.dim, " Error ") left, right := 1, ui.dim[W] - 2 line := ui.dim[H] - 2 - 2 if len(ui.err[ERROR_ERR]) == 0 { line += 1 } i_draw_text(ui.s, left, line, right, line, - ui.style[ERR_STYLE], ui.err[ERROR_MSG]) + ui.style[STYLE_ERR], ui.err[ERROR_MSG]) if len(ui.err[ERROR_ERR]) > 0 { line += 1 i_draw_text(ui.s, left, line, right, line, - ui.style[ERR_STYLE], ui.err[ERROR_ERR]) + ui.style[STYLE_ERR], ui.err[ERROR_ERR]) } } @@ -271,12 +271,12 @@ func i_draw_scrollhint(ui HardUI, litems *ItemsList) { if draw_id > 1 { ui.s.SetContent(0, 1, '▲', - nil, ui.style[BOX_STYLE]) + nil, ui.style[STYLE_BOX]) } if last - draw_id > h { ui.s.SetContent(0, ui.dim[H] - 3, '▼', - nil, ui.style[BOX_STYLE]) + nil, ui.style[STYLE_BOX]) return } } @@ -295,14 +295,14 @@ func i_draw_load_ui(ui *HardUI) { text += " " } i_draw_text(ui.s, 1, ui.dim[H] - 1, ui.dim[W], ui.dim[H] - 1, - ui.style[BOT_STYLE], text) + ui.style[STYLE_BOT], text) i_draw_bottom_text(*ui) - i_draw_msg(ui.s, 1, ui.style[BOX_STYLE], ui.dim, " Loading ") + i_draw_msg(ui.s, 1, ui.style[STYLE_BOX], ui.dim, " Loading ") text = "Loading " + strconv.Itoa(g_load_count) + " hosts" left, right := i_left_right(len(text), ui) i_draw_text(ui.s, left, ui.dim[H] - 2 - 1, right, ui.dim[H] - 2 - 1, - ui.style[DEF_STYLE], text) + ui.style[STYLE_DEF], text) ui.s.Show() ui.s.PostEvent(nil) event := ui.s.PollEvent() @@ -345,28 +345,28 @@ func i_ui(data_dir string, opts HardOpts) { if err := ui.s.Init(); err != nil { c_die("view", err) } - ui.style[DEF_STYLE] = tcell.StyleDefault. + ui.style[STYLE_DEF] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorReset) - ui.style[DIR_STYLE] = tcell.StyleDefault. + ui.style[STYLE_DIR] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorBlue).Dim(true).Bold(true) - ui.style[BOX_STYLE] = tcell.StyleDefault. + ui.style[STYLE_BOX] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorReset) - ui.style[HEAD_STYLE] = tcell.StyleDefault. + ui.style[STYLE_HEAD] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorReset) - ui.style[ERR_STYLE] = tcell.StyleDefault. + ui.style[STYLE_ERR] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorRed).Dim(true) - ui.style[TITLE_STYLE] = tcell.StyleDefault. + ui.style[STYLE_TITLE] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorBlue).Dim(true).Bold(true) - ui.style[BOT_STYLE] = tcell.StyleDefault. + ui.style[STYLE_BOT] = tcell.StyleDefault. Background(tcell.ColorReset). Foreground(tcell.ColorBlue).Dim(true) - ui.s.SetStyle(ui.style[DEF_STYLE]) + ui.s.SetStyle(ui.style[STYLE_DEF]) ui.dim[W], ui.dim[H], _ = term.GetSize(0) ldirs, litems, load_err := i_load_ui(data_dir, opts, &ui) data := HardData{ |