Commit 80f583ff authored by Tom Lane's avatar Tom Lane

Fix omission of locations in outfuncs/readfuncs partitioning node support.

We could have limped along without this for v10, which was my intention
when I annotated the bug in commit 76a3df6e.  But consensus is that it's
better to fix it now and take the cost of a post-beta1 initdb (which is
needed because these node types are stored in pg_class.relpartbound).

Since we're forcing initdb anyway, take the opportunity to make the node
type identification strings match the node struct names, instead of being
randomly different from them.

Discussion: https://postgr.es/m/E1dFBEX-0004wt-8t@gemulon.postgresql.org
parent d5cb3bab
...@@ -3530,7 +3530,7 @@ _outPartitionElem(StringInfo str, const PartitionElem *node) ...@@ -3530,7 +3530,7 @@ _outPartitionElem(StringInfo str, const PartitionElem *node)
static void static void
_outPartitionSpec(StringInfo str, const PartitionSpec *node) _outPartitionSpec(StringInfo str, const PartitionSpec *node)
{ {
WRITE_NODE_TYPE("PARTITIONBY"); WRITE_NODE_TYPE("PARTITIONSPEC");
WRITE_STRING_FIELD(strategy); WRITE_STRING_FIELD(strategy);
WRITE_NODE_FIELD(partParams); WRITE_NODE_FIELD(partParams);
...@@ -3540,23 +3540,23 @@ _outPartitionSpec(StringInfo str, const PartitionSpec *node) ...@@ -3540,23 +3540,23 @@ _outPartitionSpec(StringInfo str, const PartitionSpec *node)
static void static void
_outPartitionBoundSpec(StringInfo str, const PartitionBoundSpec *node) _outPartitionBoundSpec(StringInfo str, const PartitionBoundSpec *node)
{ {
WRITE_NODE_TYPE("PARTITIONBOUND"); WRITE_NODE_TYPE("PARTITIONBOUNDSPEC");
WRITE_CHAR_FIELD(strategy); WRITE_CHAR_FIELD(strategy);
WRITE_NODE_FIELD(listdatums); WRITE_NODE_FIELD(listdatums);
WRITE_NODE_FIELD(lowerdatums); WRITE_NODE_FIELD(lowerdatums);
WRITE_NODE_FIELD(upperdatums); WRITE_NODE_FIELD(upperdatums);
/* XXX somebody forgot location field; too late to change for v10 */ WRITE_LOCATION_FIELD(location);
} }
static void static void
_outPartitionRangeDatum(StringInfo str, const PartitionRangeDatum *node) _outPartitionRangeDatum(StringInfo str, const PartitionRangeDatum *node)
{ {
WRITE_NODE_TYPE("PARTRANGEDATUM"); WRITE_NODE_TYPE("PARTITIONRANGEDATUM");
WRITE_BOOL_FIELD(infinite); WRITE_BOOL_FIELD(infinite);
WRITE_NODE_FIELD(value); WRITE_NODE_FIELD(value);
/* XXX somebody forgot location field; too late to change for v10 */ WRITE_LOCATION_FIELD(location);
} }
/* /*
......
...@@ -2376,8 +2376,7 @@ _readPartitionBoundSpec(void) ...@@ -2376,8 +2376,7 @@ _readPartitionBoundSpec(void)
READ_NODE_FIELD(listdatums); READ_NODE_FIELD(listdatums);
READ_NODE_FIELD(lowerdatums); READ_NODE_FIELD(lowerdatums);
READ_NODE_FIELD(upperdatums); READ_NODE_FIELD(upperdatums);
/* XXX somebody forgot location field; too late to change for v10 */ READ_LOCATION_FIELD(location);
local_node->location = -1;
READ_DONE(); READ_DONE();
} }
...@@ -2392,8 +2391,7 @@ _readPartitionRangeDatum(void) ...@@ -2392,8 +2391,7 @@ _readPartitionRangeDatum(void)
READ_BOOL_FIELD(infinite); READ_BOOL_FIELD(infinite);
READ_NODE_FIELD(value); READ_NODE_FIELD(value);
/* XXX somebody forgot location field; too late to change for v10 */ READ_LOCATION_FIELD(location);
local_node->location = -1;
READ_DONE(); READ_DONE();
} }
...@@ -2638,9 +2636,9 @@ parseNodeString(void) ...@@ -2638,9 +2636,9 @@ parseNodeString(void)
return_value = _readAlternativeSubPlan(); return_value = _readAlternativeSubPlan();
else if (MATCH("EXTENSIBLENODE", 14)) else if (MATCH("EXTENSIBLENODE", 14))
return_value = _readExtensibleNode(); return_value = _readExtensibleNode();
else if (MATCH("PARTITIONBOUND", 14)) else if (MATCH("PARTITIONBOUNDSPEC", 18))
return_value = _readPartitionBoundSpec(); return_value = _readPartitionBoundSpec();
else if (MATCH("PARTRANGEDATUM", 14)) else if (MATCH("PARTITIONRANGEDATUM", 19))
return_value = _readPartitionRangeDatum(); return_value = _readPartitionRangeDatum();
else else
{ {
......
...@@ -53,6 +53,6 @@ ...@@ -53,6 +53,6 @@
*/ */
/* yyyymmddN */ /* yyyymmddN */
#define CATALOG_VERSION_NO 201705141 #define CATALOG_VERSION_NO 201705301
#endif #endif
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment