Commit df70443a authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer/rpc: less panics

parent 043264ca
...@@ -61,20 +61,20 @@ func (b *builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe ...@@ -61,20 +61,20 @@ func (b *builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
go func() { go func() {
defer responseL.Close() defer responseL.Close()
var response BuilderRunResponse
defer func() { runResponseCh <- &response }()
conn, err := responseL.Accept() conn, err := responseL.Accept()
if err != nil { if err != nil {
log.Panic(err) response.Err = err
return
} }
defer conn.Close() defer conn.Close()
decoder := gob.NewDecoder(conn) decoder := gob.NewDecoder(conn)
var response BuilderRunResponse
if err := decoder.Decode(&response); err != nil { if err := decoder.Decode(&response); err != nil {
response.Err = fmt.Errorf("Error waiting for Run: %s", err) response.Err = fmt.Errorf("Error waiting for Run: %s", err)
} }
runResponseCh <- &response
}() }()
args := &BuilderRunArgs{ args := &BuilderRunArgs{
...@@ -154,7 +154,7 @@ func (b *BuilderServer) Run(args *BuilderRunArgs, reply *interface{}) error { ...@@ -154,7 +154,7 @@ func (b *BuilderServer) Run(args *BuilderRunArgs, reply *interface{}) error {
err := responseWriter.Encode(&BuilderRunResponse{responseErr, responseAddress}) err := responseWriter.Encode(&BuilderRunResponse{responseErr, responseAddress})
if err != nil { if err != nil {
panic(err) log.Printf("BuildServer.Run error: %s", err)
} }
}() }()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment