Update comments

Various places wanted to point out that tuple descriptors don't
contain the variable-length fields of pg_attribute.  This started when
attacl was added, but more fields have been added since, and these
comments haven't been kept up to date consistently.  Reword so that
the purpose is clearer and we don't have to keep updating them.
This commit is contained in:
Peter Eisentraut 2021-11-26 09:57:23 +01:00
parent 99e4d24a9d
commit 36cb5e7c51
3 changed files with 10 additions and 8 deletions

View File

@ -630,7 +630,7 @@ TupleDescInitEntry(TupleDesc desc,
att->attisdropped = false; att->attisdropped = false;
att->attislocal = true; att->attislocal = true;
att->attinhcount = 0; att->attinhcount = 0;
/* attacl, attoptions and attfdwoptions are not present in tupledescs */ /* variable-length fields are not present in tupledescs */
tuple = SearchSysCache1(TYPEOID, ObjectIdGetDatum(oidtypeid)); tuple = SearchSysCache1(TYPEOID, ObjectIdGetDatum(oidtypeid));
if (!HeapTupleIsValid(tuple)) if (!HeapTupleIsValid(tuple))
@ -691,7 +691,7 @@ TupleDescInitBuiltinEntry(TupleDesc desc,
att->attisdropped = false; att->attisdropped = false;
att->attislocal = true; att->attislocal = true;
att->attinhcount = 0; att->attinhcount = 0;
/* attacl, attoptions and attfdwoptions are not present in tupledescs */ /* variable-length fields are not present in tupledescs */
att->atttypid = oidtypeid; att->atttypid = oidtypeid;

View File

@ -723,9 +723,10 @@ CheckAttributeType(const char *attname,
* Construct and insert a set of tuples in pg_attribute. * Construct and insert a set of tuples in pg_attribute.
* *
* Caller has already opened and locked pg_attribute. tupdesc contains the * Caller has already opened and locked pg_attribute. tupdesc contains the
* attributes to insert. attcacheoff is always initialized to -1, attacl, * attributes to insert. attcacheoff is always initialized to -1. attoptions
* attfdwoptions and attmissingval are always initialized to NULL. attoptions * supplies the values for the attoptions fields and must contain the same
* must contain the same number of elements as tupdesc, or be NULL. * number of elements as tupdesc or be NULL. The other variable-length fields
* of pg_attribute are always initialized to null values.
* *
* indstate is the index state for CatalogTupleInsertWithInfo. It can be * indstate is the index state for CatalogTupleInsertWithInfo. It can be
* passed as NULL, in which case we'll fetch the necessary info. (Don't do * passed as NULL, in which case we'll fetch the necessary info. (Don't do

View File

@ -6734,7 +6734,10 @@ ATExecAddColumn(List **wqueue, AlteredTableInfo *tab, Relation rel,
list_make1_oid(rel->rd_rel->reltype), list_make1_oid(rel->rd_rel->reltype),
0); 0);
/* construct new attribute's pg_attribute entry */ /*
* Construct new attribute's pg_attribute entry. (Variable-length fields
* are handled by InsertPgAttributeTuples().)
*/
attribute.attrelid = myrelid; attribute.attrelid = myrelid;
namestrcpy(&(attribute.attname), colDef->colname); namestrcpy(&(attribute.attname), colDef->colname);
attribute.atttypid = typeOid; attribute.atttypid = typeOid;
@ -6758,8 +6761,6 @@ ATExecAddColumn(List **wqueue, AlteredTableInfo *tab, Relation rel,
attribute.attinhcount = colDef->inhcount; attribute.attinhcount = colDef->inhcount;
attribute.attcollation = collOid; attribute.attcollation = collOid;
/* attribute.attacl is handled by InsertPgAttributeTuples() */
ReleaseSysCache(typeTuple); ReleaseSysCache(typeTuple);
tupdesc = CreateTupleDesc(lengthof(aattr), (FormData_pg_attribute **) &aattr); tupdesc = CreateTupleDesc(lengthof(aattr), (FormData_pg_attribute **) &aattr);