mirror of
				https://github.com/postgres/postgres.git
				synced 2025-11-03 09:13:20 +03:00 
			
		
		
		
	Some RELKIND macro refactoring
Add more macros to group some RELKIND_* macros: - RELKIND_HAS_PARTITIONS() - RELKIND_HAS_TABLESPACE() - RELKIND_HAS_TABLE_AM() Reviewed-by: Michael Paquier <michael@paquier.xyz> Reviewed-by: Alvaro Herrera <alvherre@alvh.no-ip.org> Discussion: https://www.postgresql.org/message-id/flat/a574c8f1-9c84-93ad-a9e5-65233d6fc00f%40enterprisedb.com
This commit is contained in:
		@@ -2954,8 +2954,7 @@ reindex_error_callback(void *arg)
 | 
			
		||||
{
 | 
			
		||||
	ReindexErrorInfo *errinfo = (ReindexErrorInfo *) arg;
 | 
			
		||||
 | 
			
		||||
	Assert(errinfo->relkind == RELKIND_PARTITIONED_INDEX ||
 | 
			
		||||
		   errinfo->relkind == RELKIND_PARTITIONED_TABLE);
 | 
			
		||||
	Assert(RELKIND_HAS_PARTITIONS(errinfo->relkind));
 | 
			
		||||
 | 
			
		||||
	if (errinfo->relkind == RELKIND_PARTITIONED_TABLE)
 | 
			
		||||
		errcontext("while reindexing partitioned table \"%s.%s\"",
 | 
			
		||||
@@ -2984,8 +2983,7 @@ ReindexPartitions(Oid relid, ReindexParams *params, bool isTopLevel)
 | 
			
		||||
	ErrorContextCallback errcallback;
 | 
			
		||||
	ReindexErrorInfo errinfo;
 | 
			
		||||
 | 
			
		||||
	Assert(relkind == RELKIND_PARTITIONED_INDEX ||
 | 
			
		||||
		   relkind == RELKIND_PARTITIONED_TABLE);
 | 
			
		||||
	Assert(RELKIND_HAS_PARTITIONS(relkind));
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
	 * Check if this runs in a transaction block, with an error callback to
 | 
			
		||||
@@ -3118,8 +3116,7 @@ ReindexMultipleInternal(List *relids, ReindexParams *params)
 | 
			
		||||
		 * Partitioned tables and indexes can never be processed directly, and
 | 
			
		||||
		 * a list of their leaves should be built first.
 | 
			
		||||
		 */
 | 
			
		||||
		Assert(relkind != RELKIND_PARTITIONED_INDEX &&
 | 
			
		||||
			   relkind != RELKIND_PARTITIONED_TABLE);
 | 
			
		||||
		Assert(!RELKIND_HAS_PARTITIONS(relkind));
 | 
			
		||||
 | 
			
		||||
		if ((params->options & REINDEXOPT_CONCURRENTLY) != 0 &&
 | 
			
		||||
			relpersistence != RELPERSISTENCE_TEMP)
 | 
			
		||||
 
 | 
			
		||||
@@ -916,9 +916,7 @@ DefineRelation(CreateStmt *stmt, char relkind, Oid ownerId,
 | 
			
		||||
					 errmsg("specifying a table access method is not supported on a partitioned table")));
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
	else if (relkind == RELKIND_RELATION ||
 | 
			
		||||
			 relkind == RELKIND_TOASTVALUE ||
 | 
			
		||||
			 relkind == RELKIND_MATVIEW)
 | 
			
		||||
	else if (RELKIND_HAS_TABLE_AM(relkind))
 | 
			
		||||
		accessMethod = default_table_access_method;
 | 
			
		||||
 | 
			
		||||
	/* look up the access method, verify it is for a table */
 | 
			
		||||
@@ -13995,9 +13993,7 @@ ATExecSetTableSpace(Oid tableOid, Oid newTableSpace, LOCKMODE lockmode)
 | 
			
		||||
	}
 | 
			
		||||
	else
 | 
			
		||||
	{
 | 
			
		||||
		Assert(rel->rd_rel->relkind == RELKIND_RELATION ||
 | 
			
		||||
			   rel->rd_rel->relkind == RELKIND_MATVIEW ||
 | 
			
		||||
			   rel->rd_rel->relkind == RELKIND_TOASTVALUE);
 | 
			
		||||
		Assert(RELKIND_HAS_TABLE_AM(rel->rd_rel->relkind));
 | 
			
		||||
		table_relation_copy_data(rel, &newrnode);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user