Remember to reset yy_start state when firing up repl_scanner.l.
authorTom Lane <[email protected]>
Mon, 24 Jan 2022 17:09:46 +0000 (12:09 -0500)
committerTom Lane <[email protected]>
Mon, 24 Jan 2022 17:09:46 +0000 (12:09 -0500)
Without this, we get odd behavior when the previous cycle of
lexing exited in a non-default exclusive state.  Every other
copy of this code is aware that it has to do BEGIN(INITIAL),
but repl_scanner.l did not get that memo.

The real-world impact of this is probably limited, since most
replication clients would abandon their connection after getting
a syntax error.  Still, it's a bug.

This mistake is old, so back-patch to all supported branches.

Discussion: https://postgr.es/m/1874781.1643035952@sss.pgh.pa.us

src/backend/replication/repl_scanner.l

index 62bb5288c0196b32a157526e3f5bc3d3ea507099..271713af7d35067d5300ce5b29e58316db8f1edd 100644 (file)
@@ -239,6 +239,9 @@ replication_scanner_init(const char *str)
    memcpy(scanbuf, str, slen);
    scanbuf[slen] = scanbuf[slen + 1] = YY_END_OF_BUFFER_CHAR;
    scanbufhandle = yy_scan_buffer(scanbuf, slen + 2);
+
+   /* Make sure we start in proper state */
+   BEGIN(INITIAL);
 }
 
 void