diff options
-rw-r--r-- | c_exec.go | 34 | ||||
-rw-r--r-- | c_lhosts.go | 1 |
2 files changed, 25 insertions, 10 deletions
@@ -54,8 +54,31 @@ import ( "strconv" ) +func exec_cmd(cmd_fmt []string) { + cmd := exec.Command(cmd_fmt[0], cmd_fmt[1:]...) + + cmd.Stdin = os.Stdin + cmd.Stdout = os.Stdout + cmd.Stderr = os.Stderr + cmd.Run() +} + +func format_cmd(id uint64, lhost *HostList) { + curr := lhost.head + var cmd_fmt []string + + curr = lhost.sel(id) + if curr == nil { + c_die("host id not found", nil) + } + cmd_fmt = []string{"ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host} + fmt.Println(cmd_fmt) + exec_cmd(cmd_fmt) +} + func display_servers(lhost *HostList) { curr := lhost.head + if lhost.head == nil { fmt.Println("no hosts") return @@ -65,14 +88,5 @@ func display_servers(lhost *HostList) { curr = curr.next } fmt.Println() - curr = lhost.sel(3) - if curr == nil { - c_die("host id not found", nil) - } - fmt.Println ("ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host) - cmd := exec.Command("ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host) - cmd.Stdin = os.Stdin - cmd.Stdout = os.Stdout - cmd.Stderr = os.Stderr - cmd.Run() + format_cmd(3, lhost) } diff --git a/c_lhosts.go b/c_lhosts.go index db932f9..d197607 100644 --- a/c_lhosts.go +++ b/c_lhosts.go @@ -103,6 +103,7 @@ func (lhost *HostList) del(id uint64) { } } +// return the list node with the according id func (lhost *HostList) sel(id uint64) *HostNode { curr := lhost.head for curr.next != nil && curr.ID != id { |