Update copyright for 2022
[pgsql.git] / src / include / catalog / pg_opfamily.h
blob8dc9ce01bb92d081ac069ce1de58ec889d8f35da
1 /*-------------------------------------------------------------------------
3 * pg_opfamily.h
4 * definition of the "operator family" system catalog (pg_opfamily)
7 * Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
8 * Portions Copyright (c) 1994, Regents of the University of California
10 * src/include/catalog/pg_opfamily.h
12 * NOTES
13 * The Catalog.pm module reads this file and derives schema
14 * information.
16 *-------------------------------------------------------------------------
18 #ifndef PG_OPFAMILY_H
19 #define PG_OPFAMILY_H
21 #include "catalog/genbki.h"
22 #include "catalog/pg_opfamily_d.h"
24 /* ----------------
25 * pg_opfamily definition. cpp turns this into
26 * typedef struct FormData_pg_opfamily
27 * ----------------
29 CATALOG(pg_opfamily,2753,OperatorFamilyRelationId)
31 Oid oid; /* oid */
33 /* index access method opfamily is for */
34 Oid opfmethod BKI_LOOKUP(pg_am);
36 /* name of this opfamily */
37 NameData opfname;
39 /* namespace of this opfamily */
40 Oid opfnamespace BKI_DEFAULT(pg_catalog) BKI_LOOKUP(pg_namespace);
42 /* opfamily owner */
43 Oid opfowner BKI_DEFAULT(POSTGRES) BKI_LOOKUP(pg_authid);
44 } FormData_pg_opfamily;
46 /* ----------------
47 * Form_pg_opfamily corresponds to a pointer to a tuple with
48 * the format of pg_opfamily relation.
49 * ----------------
51 typedef FormData_pg_opfamily *Form_pg_opfamily;
53 DECLARE_UNIQUE_INDEX(pg_opfamily_am_name_nsp_index, 2754, OpfamilyAmNameNspIndexId, on pg_opfamily using btree(opfmethod oid_ops, opfname name_ops, opfnamespace oid_ops));
54 DECLARE_UNIQUE_INDEX_PKEY(pg_opfamily_oid_index, 2755, OpfamilyOidIndexId, on pg_opfamily using btree(oid oid_ops));
56 #ifdef EXPOSE_TO_CLIENT_CODE
58 #define IsBooleanOpfamily(opfamily) \
59 ((opfamily) == BOOL_BTREE_FAM_OID || (opfamily) == BOOL_HASH_FAM_OID)
61 #endif /* EXPOSE_TO_CLIENT_CODE */
63 #endif /* PG_OPFAMILY_H */