summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/pkg/rpc/client.go7
-rw-r--r--src/pkg/rpc/server.go4
2 files changed, 9 insertions, 2 deletions
diff --git a/src/pkg/rpc/client.go b/src/pkg/rpc/client.go
index 93884d9a7..8ee4c7419 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 045e2bb4e..cf32eed8d 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);