Commit bdc4edbe authored by Peter Eisentraut's avatar Peter Eisentraut

Move catalog index declarations

Move the system catalog index declarations from catalog/indexing.h to
the respective parent tables' catalog/pg_*.h files.  The original
reason for having it split was that the old genbki system produced the
output in the order of the catalog files it read, so all the indexing
stuff needed to come separately.  But this is no longer the case, and
keeping it together makes more sense.
Reviewed-by: default avatarJohn Naylor <john.naylor@enterprisedb.com>
Discussion: https://www.postgresql.org/message-id/flat/c7cc82d6-f976-75d6-2e3e-b03d2cab26bb@2ndquadrant.com
parent b4c9695e
...@@ -38,7 +38,6 @@ ...@@ -38,7 +38,6 @@
#include "access/relation.h" #include "access/relation.h"
#include "access/reloptions.h" #include "access/reloptions.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/pg_foreign_data_wrapper.h" #include "catalog/pg_foreign_data_wrapper.h"
#include "catalog/pg_foreign_server.h" #include "catalog/pg_foreign_server.h"
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_database.h" #include "catalog/pg_database.h"
#include "commands/dbcommands.h" #include "commands/dbcommands.h"
#include "commands/seclabel.h" #include "commands/seclabel.h"
......
...@@ -18,7 +18,6 @@ ...@@ -18,7 +18,6 @@
#include "access/xact.h" #include "access/xact.h"
#include "catalog/catalog.h" #include "catalog/catalog.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_attribute.h" #include "catalog/pg_attribute.h"
#include "catalog/pg_class.h" #include "catalog/pg_class.h"
#include "catalog/pg_database.h" #include "catalog/pg_database.h"
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_namespace.h" #include "catalog/pg_namespace.h"
#include "catalog/pg_proc.h" #include "catalog/pg_proc.h"
#include "catalog/pg_type.h" #include "catalog/pg_type.h"
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_attribute.h" #include "catalog/pg_attribute.h"
#include "catalog/pg_class.h" #include "catalog/pg_class.h"
#include "catalog/pg_namespace.h" #include "catalog/pg_namespace.h"
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_database.h" #include "catalog/pg_database.h"
#include "catalog/pg_namespace.h" #include "catalog/pg_namespace.h"
#include "commands/seclabel.h" #include "commands/seclabel.h"
......
...@@ -18,13 +18,10 @@ ...@@ -18,13 +18,10 @@
<para> <para>
The structures of the catalogs are declared in specially formatted C The structures of the catalogs are declared in specially formatted C
header files in the <filename>src/include/catalog/</filename> directory of header files in the <filename>src/include/catalog/</filename> directory of
the source tree. In particular, for each catalog there is a header file the source tree. For each catalog there is a header file
named after the catalog (e.g., <filename>pg_class.h</filename> named after the catalog (e.g., <filename>pg_class.h</filename>
for <structname>pg_class</structname>), which defines the set of columns for <structname>pg_class</structname>), which defines the set of columns
the catalog has, as well as some other basic properties such as its OID. the catalog has, as well as some other basic properties such as its OID.
Other critical files defining the catalog structure
include <filename>indexing.h</filename>, which defines the indexes present
on all the system catalogs.
</para> </para>
<para> <para>
......
...@@ -72,9 +72,7 @@ CATALOG_HEADERS := \ ...@@ -72,9 +72,7 @@ CATALOG_HEADERS := \
GENERATED_HEADERS := $(CATALOG_HEADERS:%.h=%_d.h) schemapg.h GENERATED_HEADERS := $(CATALOG_HEADERS:%.h=%_d.h) schemapg.h
POSTGRES_BKI_SRCS := $(addprefix $(top_srcdir)/src/include/catalog/,\ POSTGRES_BKI_SRCS := $(addprefix $(top_srcdir)/src/include/catalog/, $(CATALOG_HEADERS))
$(CATALOG_HEADERS) indexing.h \
)
# The .dat files we need can just be listed alphabetically. # The .dat files we need can just be listed alphabetically.
POSTGRES_BKI_DATA = $(addprefix $(top_srcdir)/src/include/catalog/,\ POSTGRES_BKI_DATA = $(addprefix $(top_srcdir)/src/include/catalog/,\
......
...@@ -26,7 +26,6 @@ ...@@ -26,7 +26,6 @@
#include "access/table.h" #include "access/table.h"
#include "access/transam.h" #include "access/transam.h"
#include "catalog/catalog.h" #include "catalog/catalog.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/pg_auth_members.h" #include "catalog/pg_auth_members.h"
#include "catalog/pg_authid.h" #include "catalog/pg_authid.h"
...@@ -248,7 +247,7 @@ IsSharedRelation(Oid relationId) ...@@ -248,7 +247,7 @@ IsSharedRelation(Oid relationId)
relationId == ReplicationOriginRelationId || relationId == ReplicationOriginRelationId ||
relationId == SubscriptionRelationId) relationId == SubscriptionRelationId)
return true; return true;
/* These are their indexes (see indexing.h) */ /* These are their indexes */
if (relationId == AuthIdRolnameIndexId || if (relationId == AuthIdRolnameIndexId ||
relationId == AuthIdOidIndexId || relationId == AuthIdOidIndexId ||
relationId == AuthMemRoleMemIndexId || relationId == AuthMemRoleMemIndexId ||
......
...@@ -21,7 +21,6 @@ ...@@ -21,7 +21,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/catalog.h" #include "catalog/catalog.h"
#include "catalog/indexing.h"
#include "catalog/objectaddress.h" #include "catalog/objectaddress.h"
#include "catalog/pg_am.h" #include "catalog/pg_am.h"
#include "catalog/pg_amop.h" #include "catalog/pg_amop.h"
......
...@@ -24,7 +24,6 @@ ...@@ -24,7 +24,6 @@
#include "access/htup_details.h" #include "access/htup_details.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_aggregate.h" #include "catalog/pg_aggregate.h"
#include "catalog/pg_proc.h" #include "catalog/pg_proc.h"
#include "catalog/pg_type.h" #include "catalog/pg_type.h"
......
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/heap.h" #include "catalog/heap.h"
#include "catalog/index.h" #include "catalog/index.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/objectaccess.h" #include "catalog/objectaccess.h"
#include "catalog/partition.h" #include "catalog/partition.h"
......
...@@ -17,7 +17,6 @@ ...@@ -17,7 +17,6 @@
#include "access/genam.h" #include "access/genam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/indexing.h"
#include "catalog/partition.h" #include "catalog/partition.h"
#include "catalog/pg_inherits.h" #include "catalog/pg_inherits.h"
#include "partitioning/partbounds.h" #include "partitioning/partbounds.h"
......
...@@ -32,7 +32,6 @@ ...@@ -32,7 +32,6 @@
#include "postgres.h" #include "postgres.h"
#include "access/xact.h" #include "access/xact.h"
#include "catalog/indexing.h"
#include "miscadmin.h" #include "miscadmin.h"
#include "nodes/execnodes.h" #include "nodes/execnodes.h"
#include "replication/logical.h" #include "replication/logical.h"
......
...@@ -23,7 +23,6 @@ ...@@ -23,7 +23,6 @@
#include "catalog/catalog.h" #include "catalog/catalog.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/heap.h" #include "catalog/heap.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/objectaccess.h" #include "catalog/objectaccess.h"
#include "catalog/pg_rewrite.h" #include "catalog/pg_rewrite.h"
......
...@@ -16,7 +16,6 @@ ...@@ -16,7 +16,6 @@
#include "access/genam.h" #include "access/genam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/indexing.h"
#include "catalog/pg_enum.h" #include "catalog/pg_enum.h"
#include "libpq/pqformat.h" #include "libpq/pqformat.h"
#include "storage/procarray.h" #include "storage/procarray.h"
......
...@@ -25,7 +25,6 @@ ...@@ -25,7 +25,6 @@
#include "access/sysattr.h" #include "access/sysattr.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/dependency.h" #include "catalog/dependency.h"
#include "catalog/indexing.h"
#include "catalog/pg_aggregate.h" #include "catalog/pg_aggregate.h"
#include "catalog/pg_am.h" #include "catalog/pg_am.h"
#include "catalog/pg_authid.h" #include "catalog/pg_authid.h"
......
...@@ -16,7 +16,6 @@ ...@@ -16,7 +16,6 @@
#include "access/genam.h" #include "access/genam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/relation.h" #include "access/relation.h"
#include "catalog/indexing.h"
#include "catalog/pg_event_trigger.h" #include "catalog/pg_event_trigger.h"
#include "catalog/pg_type.h" #include "catalog/pg_type.h"
#include "commands/trigger.h" #include "commands/trigger.h"
......
...@@ -16,7 +16,6 @@ ...@@ -16,7 +16,6 @@
#include "access/genam.h" #include "access/genam.h"
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/indexing.h"
#include "catalog/pg_class.h" #include "catalog/pg_class.h"
#include "catalog/pg_tablespace.h" #include "catalog/pg_tablespace.h"
#include "miscadmin.h" #include "miscadmin.h"
......
...@@ -22,7 +22,6 @@ ...@@ -22,7 +22,6 @@
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/sysattr.h" #include "access/sysattr.h"
#include "catalog/indexing.h"
#include "catalog/pg_aggregate.h" #include "catalog/pg_aggregate.h"
#include "catalog/pg_am.h" #include "catalog/pg_am.h"
#include "catalog/pg_amop.h" #include "catalog/pg_amop.h"
...@@ -97,7 +96,7 @@ ...@@ -97,7 +96,7 @@
There must be a unique index underlying each syscache (ie, an index There must be a unique index underlying each syscache (ie, an index
whose key is the same as that of the cache). If there is not one whose key is the same as that of the cache). If there is not one
already, add definitions for it to include/catalog/indexing.h: you need already, add definitions for it to include/catalog/pg_*.h: you need
to add a DECLARE_UNIQUE_INDEX macro and a #define for the index OID. to add a DECLARE_UNIQUE_INDEX macro and a #define for the index OID.
(Adding an index requires a catversion.h update, while simply (Adding an index requires a catversion.h update, while simply
adding/deleting caches only requires a recompile.) adding/deleting caches only requires a recompile.)
......
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
#include "access/htup_details.h" #include "access/htup_details.h"
#include "access/table.h" #include "access/table.h"
#include "access/xact.h" #include "access/xact.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/pg_ts_config.h" #include "catalog/pg_ts_config.h"
#include "catalog/pg_ts_config_map.h" #include "catalog/pg_ts_config_map.h"
......
...@@ -50,7 +50,6 @@ ...@@ -50,7 +50,6 @@
#include "access/relation.h" #include "access/relation.h"
#include "access/session.h" #include "access/session.h"
#include "access/table.h" #include "access/table.h"
#include "catalog/indexing.h"
#include "catalog/pg_am.h" #include "catalog/pg_am.h"
#include "catalog/pg_constraint.h" #include "catalog/pg_constraint.h"
#include "catalog/pg_enum.h" #include "catalog/pg_enum.h"
......
...@@ -28,7 +28,6 @@ ...@@ -28,7 +28,6 @@
#include "access/xact.h" #include "access/xact.h"
#include "access/xlog.h" #include "access/xlog.h"
#include "catalog/catalog.h" #include "catalog/catalog.h"
#include "catalog/indexing.h"
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/pg_authid.h" #include "catalog/pg_authid.h"
#include "catalog/pg_database.h" #include "catalog/pg_database.h"
......
...@@ -26,7 +26,7 @@ chdir $FindBin::RealBin or die "could not cd to $FindBin::RealBin: $!\n"; ...@@ -26,7 +26,7 @@ chdir $FindBin::RealBin or die "could not cd to $FindBin::RealBin: $!\n";
use lib "$FindBin::RealBin/../../backend/catalog/"; use lib "$FindBin::RealBin/../../backend/catalog/";
use Catalog; use Catalog;
my @input_files = (glob("pg_*.h"), qw(indexing.h)); my @input_files = glob("pg_*.h");
my $oids = Catalog::FindAllOidsFromHeaders(@input_files); my $oids = Catalog::FindAllOidsFromHeaders(@input_files);
......
...@@ -54,6 +54,23 @@ ...@@ -54,6 +54,23 @@
*/ */
#define DECLARE_TOAST(name,toastoid,indexoid) extern int no_such_variable #define DECLARE_TOAST(name,toastoid,indexoid) extern int no_such_variable
/*
* These lines processed by genbki.pl to create the statements
* the bootstrap parser will turn into DefineIndex calls.
*
* The keyword is DECLARE_INDEX or DECLARE_UNIQUE_INDEX. The first two
* arguments are the index name and OID, the rest is much like a standard
* 'create index' SQL command.
*
* For each index, we also provide a #define for its OID. References to
* the index in the C code should always use these #defines, not the actual
* index name (much less the numeric OID).
*
* The macro definitions are just to keep the C compiler from spitting up.
*/
#define DECLARE_INDEX(name,oid,decl) extern int no_such_variable
#define DECLARE_UNIQUE_INDEX(name,oid,decl) extern int no_such_variable
/* The following are never defined; they are here only for documentation. */ /* The following are never defined; they are here only for documentation. */
/* /*
......
This diff is collapsed.
...@@ -110,6 +110,9 @@ typedef FormData_pg_aggregate *Form_pg_aggregate; ...@@ -110,6 +110,9 @@ typedef FormData_pg_aggregate *Form_pg_aggregate;
DECLARE_TOAST(pg_aggregate, 4159, 4160); DECLARE_TOAST(pg_aggregate, 4159, 4160);
DECLARE_UNIQUE_INDEX(pg_aggregate_fnoid_index, 2650, on pg_aggregate using btree(aggfnoid oid_ops));
#define AggregateFnoidIndexId 2650
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -47,6 +47,11 @@ CATALOG(pg_am,2601,AccessMethodRelationId) ...@@ -47,6 +47,11 @@ CATALOG(pg_am,2601,AccessMethodRelationId)
*/ */
typedef FormData_pg_am *Form_pg_am; typedef FormData_pg_am *Form_pg_am;
DECLARE_UNIQUE_INDEX(pg_am_name_index, 2651, on pg_am using btree(amname name_ops));
#define AmNameIndexId 2651
DECLARE_UNIQUE_INDEX(pg_am_oid_index, 2652, on pg_am using btree(oid oid_ops));
#define AmOidIndexId 2652
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -87,6 +87,13 @@ CATALOG(pg_amop,2602,AccessMethodOperatorRelationId) ...@@ -87,6 +87,13 @@ CATALOG(pg_amop,2602,AccessMethodOperatorRelationId)
*/ */
typedef FormData_pg_amop *Form_pg_amop; typedef FormData_pg_amop *Form_pg_amop;
DECLARE_UNIQUE_INDEX(pg_amop_fam_strat_index, 2653, on pg_amop using btree(amopfamily oid_ops, amoplefttype oid_ops, amoprighttype oid_ops, amopstrategy int2_ops));
#define AccessMethodStrategyIndexId 2653
DECLARE_UNIQUE_INDEX(pg_amop_opr_fam_index, 2654, on pg_amop using btree(amopopr oid_ops, amoppurpose char_ops, amopfamily oid_ops));
#define AccessMethodOperatorIndexId 2654
DECLARE_UNIQUE_INDEX(pg_amop_oid_index, 2756, on pg_amop using btree(oid oid_ops));
#define AccessMethodOperatorOidIndexId 2756
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* allowed values of amoppurpose: */ /* allowed values of amoppurpose: */
......
...@@ -67,4 +67,9 @@ CATALOG(pg_amproc,2603,AccessMethodProcedureRelationId) ...@@ -67,4 +67,9 @@ CATALOG(pg_amproc,2603,AccessMethodProcedureRelationId)
*/ */
typedef FormData_pg_amproc *Form_pg_amproc; typedef FormData_pg_amproc *Form_pg_amproc;
DECLARE_UNIQUE_INDEX(pg_amproc_fam_proc_index, 2655, on pg_amproc using btree(amprocfamily oid_ops, amproclefttype oid_ops, amprocrighttype oid_ops, amprocnum int2_ops));
#define AccessMethodProcedureIndexId 2655
DECLARE_UNIQUE_INDEX(pg_amproc_oid_index, 2757, on pg_amproc using btree(oid oid_ops));
#define AccessMethodProcedureOidIndexId 2757
#endif /* PG_AMPROC_H */ #endif /* PG_AMPROC_H */
...@@ -48,4 +48,9 @@ typedef FormData_pg_attrdef *Form_pg_attrdef; ...@@ -48,4 +48,9 @@ typedef FormData_pg_attrdef *Form_pg_attrdef;
DECLARE_TOAST(pg_attrdef, 2830, 2831); DECLARE_TOAST(pg_attrdef, 2830, 2831);
DECLARE_UNIQUE_INDEX(pg_attrdef_adrelid_adnum_index, 2656, on pg_attrdef using btree(adrelid oid_ops, adnum int2_ops));
#define AttrDefaultIndexId 2656
DECLARE_UNIQUE_INDEX(pg_attrdef_oid_index, 2657, on pg_attrdef using btree(oid oid_ops));
#define AttrDefaultOidIndexId 2657
#endif /* PG_ATTRDEF_H */ #endif /* PG_ATTRDEF_H */
...@@ -192,6 +192,11 @@ CATALOG(pg_attribute,1249,AttributeRelationId) BKI_BOOTSTRAP BKI_ROWTYPE_OID(75, ...@@ -192,6 +192,11 @@ CATALOG(pg_attribute,1249,AttributeRelationId) BKI_BOOTSTRAP BKI_ROWTYPE_OID(75,
*/ */
typedef FormData_pg_attribute *Form_pg_attribute; typedef FormData_pg_attribute *Form_pg_attribute;
DECLARE_UNIQUE_INDEX(pg_attribute_relid_attnam_index, 2658, on pg_attribute using btree(attrelid oid_ops, attname name_ops));
#define AttributeRelidNameIndexId 2658
DECLARE_UNIQUE_INDEX(pg_attribute_relid_attnum_index, 2659, on pg_attribute using btree(attrelid oid_ops, attnum int2_ops));
#define AttributeRelidNumIndexId 2659
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
#define ATTRIBUTE_IDENTITY_ALWAYS 'a' #define ATTRIBUTE_IDENTITY_ALWAYS 'a'
......
...@@ -42,4 +42,9 @@ CATALOG(pg_auth_members,1261,AuthMemRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_ ...@@ -42,4 +42,9 @@ CATALOG(pg_auth_members,1261,AuthMemRelationId) BKI_SHARED_RELATION BKI_ROWTYPE_
*/ */
typedef FormData_pg_auth_members *Form_pg_auth_members; typedef FormData_pg_auth_members *Form_pg_auth_members;
DECLARE_UNIQUE_INDEX(pg_auth_members_role_member_index, 2694, on pg_auth_members using btree(roleid oid_ops, member oid_ops));
#define AuthMemRoleMemIndexId 2694
DECLARE_UNIQUE_INDEX(pg_auth_members_member_role_index, 2695, on pg_auth_members using btree(member oid_ops, roleid oid_ops));
#define AuthMemMemRoleIndexId 2695
#endif /* PG_AUTH_MEMBERS_H */ #endif /* PG_AUTH_MEMBERS_H */
...@@ -59,4 +59,9 @@ DECLARE_TOAST(pg_authid, 4175, 4176); ...@@ -59,4 +59,9 @@ DECLARE_TOAST(pg_authid, 4175, 4176);
#define PgAuthidToastTable 4175 #define PgAuthidToastTable 4175
#define PgAuthidToastIndex 4176 #define PgAuthidToastIndex 4176
DECLARE_UNIQUE_INDEX(pg_authid_rolname_index, 2676, on pg_authid using btree(rolname name_ops));
#define AuthIdRolnameIndexId 2676
DECLARE_UNIQUE_INDEX(pg_authid_oid_index, 2677, on pg_authid using btree(oid oid_ops));
#define AuthIdOidIndexId 2677
#endif /* PG_AUTHID_H */ #endif /* PG_AUTHID_H */
...@@ -56,6 +56,11 @@ CATALOG(pg_cast,2605,CastRelationId) ...@@ -56,6 +56,11 @@ CATALOG(pg_cast,2605,CastRelationId)
*/ */
typedef FormData_pg_cast *Form_pg_cast; typedef FormData_pg_cast *Form_pg_cast;
DECLARE_UNIQUE_INDEX(pg_cast_oid_index, 2660, on pg_cast using btree(oid oid_ops));
#define CastOidIndexId 2660
DECLARE_UNIQUE_INDEX(pg_cast_source_target_index, 2661, on pg_cast using btree(castsource oid_ops, casttarget oid_ops));
#define CastSourceTargetIndexId 2661
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -152,6 +152,13 @@ CATALOG(pg_class,1259,RelationRelationId) BKI_BOOTSTRAP BKI_ROWTYPE_OID(83,Relat ...@@ -152,6 +152,13 @@ CATALOG(pg_class,1259,RelationRelationId) BKI_BOOTSTRAP BKI_ROWTYPE_OID(83,Relat
*/ */
typedef FormData_pg_class *Form_pg_class; typedef FormData_pg_class *Form_pg_class;
DECLARE_UNIQUE_INDEX(pg_class_oid_index, 2662, on pg_class using btree(oid oid_ops));
#define ClassOidIndexId 2662
DECLARE_UNIQUE_INDEX(pg_class_relname_nsp_index, 2663, on pg_class using btree(relname name_ops, relnamespace oid_ops));
#define ClassNameNspIndexId 2663
DECLARE_INDEX(pg_class_tblspc_relfilenode_index, 3455, on pg_class using btree(reltablespace oid_ops, relfilenode oid_ops));
#define ClassTblspcRelfilenodeIndexId 3455
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
#define RELKIND_RELATION 'r' /* ordinary table */ #define RELKIND_RELATION 'r' /* ordinary table */
......
...@@ -46,6 +46,11 @@ CATALOG(pg_collation,3456,CollationRelationId) ...@@ -46,6 +46,11 @@ CATALOG(pg_collation,3456,CollationRelationId)
*/ */
typedef FormData_pg_collation *Form_pg_collation; typedef FormData_pg_collation *Form_pg_collation;
DECLARE_UNIQUE_INDEX(pg_collation_name_enc_nsp_index, 3164, on pg_collation using btree(collname name_ops, collencoding int4_ops, collnamespace oid_ops));
#define CollationNameEncNspIndexId 3164
DECLARE_UNIQUE_INDEX(pg_collation_oid_index, 3085, on pg_collation using btree(oid oid_ops));
#define CollationOidIndexId 3085
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
#define COLLPROVIDER_DEFAULT 'd' #define COLLPROVIDER_DEFAULT 'd'
......
...@@ -155,6 +155,17 @@ typedef FormData_pg_constraint *Form_pg_constraint; ...@@ -155,6 +155,17 @@ typedef FormData_pg_constraint *Form_pg_constraint;
DECLARE_TOAST(pg_constraint, 2832, 2833); DECLARE_TOAST(pg_constraint, 2832, 2833);
DECLARE_INDEX(pg_constraint_conname_nsp_index, 2664, on pg_constraint using btree(conname name_ops, connamespace oid_ops));
#define ConstraintNameNspIndexId 2664
DECLARE_UNIQUE_INDEX(pg_constraint_conrelid_contypid_conname_index, 2665, on pg_constraint using btree(conrelid oid_ops, contypid oid_ops, conname name_ops));
#define ConstraintRelidTypidNameIndexId 2665
DECLARE_INDEX(pg_constraint_contypid_index, 2666, on pg_constraint using btree(contypid oid_ops));
#define ConstraintTypidIndexId 2666
DECLARE_UNIQUE_INDEX(pg_constraint_oid_index, 2667, on pg_constraint using btree(oid oid_ops));
#define ConstraintOidIndexId 2667
DECLARE_INDEX(pg_constraint_conparentid_index, 2579, on pg_constraint using btree(conparentid oid_ops));
#define ConstraintParentIndexId 2579
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* Valid values for contype */ /* Valid values for contype */
......
...@@ -60,6 +60,13 @@ CATALOG(pg_conversion,2607,ConversionRelationId) ...@@ -60,6 +60,13 @@ CATALOG(pg_conversion,2607,ConversionRelationId)
*/ */
typedef FormData_pg_conversion *Form_pg_conversion; typedef FormData_pg_conversion *Form_pg_conversion;
DECLARE_UNIQUE_INDEX(pg_conversion_default_index, 2668, on pg_conversion using btree(connamespace oid_ops, conforencoding int4_ops, contoencoding int4_ops, oid oid_ops));
#define ConversionDefaultIndexId 2668
DECLARE_UNIQUE_INDEX(pg_conversion_name_nsp_index, 2669, on pg_conversion using btree(conname name_ops, connamespace oid_ops));
#define ConversionNameNspIndexId 2669
DECLARE_UNIQUE_INDEX(pg_conversion_oid_index, 2670, on pg_conversion using btree(oid oid_ops));
#define ConversionOidIndexId 2670
extern ObjectAddress ConversionCreate(const char *conname, Oid connamespace, extern ObjectAddress ConversionCreate(const char *conname, Oid connamespace,
Oid conowner, Oid conowner,
......
...@@ -84,4 +84,9 @@ DECLARE_TOAST(pg_database, 4177, 4178); ...@@ -84,4 +84,9 @@ DECLARE_TOAST(pg_database, 4177, 4178);
#define PgDatabaseToastTable 4177 #define PgDatabaseToastTable 4177
#define PgDatabaseToastIndex 4178 #define PgDatabaseToastIndex 4178
DECLARE_UNIQUE_INDEX(pg_database_datname_index, 2671, on pg_database using btree(datname name_ops));
#define DatabaseNameIndexId 2671
DECLARE_UNIQUE_INDEX(pg_database_oid_index, 2672, on pg_database using btree(oid oid_ops));
#define DatabaseOidIndexId 2672
#endif /* PG_DATABASE_H */ #endif /* PG_DATABASE_H */
...@@ -47,6 +47,9 @@ DECLARE_TOAST(pg_db_role_setting, 2966, 2967); ...@@ -47,6 +47,9 @@ DECLARE_TOAST(pg_db_role_setting, 2966, 2967);
#define PgDbRoleSettingToastTable 2966 #define PgDbRoleSettingToastTable 2966
#define PgDbRoleSettingToastIndex 2967 #define PgDbRoleSettingToastIndex 2967
DECLARE_UNIQUE_INDEX(pg_db_role_setting_databaseid_rol_index, 2965, on pg_db_role_setting using btree(setdatabase oid_ops, setrole oid_ops));
#define DbRoleSettingDatidRolidIndexId 2965
/* /*
* prototypes for functions in pg_db_role_setting.h * prototypes for functions in pg_db_role_setting.h
*/ */
......
...@@ -49,6 +49,11 @@ typedef FormData_pg_default_acl *Form_pg_default_acl; ...@@ -49,6 +49,11 @@ typedef FormData_pg_default_acl *Form_pg_default_acl;
DECLARE_TOAST(pg_default_acl, 4143, 4144); DECLARE_TOAST(pg_default_acl, 4143, 4144);
DECLARE_UNIQUE_INDEX(pg_default_acl_role_nsp_obj_index, 827, on pg_default_acl using btree(defaclrole oid_ops, defaclnamespace oid_ops, defaclobjtype char_ops));
#define DefaultAclRoleNspObjIndexId 827
DECLARE_UNIQUE_INDEX(pg_default_acl_oid_index, 828, on pg_default_acl using btree(oid oid_ops));
#define DefaultAclOidIndexId 828
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -75,4 +75,9 @@ typedef FormData_pg_depend *Form_pg_depend; ...@@ -75,4 +75,9 @@ typedef FormData_pg_depend *Form_pg_depend;
DECLARE_TOAST(pg_depend, 8888, 8889); DECLARE_TOAST(pg_depend, 8888, 8889);
DECLARE_INDEX(pg_depend_depender_index, 2673, on pg_depend using btree(classid oid_ops, objid oid_ops, objsubid int4_ops));
#define DependDependerIndexId 2673
DECLARE_INDEX(pg_depend_reference_index, 2674, on pg_depend using btree(refclassid oid_ops, refobjid oid_ops, refobjsubid int4_ops));
#define DependReferenceIndexId 2674
#endif /* PG_DEPEND_H */ #endif /* PG_DEPEND_H */
...@@ -65,4 +65,7 @@ typedef FormData_pg_description * Form_pg_description; ...@@ -65,4 +65,7 @@ typedef FormData_pg_description * Form_pg_description;
DECLARE_TOAST(pg_description, 2834, 2835); DECLARE_TOAST(pg_description, 2834, 2835);
DECLARE_UNIQUE_INDEX(pg_description_o_c_o_index, 2675, on pg_description using btree(objoid oid_ops, classoid oid_ops, objsubid int4_ops));
#define DescriptionObjIndexId 2675
#endif /* PG_DESCRIPTION_H */ #endif /* PG_DESCRIPTION_H */
...@@ -43,6 +43,13 @@ CATALOG(pg_enum,3501,EnumRelationId) ...@@ -43,6 +43,13 @@ CATALOG(pg_enum,3501,EnumRelationId)
*/ */
typedef FormData_pg_enum *Form_pg_enum; typedef FormData_pg_enum *Form_pg_enum;
DECLARE_UNIQUE_INDEX(pg_enum_oid_index, 3502, on pg_enum using btree(oid oid_ops));
#define EnumOidIndexId 3502
DECLARE_UNIQUE_INDEX(pg_enum_typid_label_index, 3503, on pg_enum using btree(enumtypid oid_ops, enumlabel name_ops));
#define EnumTypIdLabelIndexId 3503
DECLARE_UNIQUE_INDEX(pg_enum_typid_sortorder_index, 3534, on pg_enum using btree(enumtypid oid_ops, enumsortorder float4_ops));
#define EnumTypIdSortOrderIndexId 3534
/* /*
* prototypes for functions in pg_enum.c * prototypes for functions in pg_enum.c
*/ */
......
...@@ -50,4 +50,9 @@ typedef FormData_pg_event_trigger *Form_pg_event_trigger; ...@@ -50,4 +50,9 @@ typedef FormData_pg_event_trigger *Form_pg_event_trigger;
DECLARE_TOAST(pg_event_trigger, 4145, 4146); DECLARE_TOAST(pg_event_trigger, 4145, 4146);
DECLARE_UNIQUE_INDEX(pg_event_trigger_evtname_index, 3467, on pg_event_trigger using btree(evtname name_ops));
#define EventTriggerNameIndexId 3467
DECLARE_UNIQUE_INDEX(pg_event_trigger_oid_index, 3468, on pg_event_trigger using btree(oid oid_ops));
#define EventTriggerOidIndexId 3468
#endif /* PG_EVENT_TRIGGER_H */ #endif /* PG_EVENT_TRIGGER_H */
...@@ -51,4 +51,9 @@ typedef FormData_pg_extension *Form_pg_extension; ...@@ -51,4 +51,9 @@ typedef FormData_pg_extension *Form_pg_extension;
DECLARE_TOAST(pg_extension, 4147, 4148); DECLARE_TOAST(pg_extension, 4147, 4148);
DECLARE_UNIQUE_INDEX(pg_extension_oid_index, 3080, on pg_extension using btree(oid oid_ops));
#define ExtensionOidIndexId 3080
DECLARE_UNIQUE_INDEX(pg_extension_name_index, 3081, on pg_extension using btree(extname name_ops));
#define ExtensionNameIndexId 3081
#endif /* PG_EXTENSION_H */ #endif /* PG_EXTENSION_H */
...@@ -49,4 +49,9 @@ typedef FormData_pg_foreign_data_wrapper *Form_pg_foreign_data_wrapper; ...@@ -49,4 +49,9 @@ typedef FormData_pg_foreign_data_wrapper *Form_pg_foreign_data_wrapper;
DECLARE_TOAST(pg_foreign_data_wrapper, 4149, 4150); DECLARE_TOAST(pg_foreign_data_wrapper, 4149, 4150);
DECLARE_UNIQUE_INDEX(pg_foreign_data_wrapper_oid_index, 112, on pg_foreign_data_wrapper using btree(oid oid_ops));
#define ForeignDataWrapperOidIndexId 112
DECLARE_UNIQUE_INDEX(pg_foreign_data_wrapper_name_index, 548, on pg_foreign_data_wrapper using btree(fdwname name_ops));
#define ForeignDataWrapperNameIndexId 548
#endif /* PG_FOREIGN_DATA_WRAPPER_H */ #endif /* PG_FOREIGN_DATA_WRAPPER_H */
...@@ -49,4 +49,9 @@ typedef FormData_pg_foreign_server *Form_pg_foreign_server; ...@@ -49,4 +49,9 @@ typedef FormData_pg_foreign_server *Form_pg_foreign_server;
DECLARE_TOAST(pg_foreign_server, 4151, 4152); DECLARE_TOAST(pg_foreign_server, 4151, 4152);
DECLARE_UNIQUE_INDEX(pg_foreign_server_oid_index, 113, on pg_foreign_server using btree(oid oid_ops));
#define ForeignServerOidIndexId 113
DECLARE_UNIQUE_INDEX(pg_foreign_server_name_index, 549, on pg_foreign_server using btree(srvname name_ops));
#define ForeignServerNameIndexId 549
#endif /* PG_FOREIGN_SERVER_H */ #endif /* PG_FOREIGN_SERVER_H */
...@@ -44,4 +44,7 @@ typedef FormData_pg_foreign_table *Form_pg_foreign_table; ...@@ -44,4 +44,7 @@ typedef FormData_pg_foreign_table *Form_pg_foreign_table;
DECLARE_TOAST(pg_foreign_table, 4153, 4154); DECLARE_TOAST(pg_foreign_table, 4153, 4154);
DECLARE_UNIQUE_INDEX(pg_foreign_table_relid_index, 3119, on pg_foreign_table using btree(ftrelid oid_ops));
#define ForeignTableRelidIndexId 3119
#endif /* PG_FOREIGN_TABLE_H */ #endif /* PG_FOREIGN_TABLE_H */
...@@ -67,6 +67,11 @@ CATALOG(pg_index,2610,IndexRelationId) BKI_SCHEMA_MACRO ...@@ -67,6 +67,11 @@ CATALOG(pg_index,2610,IndexRelationId) BKI_SCHEMA_MACRO
*/ */
typedef FormData_pg_index *Form_pg_index; typedef FormData_pg_index *Form_pg_index;
DECLARE_INDEX(pg_index_indrelid_index, 2678, on pg_index using btree(indrelid oid_ops));
#define IndexIndrelidIndexId 2678
DECLARE_UNIQUE_INDEX(pg_index_indexrelid_index, 2679, on pg_index using btree(indexrelid oid_ops));
#define IndexRelidIndexId 2679
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -43,6 +43,11 @@ CATALOG(pg_inherits,2611,InheritsRelationId) ...@@ -43,6 +43,11 @@ CATALOG(pg_inherits,2611,InheritsRelationId)
*/ */
typedef FormData_pg_inherits *Form_pg_inherits; typedef FormData_pg_inherits *Form_pg_inherits;
DECLARE_UNIQUE_INDEX(pg_inherits_relid_seqno_index, 2680, on pg_inherits using btree(inhrelid oid_ops, inhseqno int4_ops));
#define InheritsRelidSeqnoIndexId 2680
DECLARE_INDEX(pg_inherits_parent_index, 2187, on pg_inherits using btree(inhparent oid_ops));
#define InheritsParentIndexId 2187
extern List *find_inheritance_children(Oid parentrelId, LOCKMODE lockmode); extern List *find_inheritance_children(Oid parentrelId, LOCKMODE lockmode);
extern List *find_all_inheritors(Oid parentrelId, LOCKMODE lockmode, extern List *find_all_inheritors(Oid parentrelId, LOCKMODE lockmode,
......
...@@ -64,6 +64,9 @@ typedef FormData_pg_init_privs * Form_pg_init_privs; ...@@ -64,6 +64,9 @@ typedef FormData_pg_init_privs * Form_pg_init_privs;
DECLARE_TOAST(pg_init_privs, 4155, 4156); DECLARE_TOAST(pg_init_privs, 4155, 4156);
DECLARE_UNIQUE_INDEX(pg_init_privs_o_c_o_index, 3395, on pg_init_privs using btree(objoid oid_ops, classoid oid_ops, objsubid int4_ops));
#define InitPrivsObjIndexId 3395
/* /*
* It is important to know if the initial privileges are from initdb or from an * It is important to know if the initial privileges are from initdb or from an
* extension. This enum is used to provide that differentiation and the two * extension. This enum is used to provide that differentiation and the two
......
...@@ -66,4 +66,9 @@ typedef FormData_pg_language *Form_pg_language; ...@@ -66,4 +66,9 @@ typedef FormData_pg_language *Form_pg_language;
DECLARE_TOAST(pg_language, 4157, 4158); DECLARE_TOAST(pg_language, 4157, 4158);
DECLARE_UNIQUE_INDEX(pg_language_name_index, 2681, on pg_language using btree(lanname name_ops));
#define LanguageNameIndexId 2681
DECLARE_UNIQUE_INDEX(pg_language_oid_index, 2682, on pg_language using btree(oid oid_ops));
#define LanguageOidIndexId 2682
#endif /* PG_LANGUAGE_H */ #endif /* PG_LANGUAGE_H */
...@@ -43,6 +43,9 @@ CATALOG(pg_largeobject,2613,LargeObjectRelationId) ...@@ -43,6 +43,9 @@ CATALOG(pg_largeobject,2613,LargeObjectRelationId)
*/ */
typedef FormData_pg_largeobject *Form_pg_largeobject; typedef FormData_pg_largeobject *Form_pg_largeobject;
DECLARE_UNIQUE_INDEX(pg_largeobject_loid_pn_index, 2683, on pg_largeobject using btree(loid oid_ops, pageno int4_ops));
#define LargeObjectLOidPNIndexId 2683
extern Oid LargeObjectCreate(Oid loid); extern Oid LargeObjectCreate(Oid loid);
extern void LargeObjectDrop(Oid loid); extern void LargeObjectDrop(Oid loid);
extern bool LargeObjectExists(Oid loid); extern bool LargeObjectExists(Oid loid);
......
...@@ -45,4 +45,7 @@ CATALOG(pg_largeobject_metadata,2995,LargeObjectMetadataRelationId) ...@@ -45,4 +45,7 @@ CATALOG(pg_largeobject_metadata,2995,LargeObjectMetadataRelationId)
*/ */
typedef FormData_pg_largeobject_metadata *Form_pg_largeobject_metadata; typedef FormData_pg_largeobject_metadata *Form_pg_largeobject_metadata;
DECLARE_UNIQUE_INDEX(pg_largeobject_metadata_oid_index, 2996, on pg_largeobject_metadata using btree(oid oid_ops));
#define LargeObjectMetadataOidIndexId 2996
#endif /* PG_LARGEOBJECT_METADATA_H */ #endif /* PG_LARGEOBJECT_METADATA_H */
...@@ -53,6 +53,11 @@ typedef FormData_pg_namespace *Form_pg_namespace; ...@@ -53,6 +53,11 @@ typedef FormData_pg_namespace *Form_pg_namespace;
DECLARE_TOAST(pg_namespace, 4163, 4164); DECLARE_TOAST(pg_namespace, 4163, 4164);
DECLARE_UNIQUE_INDEX(pg_namespace_nspname_index, 2684, on pg_namespace using btree(nspname name_ops));
#define NamespaceNameIndexId 2684
DECLARE_UNIQUE_INDEX(pg_namespace_oid_index, 2685, on pg_namespace using btree(oid oid_ops));
#define NamespaceOidIndexId 2685
/* /*
* prototypes for functions in pg_namespace.c * prototypes for functions in pg_namespace.c
*/ */
......
...@@ -82,4 +82,9 @@ CATALOG(pg_opclass,2616,OperatorClassRelationId) ...@@ -82,4 +82,9 @@ CATALOG(pg_opclass,2616,OperatorClassRelationId)
*/ */
typedef FormData_pg_opclass *Form_pg_opclass; typedef FormData_pg_opclass *Form_pg_opclass;
DECLARE_UNIQUE_INDEX(pg_opclass_am_name_nsp_index, 2686, on pg_opclass using btree(opcmethod oid_ops, opcname name_ops, opcnamespace oid_ops));
#define OpclassAmNameNspIndexId 2686
DECLARE_UNIQUE_INDEX(pg_opclass_oid_index, 2687, on pg_opclass using btree(oid oid_ops));
#define OpclassOidIndexId 2687
#endif /* PG_OPCLASS_H */ #endif /* PG_OPCLASS_H */
...@@ -82,6 +82,11 @@ CATALOG(pg_operator,2617,OperatorRelationId) ...@@ -82,6 +82,11 @@ CATALOG(pg_operator,2617,OperatorRelationId)
*/ */
typedef FormData_pg_operator *Form_pg_operator; typedef FormData_pg_operator *Form_pg_operator;
DECLARE_UNIQUE_INDEX(pg_operator_oid_index, 2688, on pg_operator using btree(oid oid_ops));
#define OperatorOidIndexId 2688
DECLARE_UNIQUE_INDEX(pg_operator_oprname_l_r_n_index, 2689, on pg_operator using btree(oprname name_ops, oprleft oid_ops, oprright oid_ops, oprnamespace oid_ops));
#define OperatorNameNspIndexId 2689
extern ObjectAddress OperatorCreate(const char *operatorName, extern ObjectAddress OperatorCreate(const char *operatorName,
Oid operatorNamespace, Oid operatorNamespace,
......
...@@ -50,6 +50,11 @@ CATALOG(pg_opfamily,2753,OperatorFamilyRelationId) ...@@ -50,6 +50,11 @@ CATALOG(pg_opfamily,2753,OperatorFamilyRelationId)
*/ */
typedef FormData_pg_opfamily *Form_pg_opfamily; typedef FormData_pg_opfamily *Form_pg_opfamily;
DECLARE_UNIQUE_INDEX(pg_opfamily_am_name_nsp_index, 2754, on pg_opfamily using btree(opfmethod oid_ops, opfname name_ops, opfnamespace oid_ops));
#define OpfamilyAmNameNspIndexId 2754
DECLARE_UNIQUE_INDEX(pg_opfamily_oid_index, 2755, on pg_opfamily using btree(oid oid_ops));
#define OpfamilyOidIndexId 2755
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
#define IsBooleanOpfamily(opfamily) \ #define IsBooleanOpfamily(opfamily) \
......
...@@ -66,4 +66,7 @@ typedef FormData_pg_partitioned_table *Form_pg_partitioned_table; ...@@ -66,4 +66,7 @@ typedef FormData_pg_partitioned_table *Form_pg_partitioned_table;
DECLARE_TOAST(pg_partitioned_table, 4165, 4166); DECLARE_TOAST(pg_partitioned_table, 4165, 4166);
DECLARE_UNIQUE_INDEX(pg_partitioned_table_partrelid_index, 3351, on pg_partitioned_table using btree(partrelid oid_ops));
#define PartitionedRelidIndexId 3351
#endif /* PG_PARTITIONED_TABLE_H */ #endif /* PG_PARTITIONED_TABLE_H */
...@@ -51,4 +51,9 @@ typedef FormData_pg_policy *Form_pg_policy; ...@@ -51,4 +51,9 @@ typedef FormData_pg_policy *Form_pg_policy;
DECLARE_TOAST(pg_policy, 4167, 4168); DECLARE_TOAST(pg_policy, 4167, 4168);
DECLARE_UNIQUE_INDEX(pg_policy_oid_index, 3257, on pg_policy using btree(oid oid_ops));
#define PolicyOidIndexId 3257
DECLARE_UNIQUE_INDEX(pg_policy_polrelid_polname_index, 3258, on pg_policy using btree(polrelid oid_ops, polname name_ops));
#define PolicyPolrelidPolnameIndexId 3258
#endif /* PG_POLICY_H */ #endif /* PG_POLICY_H */
...@@ -134,6 +134,11 @@ typedef FormData_pg_proc *Form_pg_proc; ...@@ -134,6 +134,11 @@ typedef FormData_pg_proc *Form_pg_proc;
DECLARE_TOAST(pg_proc, 2836, 2837); DECLARE_TOAST(pg_proc, 2836, 2837);
DECLARE_UNIQUE_INDEX(pg_proc_oid_index, 2690, on pg_proc using btree(oid oid_ops));
#define ProcedureOidIndexId 2690
DECLARE_UNIQUE_INDEX(pg_proc_proname_args_nsp_index, 2691, on pg_proc using btree(proname name_ops, proargtypes oidvector_ops, pronamespace oid_ops));
#define ProcedureNameArgsNspIndexId 2691
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -63,6 +63,11 @@ CATALOG(pg_publication,6104,PublicationRelationId) ...@@ -63,6 +63,11 @@ CATALOG(pg_publication,6104,PublicationRelationId)
*/ */
typedef FormData_pg_publication *Form_pg_publication; typedef FormData_pg_publication *Form_pg_publication;
DECLARE_UNIQUE_INDEX(pg_publication_oid_index, 6110, on pg_publication using btree(oid oid_ops));
#define PublicationObjectIndexId 6110
DECLARE_UNIQUE_INDEX(pg_publication_pubname_index, 6111, on pg_publication using btree(pubname name_ops));
#define PublicationNameIndexId 6111
typedef struct PublicationActions typedef struct PublicationActions
{ {
bool pubinsert; bool pubinsert;
......
...@@ -40,4 +40,9 @@ CATALOG(pg_publication_rel,6106,PublicationRelRelationId) ...@@ -40,4 +40,9 @@ CATALOG(pg_publication_rel,6106,PublicationRelRelationId)
*/ */
typedef FormData_pg_publication_rel *Form_pg_publication_rel; typedef FormData_pg_publication_rel *Form_pg_publication_rel;
DECLARE_UNIQUE_INDEX(pg_publication_rel_oid_index, 6112, on pg_publication_rel using btree(oid oid_ops));
#define PublicationRelObjectIndexId 6112
DECLARE_UNIQUE_INDEX(pg_publication_rel_prrelid_prpubid_index, 6113, on pg_publication_rel using btree(prrelid oid_ops, prpubid oid_ops));
#define PublicationRelPrrelidPrpubidIndexId 6113
#endif /* PG_PUBLICATION_REL_H */ #endif /* PG_PUBLICATION_REL_H */
...@@ -54,6 +54,9 @@ CATALOG(pg_range,3541,RangeRelationId) ...@@ -54,6 +54,9 @@ CATALOG(pg_range,3541,RangeRelationId)
*/ */
typedef FormData_pg_range *Form_pg_range; typedef FormData_pg_range *Form_pg_range;
DECLARE_UNIQUE_INDEX(pg_range_rngtypid_index, 3542, on pg_range using btree(rngtypid oid_ops));
#define RangeTypidIndexId 3542
/* /*
* prototypes for functions in pg_range.c * prototypes for functions in pg_range.c
*/ */
......
...@@ -58,4 +58,9 @@ DECLARE_TOAST(pg_replication_origin, 4181, 4182); ...@@ -58,4 +58,9 @@ DECLARE_TOAST(pg_replication_origin, 4181, 4182);
#define PgReplicationOriginToastTable 4181 #define PgReplicationOriginToastTable 4181
#define PgReplicationOriginToastIndex 4182 #define PgReplicationOriginToastIndex 4182
DECLARE_UNIQUE_INDEX(pg_replication_origin_roiident_index, 6001, on pg_replication_origin using btree(roident oid_ops));
#define ReplicationOriginIdentIndex 6001
DECLARE_UNIQUE_INDEX(pg_replication_origin_roname_index, 6002, on pg_replication_origin using btree(roname text_ops));
#define ReplicationOriginNameIndex 6002
#endif /* PG_REPLICATION_ORIGIN_H */ #endif /* PG_REPLICATION_ORIGIN_H */
...@@ -53,4 +53,9 @@ typedef FormData_pg_rewrite *Form_pg_rewrite; ...@@ -53,4 +53,9 @@ typedef FormData_pg_rewrite *Form_pg_rewrite;
DECLARE_TOAST(pg_rewrite, 2838, 2839); DECLARE_TOAST(pg_rewrite, 2838, 2839);
DECLARE_UNIQUE_INDEX(pg_rewrite_oid_index, 2692, on pg_rewrite using btree(oid oid_ops));
#define RewriteOidIndexId 2692
DECLARE_UNIQUE_INDEX(pg_rewrite_rel_rulename_index, 2693, on pg_rewrite using btree(ev_class oid_ops, rulename name_ops));
#define RewriteRelRulenameIndexId 2693
#endif /* PG_REWRITE_H */ #endif /* PG_REWRITE_H */
...@@ -39,4 +39,7 @@ CATALOG(pg_seclabel,3596,SecLabelRelationId) ...@@ -39,4 +39,7 @@ CATALOG(pg_seclabel,3596,SecLabelRelationId)
DECLARE_TOAST(pg_seclabel, 3598, 3599); DECLARE_TOAST(pg_seclabel, 3598, 3599);
DECLARE_UNIQUE_INDEX(pg_seclabel_object_index, 3597, on pg_seclabel using btree(objoid oid_ops, classoid oid_ops, objsubid int4_ops, provider text_ops));
#define SecLabelObjectIndexId 3597
#endif /* PG_SECLABEL_H */ #endif /* PG_SECLABEL_H */
...@@ -39,4 +39,7 @@ CATALOG(pg_sequence,2224,SequenceRelationId) ...@@ -39,4 +39,7 @@ CATALOG(pg_sequence,2224,SequenceRelationId)
*/ */
typedef FormData_pg_sequence *Form_pg_sequence; typedef FormData_pg_sequence *Form_pg_sequence;
DECLARE_UNIQUE_INDEX(pg_sequence_seqrelid_index, 5002, on pg_sequence using btree(seqrelid oid_ops));
#define SequenceRelidIndexId 5002
#endif /* PG_SEQUENCE_H */ #endif /* PG_SEQUENCE_H */
...@@ -69,4 +69,9 @@ CATALOG(pg_shdepend,1214,SharedDependRelationId) BKI_SHARED_RELATION ...@@ -69,4 +69,9 @@ CATALOG(pg_shdepend,1214,SharedDependRelationId) BKI_SHARED_RELATION
*/ */
typedef FormData_pg_shdepend *Form_pg_shdepend; typedef FormData_pg_shdepend *Form_pg_shdepend;
DECLARE_INDEX(pg_shdepend_depender_index, 1232, on pg_shdepend using btree(dbid oid_ops, classid oid_ops, objid oid_ops, objsubid int4_ops));
#define SharedDependDependerIndexId 1232
DECLARE_INDEX(pg_shdepend_reference_index, 1233, on pg_shdepend using btree(refclassid oid_ops, refobjid oid_ops));
#define SharedDependReferenceIndexId 1233
#endif /* PG_SHDEPEND_H */ #endif /* PG_SHDEPEND_H */
...@@ -59,4 +59,7 @@ DECLARE_TOAST(pg_shdescription, 2846, 2847); ...@@ -59,4 +59,7 @@ DECLARE_TOAST(pg_shdescription, 2846, 2847);
#define PgShdescriptionToastTable 2846 #define PgShdescriptionToastTable 2846
#define PgShdescriptionToastIndex 2847 #define PgShdescriptionToastIndex 2847
DECLARE_UNIQUE_INDEX(pg_shdescription_o_c_index, 2397, on pg_shdescription using btree(objoid oid_ops, classoid oid_ops));
#define SharedDescriptionObjIndexId 2397
#endif /* PG_SHDESCRIPTION_H */ #endif /* PG_SHDESCRIPTION_H */
...@@ -42,4 +42,7 @@ DECLARE_TOAST(pg_shseclabel, 4060, 4061); ...@@ -42,4 +42,7 @@ DECLARE_TOAST(pg_shseclabel, 4060, 4061);
#define PgShseclabelToastTable 4060 #define PgShseclabelToastTable 4060
#define PgShseclabelToastIndex 4061 #define PgShseclabelToastIndex 4061
DECLARE_UNIQUE_INDEX(pg_shseclabel_object_index, 3593, on pg_shseclabel using btree(objoid oid_ops, classoid oid_ops, provider text_ops));
#define SharedSecLabelObjectIndexId 3593
#endif /* PG_SHSECLABEL_H */ #endif /* PG_SHSECLABEL_H */
...@@ -135,6 +135,9 @@ typedef FormData_pg_statistic *Form_pg_statistic; ...@@ -135,6 +135,9 @@ typedef FormData_pg_statistic *Form_pg_statistic;
DECLARE_TOAST(pg_statistic, 2840, 2841); DECLARE_TOAST(pg_statistic, 2840, 2841);
DECLARE_UNIQUE_INDEX(pg_statistic_relid_att_inh_index, 2696, on pg_statistic using btree(starelid oid_ops, staattnum int2_ops, stainherit bool_ops));
#define StatisticRelidAttnumInhIndexId 2696
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -65,6 +65,13 @@ typedef FormData_pg_statistic_ext *Form_pg_statistic_ext; ...@@ -65,6 +65,13 @@ typedef FormData_pg_statistic_ext *Form_pg_statistic_ext;
DECLARE_TOAST(pg_statistic_ext, 3439, 3440); DECLARE_TOAST(pg_statistic_ext, 3439, 3440);
DECLARE_UNIQUE_INDEX(pg_statistic_ext_oid_index, 3380, on pg_statistic_ext using btree(oid oid_ops));
#define StatisticExtOidIndexId 3380
DECLARE_UNIQUE_INDEX(pg_statistic_ext_name_index, 3997, on pg_statistic_ext using btree(stxname name_ops, stxnamespace oid_ops));
#define StatisticExtNameIndexId 3997
DECLARE_INDEX(pg_statistic_ext_relid_index, 3379, on pg_statistic_ext using btree(stxrelid oid_ops));
#define StatisticExtRelidIndexId 3379
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
#define STATS_EXT_NDISTINCT 'd' #define STATS_EXT_NDISTINCT 'd'
......
...@@ -51,4 +51,7 @@ typedef FormData_pg_statistic_ext_data * Form_pg_statistic_ext_data; ...@@ -51,4 +51,7 @@ typedef FormData_pg_statistic_ext_data * Form_pg_statistic_ext_data;
DECLARE_TOAST(pg_statistic_ext_data, 3430, 3431); DECLARE_TOAST(pg_statistic_ext_data, 3430, 3431);
DECLARE_UNIQUE_INDEX(pg_statistic_ext_data_stxoid_index, 3433, on pg_statistic_ext_data using btree(stxoid oid_ops));
#define StatisticExtDataStxoidIndexId 3433
#endif /* PG_STATISTIC_EXT_DATA_H */ #endif /* PG_STATISTIC_EXT_DATA_H */
...@@ -74,6 +74,11 @@ DECLARE_TOAST(pg_subscription, 4183, 4184); ...@@ -74,6 +74,11 @@ DECLARE_TOAST(pg_subscription, 4183, 4184);
#define PgSubscriptionToastTable 4183 #define PgSubscriptionToastTable 4183
#define PgSubscriptionToastIndex 4184 #define PgSubscriptionToastIndex 4184
DECLARE_UNIQUE_INDEX(pg_subscription_oid_index, 6114, on pg_subscription using btree(oid oid_ops));
#define SubscriptionObjectIndexId 6114
DECLARE_UNIQUE_INDEX(pg_subscription_subname_index, 6115, on pg_subscription using btree(subdbid oid_ops, subname name_ops));
#define SubscriptionNameIndexId 6115
typedef struct Subscription typedef struct Subscription
{ {
Oid oid; /* Oid of the subscription */ Oid oid; /* Oid of the subscription */
......
...@@ -49,6 +49,9 @@ CATALOG(pg_subscription_rel,6102,SubscriptionRelRelationId) ...@@ -49,6 +49,9 @@ CATALOG(pg_subscription_rel,6102,SubscriptionRelRelationId)
typedef FormData_pg_subscription_rel *Form_pg_subscription_rel; typedef FormData_pg_subscription_rel *Form_pg_subscription_rel;
DECLARE_UNIQUE_INDEX(pg_subscription_rel_srrelid_srsubid_index, 6117, on pg_subscription_rel using btree(srrelid oid_ops, srsubid oid_ops));
#define SubscriptionRelSrrelidSrsubidIndexId 6117
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* ---------------- /* ----------------
......
...@@ -49,4 +49,9 @@ DECLARE_TOAST(pg_tablespace, 4185, 4186); ...@@ -49,4 +49,9 @@ DECLARE_TOAST(pg_tablespace, 4185, 4186);
#define PgTablespaceToastTable 4185 #define PgTablespaceToastTable 4185
#define PgTablespaceToastIndex 4186 #define PgTablespaceToastIndex 4186
DECLARE_UNIQUE_INDEX(pg_tablespace_oid_index, 2697, on pg_tablespace using btree(oid oid_ops));
#define TablespaceOidIndexId 2697
DECLARE_UNIQUE_INDEX(pg_tablespace_spcname_index, 2698, on pg_tablespace using btree(spcname name_ops));
#define TablespaceNameIndexId 2698
#endif /* PG_TABLESPACE_H */ #endif /* PG_TABLESPACE_H */
...@@ -42,4 +42,9 @@ CATALOG(pg_transform,3576,TransformRelationId) ...@@ -42,4 +42,9 @@ CATALOG(pg_transform,3576,TransformRelationId)
*/ */
typedef FormData_pg_transform *Form_pg_transform; typedef FormData_pg_transform *Form_pg_transform;
DECLARE_UNIQUE_INDEX(pg_transform_oid_index, 3574, on pg_transform using btree(oid oid_ops));
#define TransformOidIndexId 3574
DECLARE_UNIQUE_INDEX(pg_transform_type_lang_index, 3575, on pg_transform using btree(trftype oid_ops, trflang oid_ops));
#define TransformTypeLangIndexId 3575
#endif /* PG_TRANSFORM_H */ #endif /* PG_TRANSFORM_H */
...@@ -74,6 +74,13 @@ typedef FormData_pg_trigger *Form_pg_trigger; ...@@ -74,6 +74,13 @@ typedef FormData_pg_trigger *Form_pg_trigger;
DECLARE_TOAST(pg_trigger, 2336, 2337); DECLARE_TOAST(pg_trigger, 2336, 2337);
DECLARE_INDEX(pg_trigger_tgconstraint_index, 2699, on pg_trigger using btree(tgconstraint oid_ops));
#define TriggerConstraintIndexId 2699
DECLARE_UNIQUE_INDEX(pg_trigger_tgrelid_tgname_index, 2701, on pg_trigger using btree(tgrelid oid_ops, tgname name_ops));
#define TriggerRelidNameIndexId 2701
DECLARE_UNIQUE_INDEX(pg_trigger_oid_index, 2702, on pg_trigger using btree(oid oid_ops));
#define TriggerOidIndexId 2702
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* Bits within tgtype */ /* Bits within tgtype */
......
...@@ -47,4 +47,9 @@ CATALOG(pg_ts_config,3602,TSConfigRelationId) ...@@ -47,4 +47,9 @@ CATALOG(pg_ts_config,3602,TSConfigRelationId)
typedef FormData_pg_ts_config *Form_pg_ts_config; typedef FormData_pg_ts_config *Form_pg_ts_config;
DECLARE_UNIQUE_INDEX(pg_ts_config_cfgname_index, 3608, on pg_ts_config using btree(cfgname name_ops, cfgnamespace oid_ops));
#define TSConfigNameNspIndexId 3608
DECLARE_UNIQUE_INDEX(pg_ts_config_oid_index, 3712, on pg_ts_config using btree(oid oid_ops));
#define TSConfigOidIndexId 3712
#endif /* PG_TS_CONFIG_H */ #endif /* PG_TS_CONFIG_H */
...@@ -44,4 +44,7 @@ CATALOG(pg_ts_config_map,3603,TSConfigMapRelationId) ...@@ -44,4 +44,7 @@ CATALOG(pg_ts_config_map,3603,TSConfigMapRelationId)
typedef FormData_pg_ts_config_map *Form_pg_ts_config_map; typedef FormData_pg_ts_config_map *Form_pg_ts_config_map;
DECLARE_UNIQUE_INDEX(pg_ts_config_map_index, 3609, on pg_ts_config_map using btree(mapcfg oid_ops, maptokentype int4_ops, mapseqno int4_ops));
#define TSConfigMapIndexId 3609
#endif /* PG_TS_CONFIG_MAP_H */ #endif /* PG_TS_CONFIG_MAP_H */
...@@ -53,4 +53,9 @@ typedef FormData_pg_ts_dict *Form_pg_ts_dict; ...@@ -53,4 +53,9 @@ typedef FormData_pg_ts_dict *Form_pg_ts_dict;
DECLARE_TOAST(pg_ts_dict, 4169, 4170); DECLARE_TOAST(pg_ts_dict, 4169, 4170);
DECLARE_UNIQUE_INDEX(pg_ts_dict_dictname_index, 3604, on pg_ts_dict using btree(dictname name_ops, dictnamespace oid_ops));
#define TSDictionaryNameNspIndexId 3604
DECLARE_UNIQUE_INDEX(pg_ts_dict_oid_index, 3605, on pg_ts_dict using btree(oid oid_ops));
#define TSDictionaryOidIndexId 3605
#endif /* PG_TS_DICT_H */ #endif /* PG_TS_DICT_H */
...@@ -54,4 +54,9 @@ CATALOG(pg_ts_parser,3601,TSParserRelationId) ...@@ -54,4 +54,9 @@ CATALOG(pg_ts_parser,3601,TSParserRelationId)
typedef FormData_pg_ts_parser *Form_pg_ts_parser; typedef FormData_pg_ts_parser *Form_pg_ts_parser;
DECLARE_UNIQUE_INDEX(pg_ts_parser_prsname_index, 3606, on pg_ts_parser using btree(prsname name_ops, prsnamespace oid_ops));
#define TSParserNameNspIndexId 3606
DECLARE_UNIQUE_INDEX(pg_ts_parser_oid_index, 3607, on pg_ts_parser using btree(oid oid_ops));
#define TSParserOidIndexId 3607
#endif /* PG_TS_PARSER_H */ #endif /* PG_TS_PARSER_H */
...@@ -45,4 +45,9 @@ CATALOG(pg_ts_template,3764,TSTemplateRelationId) ...@@ -45,4 +45,9 @@ CATALOG(pg_ts_template,3764,TSTemplateRelationId)
typedef FormData_pg_ts_template *Form_pg_ts_template; typedef FormData_pg_ts_template *Form_pg_ts_template;
DECLARE_UNIQUE_INDEX(pg_ts_template_tmplname_index, 3766, on pg_ts_template using btree(tmplname name_ops, tmplnamespace oid_ops));
#define TSTemplateNameNspIndexId 3766
DECLARE_UNIQUE_INDEX(pg_ts_template_oid_index, 3767, on pg_ts_template using btree(oid oid_ops));
#define TSTemplateOidIndexId 3767
#endif /* PG_TS_TEMPLATE_H */ #endif /* PG_TS_TEMPLATE_H */
...@@ -256,6 +256,11 @@ typedef FormData_pg_type *Form_pg_type; ...@@ -256,6 +256,11 @@ typedef FormData_pg_type *Form_pg_type;
DECLARE_TOAST(pg_type, 4171, 4172); DECLARE_TOAST(pg_type, 4171, 4172);
DECLARE_UNIQUE_INDEX(pg_type_oid_index, 2703, on pg_type using btree(oid oid_ops));
#define TypeOidIndexId 2703
DECLARE_UNIQUE_INDEX(pg_type_typname_nsp_index, 2704, on pg_type using btree(typname name_ops, typnamespace oid_ops));
#define TypeNameNspIndexId 2704
#ifdef EXPOSE_TO_CLIENT_CODE #ifdef EXPOSE_TO_CLIENT_CODE
/* /*
......
...@@ -47,4 +47,9 @@ typedef FormData_pg_user_mapping *Form_pg_user_mapping; ...@@ -47,4 +47,9 @@ typedef FormData_pg_user_mapping *Form_pg_user_mapping;
DECLARE_TOAST(pg_user_mapping, 4173, 4174); DECLARE_TOAST(pg_user_mapping, 4173, 4174);
DECLARE_UNIQUE_INDEX(pg_user_mapping_oid_index, 174, on pg_user_mapping using btree(oid oid_ops));
#define UserMappingOidIndexId 174
DECLARE_UNIQUE_INDEX(pg_user_mapping_user_server_index, 175, on pg_user_mapping using btree(umuser oid_ops, umserver oid_ops));
#define UserMappingUserServerIndexId 175
#endif /* PG_USER_MAPPING_H */ #endif /* PG_USER_MAPPING_H */
...@@ -61,7 +61,7 @@ if ($output_path ne '' && substr($output_path, -1) ne '/') ...@@ -61,7 +61,7 @@ if ($output_path ne '' && substr($output_path, -1) ne '/')
} }
# Collect all the existing assigned OIDs (including those to be remapped). # Collect all the existing assigned OIDs (including those to be remapped).
my @header_files = (glob("pg_*.h"), qw(indexing.h)); my @header_files = glob("pg_*.h");
my $oids = Catalog::FindAllOidsFromHeaders(@header_files); my $oids = Catalog::FindAllOidsFromHeaders(@header_files);
# Hash-ify the existing OIDs for convenient lookup. # Hash-ify the existing OIDs for convenient lookup.
...@@ -173,19 +173,6 @@ foreach my $input_file (@header_files) ...@@ -173,19 +173,6 @@ foreach my $input_file (@header_files)
} }
} }
# In indexing.h only, check for #define SYM nnnn,
# and replace if within mapped range.
elsif ($line =~ m/^(\s*#\s*define\s+\w+\s+)(\d+)\b/)
{
if (($catname eq 'indexing' || $catname eq 'toasting')
&& exists $maphash{$2})
{
my $repl = $1 . $maphash{$2};
$line =~ s/^\s*#\s*define\s+\w+\s+\d+\b/$repl/;
$changed = 1;
}
}
print $ofd $line; print $ofd $line;
} }
......
...@@ -28,7 +28,7 @@ chdir $FindBin::RealBin or die "could not cd to $FindBin::RealBin: $!\n"; ...@@ -28,7 +28,7 @@ chdir $FindBin::RealBin or die "could not cd to $FindBin::RealBin: $!\n";
use lib "$FindBin::RealBin/../../backend/catalog/"; use lib "$FindBin::RealBin/../../backend/catalog/";
use Catalog; use Catalog;
my @input_files = (glob("pg_*.h"), qw(indexing.h)); my @input_files = glob("pg_*.h");
my $oids = Catalog::FindAllOidsFromHeaders(@input_files); my $oids = Catalog::FindAllOidsFromHeaders(@input_files);
......
...@@ -762,7 +762,6 @@ EOF ...@@ -762,7 +762,6 @@ EOF
$mf =~ /^CATALOG_HEADERS\s*:?=(.*)$/gm $mf =~ /^CATALOG_HEADERS\s*:?=(.*)$/gm
|| croak "Could not find CATALOG_HEADERS in Makefile\n"; || croak "Could not find CATALOG_HEADERS in Makefile\n";
my @bki_srcs = split /\s+/, $1; my @bki_srcs = split /\s+/, $1;
push @bki_srcs, 'indexing.h';
$mf =~ /^POSTGRES_BKI_DATA\s*:?=[^,]+,(.*)\)$/gm $mf =~ /^POSTGRES_BKI_DATA\s*:?=[^,]+,(.*)\)$/gm
|| croak "Could not find POSTGRES_BKI_DATA in Makefile\n"; || croak "Could not find POSTGRES_BKI_DATA in Makefile\n";
my @bki_data = split /\s+/, $1; my @bki_data = split /\s+/, $1;
......
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