Re: BUG #17056: Segmentation fault on altering the type of the foreign table column with a default - Mailing list pgsql-bugs

From Alvaro Herrera
Subject Re: BUG #17056: Segmentation fault on altering the type of the foreign table column with a default
Date
Msg-id 202106141913.cbzfrrcoinxx@alvherre.pgsql
Whole thread Raw
In response to Re: BUG #17056: Segmentation fault on altering the type of the foreign table column with a default  (Andrew Dunstan <andrew@dunslane.net>)
Responses Re: BUG #17056: Segmentation fault on altering the type of the foreign table column with a default  (Andrew Dunstan <andrew@dunslane.net>)
List pgsql-bugs
On 2021-Jun-12, Andrew Dunstan wrote:

> +    /* Don't do anything unless it's a RELKIND type relation */
> +    if (tablerel->rd_rel->relkind != RELKIND_RELATION)
> +    {
> +        table_close(tablerel, AccessExclusiveLock);
> +        return;
> +    }

"RELKIND type relation" is the wrong phrase ... maybe "it's a plain
table" is good enough?  (Ditto in RelationBuildTupleDesc).

>      /*
>       * Here we go --- change the recorded column type and collation.  (Note
>       * heapTup is a copy of the syscache entry, so okay to scribble on.) First
> -     * fix up the missing value if any.
> +     * fix up the missing value if any. There shouldn't be any missing values
> +     * for anything except RELKIND_RELATION relations, but if there are, ignore
> +     * them.
>       */
> -    if (attTup->atthasmissing)
> +    if (rel->rd_rel->relkind == RELKIND_RELATION  && attTup->atthasmissing)

Would it be sensible to have a macro "AttributeHasMissingVal(rel,
attTup)", to use instead of reading atthasmissing directly?  The macro
would check the relkind, and also serve as documentation that said check
is necessary.

-- 
Álvaro Herrera                            39°49'30"S 73°17'W
"Uno puede defenderse de los ataques; contra los elogios se esta indefenso"



pgsql-bugs by date:

Previous
From: Thomas Munro
Date:
Subject: Re: BUG #17058: Unable to create collation in version 13.
Next
From: Andrew Dunstan
Date:
Subject: Re: BUG #17056: Segmentation fault on altering the type of the foreign table column with a default