patch 9.0.1922: LSP server request message is misinterpreted as a response message

Problem:  LSP server request message is misinterpreted as a response message
Solution: Check that the message does not have the "message" field

closes: #13133

Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
diff --git a/src/channel.c b/src/channel.c
index cdb956e..4326ca7 100644
--- a/src/channel.c
+++ b/src/channel.c
@@ -2927,9 +2927,16 @@
 	    seq_nr = 0;
 	    if (d != NULL)
 	    {
-		di = dict_find(d, (char_u *)"id", -1);
-		if (di != NULL && di->di_tv.v_type == VAR_NUMBER)
-		    seq_nr = di->di_tv.vval.v_number;
+		// When looking for a response message from the LSP server,
+		// ignore new LSP request and notification messages.  LSP
+		// request and notification messages have the "method" field in
+		// the header and the response messages do not have this field.
+		if (!dict_has_key(d, "method"))
+		{
+		    di = dict_find(d, (char_u *)"id", -1);
+		    if (di != NULL && di->di_tv.v_type == VAR_NUMBER)
+			seq_nr = di->di_tv.vval.v_number;
+		}
 	    }
 
 	    argv[1] = *listtv;
diff --git a/src/version.c b/src/version.c
index 5f36234..7e8589b 100644
--- a/src/version.c
+++ b/src/version.c
@@ -700,6 +700,8 @@
 static int included_patches[] =
 {   /* Add new patch number below this line */
 /**/
+    1922,
+/**/
     1921,
 /**/
     1920,