From 50c04132ac43123b968b6057f49d4c387f922ed3 Mon Sep 17 00:00:00 2001 From: Rob Pike Date: Mon, 16 Nov 2009 23:32:16 -0800 Subject: [PATCH] fix bug causing empty strings to be become non-nil errors on client side of rpc connection. R=rsc CC=golang-dev https://golang.org/cl/155078 --- src/pkg/rpc/client.go | 7 ++++++- src/pkg/rpc/server.go | 4 +++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/pkg/rpc/client.go b/src/pkg/rpc/client.go index 93884d9a71..8ee4c7419b 100644 --- a/src/pkg/rpc/client.go +++ b/src/pkg/rpc/client.go @@ -83,7 +83,12 @@ func (client *Client) input() { client.pending[seq] = c, false; client.mutex.Unlock(); err = client.dec.Decode(c.Reply); - c.Error = os.ErrorString(response.Error); + // Empty strings should turn into nil os.Errors + if response.Error != "" { + c.Error = os.ErrorString(response.Error) + } else { + c.Error = nil + } // We don't want to block here. It is the caller's responsibility to make // sure the channel has enough buffer space. See comment in Go(). _ = c.Done <- c; // do not block diff --git a/src/pkg/rpc/server.go b/src/pkg/rpc/server.go index 045e2bb4ee..cf32eed8df 100644 --- a/src/pkg/rpc/server.go +++ b/src/pkg/rpc/server.go @@ -276,7 +276,9 @@ func sendResponse(sending *sync.Mutex, req *Request, reply interface{}, enc *gob resp := new(Response); // Encode the response header resp.ServiceMethod = req.ServiceMethod; - resp.Error = errmsg; + if errmsg != "" { + resp.Error = errmsg + } resp.Seq = req.Seq; sending.Lock(); enc.Encode(resp); -- 2.48.1