Prevent psql from issuing BEGIN before ALTER SYSTEM when AUTOCOMMIT is off.
authorFujii Masao
Wed, 2 Jul 2014 03:42:20 +0000 (12:42 +0900)
committerFujii Masao
Wed, 2 Jul 2014 03:42:20 +0000 (12:42 +0900)
The autocommit-off mode works by issuing an implicit BEGIN just before
any command that is not already in a transaction block and is not itself
a BEGIN or other transaction-control command, nor a command that
cannot be executed inside a transaction block. This commit prevents psql
from issuing such an implicit BEGIN before ALTER SYSTEM because it's
not allowed inside a transaction block.

Backpatch to 9.4 where ALTER SYSTEM was added.

Report by Feike Steenbergen

src/bin/psql/common.c

index 60169a2a7dfae3213795f1aedcc9160b8951929e..c08c81366d11775381ce27e09d2a8b252aa5ca52 100644 (file)
@@ -1524,6 +1524,23 @@ command_no_begin(const char *query)
        return false;
    }
 
+   if (wordlen == 5 && pg_strncasecmp(query, "alter", 5) == 0)
+   {
+       query += wordlen;
+
+       query = skip_white_space(query);
+
+       wordlen = 0;
+       while (isalpha((unsigned char) query[wordlen]))
+           wordlen += PQmblen(&query[wordlen], pset.encoding);
+
+       /* ALTER SYSTEM isn't allowed in xacts */
+       if (wordlen == 6 && pg_strncasecmp(query, "system", 6) == 0)
+           return true;
+
+       return false;
+   }
+
    /*
     * Note: these tests will match DROP SYSTEM and REINDEX TABLESPACE, which
     * aren't really valid commands so we don't care much. The other four