From e1f9fdf1bbdbf9afb90fd78aeaf3d384fd2102f2 Mon Sep 17 00:00:00 2001 From: Semesse Date: Sat, 14 Jan 2023 02:33:58 +0800 Subject: [PATCH] fix no corresponding request if req.ID is modified by onSend (#60) --- jsonrpc2.go | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/jsonrpc2.go b/jsonrpc2.go index 7815c84..0bfcc71 100644 --- a/jsonrpc2.go +++ b/jsonrpc2.go @@ -432,8 +432,7 @@ func (c *Conn) send(_ context.Context, m *anyMessage, wait bool) (cc *call, err return nil, ErrClosed } - // Store requests so we can later associate them with incoming - // responses. + // Assign a default id if not set if m.request != nil && wait { cc = &call{request: m.request, seq: c.seq, done: make(chan error, 1)} @@ -445,8 +444,6 @@ func (c *Conn) send(_ context.Context, m *anyMessage, wait bool) (cc *call, err m.request.ID.Num = c.seq } } - id = m.request.ID - c.pending[id] = cc c.seq++ } c.mu.Unlock() @@ -467,6 +464,15 @@ func (c *Conn) send(_ context.Context, m *anyMessage, wait bool) (cc *call, err } } + // Store requests so we can later associate them with incoming + // responses. + if m.request != nil && wait { + c.mu.Lock() + id = m.request.ID + c.pending[id] = cc + c.mu.Unlock() + } + // From here on, if we fail to send this, then we need to remove // this from the pending map so we don't block on it or pile up // pending entries for unsent messages.