diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/c_defs.go | 7 | ||||
-rw-r--r-- | src/i_events.go | 3 | ||||
-rw-r--r-- | src/i_insert.go | 29 |
3 files changed, 33 insertions, 6 deletions
diff --git a/src/c_defs.go b/src/c_defs.go index 2781c53..a1da14f 100644 --- a/src/c_defs.go +++ b/src/c_defs.go @@ -133,8 +133,13 @@ const ( INS_RDP_QUALITY INS_RDP_DRIVE INS_RDP_NOTE - // TODO: here INS_RDP_OK + INS_CMD_CMD + INS_CMD_SHELL + INS_CMD_SILENT + INS_CMD_NOTE + INS_CMD_OK + // TODO: here ) var ( diff --git a/src/i_events.go b/src/i_events.go index b0d0fda..268fda5 100644 --- a/src/i_events.go +++ b/src/i_events.go @@ -340,8 +340,9 @@ func i_set_protocol_defaults(data *HardData, in *HostNode) { data.ui.insert_sel_max = INS_RDP_OK + len(in.Drive) in.drive_keys = nil case PROTOCOL_CMD: + in.Silent = false in.Shell = []string{"/bin/sh", "-c"} - data.ui.insert_sel_max = 2 + data.ui.insert_sel_max = INS_CMD_OK case PROTOCOL_OS: in.Stack.RegionName = "eu-west-0" in.Stack.IdentityAPI = "3" diff --git a/src/i_insert.go b/src/i_insert.go index 80f4236..f1838d5 100644 --- a/src/i_insert.go +++ b/src/i_insert.go @@ -547,10 +547,31 @@ func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int { return line } -func i_draw_insert_os(ui HardUI, line int, win Quad, in *HostNode) int { - return 0 +func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int { + red := false + if win.T + line >= win.B { return line } + text := "---- Settings ----" + i_draw_text(ui.s, ui.dim[W] / 2 - len(text) / 2, win.T + line, win.R - 1, + win.T + line, ui.style[DEF_STYLE], text) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Command", in.Host, + INS_CMD_CMD, false) + if line += 1; win.T + line >= win.B { return line } + if shell := in.Shell[0]; len(shell) > 0 { + if shell[0] == '~' { + home, _ := os.UserHomeDir() + shell = home + shell[1:] + } + if stat, err := os.Stat(shell); + err != nil || stat.IsDir() == true { + red = true + } + } + i_draw_text_box(ui, win.T + line, win, "Shell", in.Shell[0], + INS_CMD_SHELL, red); + return line } -func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int { - return 0 +func i_draw_insert_os(ui HardUI, line int, win Quad, in *HostNode) int { + return line } |