isTTY bool
+ loop *frontend.Loop
logFunc func(level safcm.LogLevel, escaped bool, msg string)
}
allHosts: allHosts,
allGroups: allGroups,
isTTY: isTTY,
+ loop: loop,
}
s.logFunc = func(level safcm.LogLevel, escaped bool,
msg string) {
- loop.Log(s, level, escaped, msg)
+ s.loop.Log(s, level, escaped, msg)
}
hosts = append(hosts, s)
}
func (s *Sync) logVerbosef(format string, a ...interface{}) {
s.log(safcm.LogVerbose, false, fmt.Sprintf(format, a...))
}
-
-// sendRecv sends a message over conn and waits for the response. Any MsgLog
-// messages received before the final (non MsgLog) response are passed to
-// s.log.
-func (s *Sync) sendRecv(conn *rpc.Conn, msg safcm.Msg) (safcm.Msg, error) {
- err := conn.Send(msg)
- if err != nil {
- return nil, err
- }
- for {
- x, err := conn.Recv()
- if err != nil {
- return nil, err
- }
- log, ok := x.(safcm.MsgLog)
- if ok {
- s.log(log.Level, false, log.Text)
- continue
- }
- return x, nil
- }
-}