Skip to content

Commit 6de1b53

Browse files
committed
Avoid core dump in _outPathInfo() for Path without a parent RelOptInfo.
Nearly all Paths have parents, but a ResultPath representing an empty FROM clause does not. Avoid a core dump in such cases. I believe this is only a hazard for debugging usage, not for production, else we'd have heard about it before. Nonetheless, back-patch to 9.1 where the troublesome code was introduced. Noted while poking at bug #11703.
1 parent 787e20b commit 6de1b53

File tree

1 file changed

+4
-1
lines changed

1 file changed

+4
-1
lines changed

src/backend/nodes/outfuncs.c

Lines changed: 4 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1470,7 +1470,10 @@ _outPathInfo(StringInfo str, const Path *node)
14701470
{
14711471
WRITE_ENUM_FIELD(pathtype, NodeTag);
14721472
appendStringInfo(str, " :parent_relids ");
1473-
_outBitmapset(str, node->parent->relids);
1473+
if (node->parent)
1474+
_outBitmapset(str, node->parent->relids);
1475+
else
1476+
_outBitmapset(str, NULL);
14741477
appendStringInfo(str, " :required_outer ");
14751478
if (node->param_info)
14761479
_outBitmapset(str, node->param_info->ppi_req_outer);

0 commit comments

Comments
 (0)