Re: [PATCHES] CLASSOID patch

From: Bruce Momjian <pgman(at)candle(dot)pha(dot)pa(dot)us>
To: Chris Bitmead <chris(at)bitmead(dot)com>
Cc: Postgres Hackers List <hackers(at)postgreSQL(dot)org>, "pgsql-patches(at)postgresql(dot)org" <pgsql-patches(at)postgreSQL(dot)org>
Subject: Re: [PATCHES] CLASSOID patch
Date: 2000-10-10 21:53:06
Message-ID: 200010102153.RAA11168@candle.pha.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers pgsql-patches

I don't see this in the tree. Status, please.

>
> Attached is a first attempt at implementing the classoid feature. It
> works! Can the postgres gurus comment if I've done it right and point
> out any problems. A lot of it was guess work so I'm sure it can be
> cleaned up some.
>
> --
> Chris Bitmead
> mailto:chris(at)bitmead(dot)com

> ? config.log
> ? config.cache
> ? config.status
> ? nohup.out
> ? GNUmakefile
> ? src/GNUmakefile
> ? src/Makefile.global
> ? src/ID
> ? src/nohup.out
> ? src/backend/fmgr.h
> ? src/backend/parse.h
> ? src/backend/postgres
> ? src/backend/global1.bki.source
> ? src/backend/local1_template1.bki.source
> ? src/backend/global1.description
> ? src/backend/local1_template1.description
> ? src/backend/1
> ? src/backend/catalog/genbki.sh
> ? src/backend/catalog/global1.bki.source
> ? src/backend/catalog/global1.description
> ? src/backend/catalog/local1_template1.bki.source
> ? src/backend/catalog/local1_template1.description
> ? src/backend/parser/y.output
> ? src/backend/parser/y.output.gz
> ? src/backend/parser/gram.y.works
> ? src/backend/parser/gram.y.works.try
> ? src/backend/parser/y.output.noerror
> ? src/backend/parser/gram.y.gz
> ? src/backend/port/Makefile
> ? src/backend/utils/Gen_fmgrtab.sh
> ? src/backend/utils/fmgr.h
> ? src/backend/utils/fmgrstamp-h
> ? src/bin/initdb/initdb
> ? src/bin/initlocation/initlocation
> ? src/bin/ipcclean/ipcclean
> ? src/bin/pg_ctl/pg_ctl
> ? src/bin/pg_dump/Makefile
> ? src/bin/pg_dump/pg_dump
> ? src/bin/pg_id/pg_id
> ? src/bin/pg_passwd/pg_passwd
> ? src/bin/pg_version/Makefile
> ? src/bin/pg_version/pg_version
> ? src/bin/pgtclsh/mkMakefile.tcldefs.sh
> ? src/bin/pgtclsh/mkMakefile.tkdefs.sh
> ? src/bin/psql/Makefile
> ? src/bin/psql/psql
> ? src/bin/scripts/createlang
> ? src/include/version.h
> ? src/include/config.h
> ? src/include/parser/parse.h
> ? src/include/utils/fmgroids.h
> ? src/interfaces/Makefile
> ? src/interfaces/ecpg/lib/Makefile
> ? src/interfaces/ecpg/lib/libecpg.so.3.1.1
> ? src/interfaces/ecpg/preproc/Makefile
> ? src/interfaces/ecpg/preproc/ecpg
> ? src/interfaces/jdbc/postgresql.jar
> ? src/interfaces/jdbc/example/psql.class
> ? src/interfaces/jdbc/postgresql/DriverClass.java
> ? src/interfaces/jdbc/postgresql/DriverClass.class
> ? src/interfaces/jdbc/postgresql/Connection.class
> ? src/interfaces/jdbc/postgresql/Field.class
> ? src/interfaces/jdbc/postgresql/PG_Stream.class
> ? src/interfaces/jdbc/postgresql/Driver.class
> ? src/interfaces/jdbc/postgresql/ResultSet.class
> ? src/interfaces/jdbc/postgresql/fastpath/Fastpath.class
> ? src/interfaces/jdbc/postgresql/fastpath/FastpathArg.class
> ? src/interfaces/jdbc/postgresql/geometric/PGbox.class
> ? src/interfaces/jdbc/postgresql/geometric/PGpoint.class
> ? src/interfaces/jdbc/postgresql/geometric/PGcircle.class
> ? src/interfaces/jdbc/postgresql/geometric/PGline.class
> ? src/interfaces/jdbc/postgresql/geometric/PGlseg.class
> ? src/interfaces/jdbc/postgresql/geometric/PGpath.class
> ? src/interfaces/jdbc/postgresql/geometric/PGpolygon.class
> ? src/interfaces/jdbc/postgresql/jdbc2/ResultSet.class
> ? src/interfaces/jdbc/postgresql/jdbc2/Connection.class
> ? src/interfaces/jdbc/postgresql/jdbc2/ResultSetMetaData.class
> ? src/interfaces/jdbc/postgresql/jdbc2/DatabaseMetaData.class
> ? src/interfaces/jdbc/postgresql/jdbc2/Statement.class
> ? src/interfaces/jdbc/postgresql/jdbc2/PreparedStatement.class
> ? src/interfaces/jdbc/postgresql/jdbc2/CallableStatement.class
> ? src/interfaces/jdbc/postgresql/largeobject/LargeObjectManager.class
> ? src/interfaces/jdbc/postgresql/largeobject/LargeObject.class
> ? src/interfaces/jdbc/postgresql/util/PSQLException.class
> ? src/interfaces/jdbc/postgresql/util/UnixCrypt.class
> ? src/interfaces/jdbc/postgresql/util/Serialize.class
> ? src/interfaces/jdbc/postgresql/util/PGobject.class
> ? src/interfaces/jdbc/postgresql/util/PGtokenizer.class
> ? src/interfaces/jdbc/postgresql/util/PGmoney.class
> ? src/interfaces/libpgeasy/Makefile
> ? src/interfaces/libpgeasy/libpgeasy.so.2.1
> ? src/interfaces/libpgtcl/Makefile
> ? src/interfaces/libpgtcl/mkMakefile.tcldefs.sh
> ? src/interfaces/libpgtcl/mkMakefile.tkdefs.sh
> ? src/interfaces/libpq/Makefile
> ? src/interfaces/libpq/libpq.so.2.1
> ? src/interfaces/libpq++/Makefile
> ? src/interfaces/libpq++/libpq++.so.3.1
> ? src/interfaces/odbc/GNUmakefile
> ? src/interfaces/odbc/Makefile.global
> ? src/interfaces/perl5/GNUmakefile
> ? src/interfaces/python/GNUmakefile
> ? src/pl/Makefile
> ? src/pl/plperl/GNUmakefile
> ? src/pl/plpgsql/Makefile
> ? src/pl/plpgsql/src/Makefile
> ? src/pl/plpgsql/src/libplpgsql.so.1.0
> ? src/pl/tcl/mkMakefile.tcldefs.sh
> ? src/test/regress/GNUmakefile
> ? src/test/regress/x.x
> ? src/test/regress/nohup.out
> Index: src/backend/access/common/heaptuple.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/access/common/heaptuple.c,v
> retrieving revision 1.62
> diff -c -r1.62 heaptuple.c
> *** src/backend/access/common/heaptuple.c 2000/04/12 17:14:36 1.62
> --- src/backend/access/common/heaptuple.c 2000/06/24 15:24:46
> ***************
> *** 9,15 ****
> *
> *
> * IDENTIFICATION
> ! * $Header: /home/projects/pgsql/cvsroot/pgsql/src/backend/access/common/heaptuple.c,v 1.62 2000/04/12 17:14:36 momjian Exp $
> *
> * NOTES
> * The old interface functions have been converted to macros
> --- 9,15 ----
> *
> *
> * IDENTIFICATION
> ! * $Header: /usr/local/cvsroot/pgsql/src/backend/access/common/heaptuple.c,v 1.62 2000/04/12 17:14:36 momjian Exp $
> *
> * NOTES
> * The old interface functions have been converted to macros
> ***************
> *** 169,174 ****
> --- 169,175 ----
> else
> switch (attnum)
> {
> + case ClassOidAttributeNumber:
> case SelfItemPointerAttributeNumber:
> case ObjectIdAttributeNumber:
> case MinTransactionIdAttributeNumber:
> ***************
> *** 205,210 ****
> --- 206,213 ----
>
> switch (attno)
> {
> + case ClassOidAttributeNumber:
> + return sizeof f->t_oid;
> case SelfItemPointerAttributeNumber:
> return sizeof f->t_ctid;
> case ObjectIdAttributeNumber:
> ***************
> *** 237,242 ****
> --- 240,248 ----
>
> switch (attno)
> {
> + case ClassOidAttributeNumber:
> + byval = true;
> + break;
> case SelfItemPointerAttributeNumber:
> byval = false;
> break;
> ***************
> *** 275,281 ****
> {
> switch (attnum)
> {
> ! case SelfItemPointerAttributeNumber:
> return (Datum) &tup->t_ctid;
> case ObjectIdAttributeNumber:
> return (Datum) (long) tup->t_oid;
> --- 281,289 ----
> {
> switch (attnum)
> {
> ! case ClassOidAttributeNumber:
> ! return (Datum) &tup->t_classoid;
> ! case SelfItemPointerAttributeNumber:
> return (Datum) &tup->t_ctid;
> case ObjectIdAttributeNumber:
> return (Datum) (long) tup->t_oid;
> Index: src/backend/access/heap/heapam.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/access/heap/heapam.c,v
> retrieving revision 1.71
> diff -c -r1.71 heapam.c
> *** src/backend/access/heap/heapam.c 2000/06/15 04:09:34 1.71
> --- src/backend/access/heap/heapam.c 2000/06/24 15:24:49
> ***************
> *** 235,240 ****
> --- 235,242 ----
> int linesleft;
> ItemPointer tid = (tuple->t_data == NULL) ?
> (ItemPointer) NULL : &(tuple->t_self);
> +
> + tuple->relation = relation;
>
> /* ----------------
> * increment access statistics
> ***************
> *** 567,572 ****
> --- 569,575 ----
>
> Assert(lockmode >= NoLock && lockmode < MAX_LOCKMODES);
>
> +
> /* ----------------
> * increment access statistics
> * ----------------
> ***************
> *** 1030,1035 ****
> --- 1033,1039 ----
> ItemPointer tid = &(tuple->t_self);
> OffsetNumber offnum;
>
> + tuple->relation = relation;
> /* ----------------
> * increment access statistics
> * ----------------
> ***************
> *** 1124,1129 ****
> --- 1128,1134 ----
> bool invalidBlock,
> linkend;
>
> + tp.relation = relation;
> /* ----------------
> * get the buffer from the relation descriptor
> * Note that this does a buffer pin.
> ***************
> *** 1216,1221 ****
> --- 1221,1227 ----
> * increment access statistics
> * ----------------
> */
> + tup->relation = relation;
> IncrHeapAccessStat(local_insert);
> IncrHeapAccessStat(global_insert);
>
> ***************
> *** 1284,1289 ****
> --- 1290,1296 ----
> Buffer buffer;
> int result;
>
> + tp.relation = relation;
> /* increment access statistics */
> IncrHeapAccessStat(local_delete);
> IncrHeapAccessStat(global_delete);
> ***************
> *** 1396,1401 ****
> --- 1403,1409 ----
> Buffer buffer;
> int result;
>
> + newtup->relation = relation;
> /* increment access statistics */
> IncrHeapAccessStat(local_replace);
> IncrHeapAccessStat(global_replace);
> ***************
> *** 1524,1529 ****
> --- 1532,1538 ----
> PageHeader dp;
> int result;
>
> + tuple->relation = relation;
> /* increment access statistics */
> IncrHeapAccessStat(local_mark4update);
> IncrHeapAccessStat(global_mark4update);
> Index: src/backend/catalog/heap.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/catalog/heap.c,v
> retrieving revision 1.133
> diff -c -r1.133 heap.c
> *** src/backend/catalog/heap.c 2000/06/18 22:43:55 1.133
> --- src/backend/catalog/heap.c 2000/06/24 15:24:54
> ***************
> *** 101,106 ****
> --- 101,107 ----
> * be more difficult if not impossible.
> */
>
> +
> static FormData_pg_attribute a1 = {
> 0xffffffff, {"ctid"}, TIDOID, 0, sizeof(ItemPointerData),
> SelfItemPointerAttributeNumber, 0, -1, -1, '\0', 'p', '\0', 'i', '\0', '\0'
> ***************
> *** 130,137 ****
> 0xffffffff, {"cmax"}, CIDOID, 0, sizeof(CommandId),
> MaxCommandIdAttributeNumber, 0, -1, -1, '\001', 'p', '\0', 'i', '\0', '\0'
> };
>
> ! static Form_pg_attribute HeapAtt[] = {&a1, &a2, &a3, &a4, &a5, &a6};
>
> /* ----------------------------------------------------------------
> * XXX END OF UGLY HARD CODED BADNESS XXX
> --- 131,143 ----
> 0xffffffff, {"cmax"}, CIDOID, 0, sizeof(CommandId),
> MaxCommandIdAttributeNumber, 0, -1, -1, '\001', 'p', '\0', 'i', '\0', '\0'
> };
> +
> + static FormData_pg_attribute a7 = {
> + 0xffffffff, {"classoid"}, OIDOID, 0, sizeof(Oid),
> + ClassOidAttributeNumber, 0, -1, -1, '\0', 'p', '\0', 'i', '\0', '\0'
> + };
>
> ! static Form_pg_attribute HeapAtt[] = {&a1, &a2, &a3, &a4, &a5, &a6, &a7};
>
> /* ----------------------------------------------------------------
> * XXX END OF UGLY HARD CODED BADNESS XXX
> Index: src/backend/optimizer/path/tidpath.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/optimizer/path/tidpath.c,v
> retrieving revision 1.7
> diff -c -r1.7 tidpath.c
> *** src/backend/optimizer/path/tidpath.c 2000/05/30 00:49:47 1.7
> --- src/backend/optimizer/path/tidpath.c 2000/06/24 15:24:55
> ***************
> *** 105,110 ****
> --- 105,118 ----
> var->varoattno == SelfItemPointerAttributeNumber &&
> var->vartype == TIDOID)
> arg = arg2;
> + /* else if (var->varno == varno &&
> + var->varattno == ClassOidAttributeNumber &&
> + var->vartype == OIDCLASSOID)
> + arg = arg2;
> + else if (var->varnoold == varno &&
> + var->varoattno == ClassOidAttributeNumber &&
> + var->vartype == OIDCLASSOID)
> + arg = arg2; */
> }
> if ((!arg) && IsA(arg2, Var))
> {
> ***************
> *** 113,118 ****
> --- 121,130 ----
> var->varattno == SelfItemPointerAttributeNumber &&
> var->vartype == TIDOID)
> arg = arg1;
> + /* else if (var->varno == varno &&
> + var->varattno == ClassOidAttributeNumber &&
> + var->vartype == OIDCLASSOID)
> + arg = arg1; */
> }
> if (!arg)
> return rnode;
> Index: src/backend/optimizer/prep/preptlist.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/optimizer/prep/preptlist.c,v
> retrieving revision 1.36
> diff -c -r1.36 preptlist.c
> *** src/backend/optimizer/prep/preptlist.c 2000/04/12 17:15:23 1.36
> --- src/backend/optimizer/prep/preptlist.c 2000/06/24 15:24:57
> ***************
> *** 15,21 ****
> * Portions Copyright (c) 1994, Regents of the University of California
> *
> * IDENTIFICATION
> ! * $Header: /home/projects/pgsql/cvsroot/pgsql/src/backend/optimizer/prep/preptlist.c,v 1.36 2000/04/12 17:15:23 momjian Exp $
> *
> *-------------------------------------------------------------------------
> */
> --- 15,21 ----
> * Portions Copyright (c) 1994, Regents of the University of California
> *
> * IDENTIFICATION
> ! * $Header: /usr/local/cvsroot/pgsql/src/backend/optimizer/prep/preptlist.c,v 1.36 2000/04/12 17:15:23 momjian Exp $
> *
> *-------------------------------------------------------------------------
> */
> ***************
> *** 66,72 ****
> if (command_type == CMD_UPDATE || command_type == CMD_DELETE)
> {
> Resdom *resdom;
> ! Var *var;
>
> resdom = makeResdom(length(tlist) + 1,
> TIDOID,
> --- 66,72 ----
> if (command_type == CMD_UPDATE || command_type == CMD_DELETE)
> {
> Resdom *resdom;
> ! Var *var1, *var2;
>
> resdom = makeResdom(length(tlist) + 1,
> TIDOID,
> ***************
> *** 76,83 ****
> 0,
> true);
>
> ! var = makeVar(result_relation, SelfItemPointerAttributeNumber,
> TIDOID, -1, 0);
>
> /*
> * For an UPDATE, expand_targetlist already created a fresh tlist.
> --- 76,85 ----
> 0,
> true);
>
> ! var1 = makeVar(result_relation, SelfItemPointerAttributeNumber,
> TIDOID, -1, 0);
> + var2 = makeVar(result_relation, ClassOidAttributeNumber,
> + OIDOID, -1, 0);
>
> /*
> * For an UPDATE, expand_targetlist already created a fresh tlist.
> ***************
> *** 87,93 ****
> if (command_type == CMD_DELETE)
> tlist = listCopy(tlist);
>
> ! tlist = lappend(tlist, makeTargetEntry(resdom, (Node *) var));
> }
>
> return tlist;
> --- 89,96 ----
> if (command_type == CMD_DELETE)
> tlist = listCopy(tlist);
>
> ! tlist = lappend(tlist, makeTargetEntry(resdom, (Node *) var1));
> ! tlist = lappend(tlist, makeTargetEntry(resdom, (Node *) var2));
> }
>
> return tlist;
> Index: src/backend/parser/parse_relation.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/parser/parse_relation.c,v
> retrieving revision 1.44
> diff -c -r1.44 parse_relation.c
> *** src/backend/parser/parse_relation.c 2000/06/20 01:41:21 1.44
> --- src/backend/parser/parse_relation.c 2000/06/24 15:24:58
> ***************
> *** 40,45 ****
> --- 40,48 ----
>
> {
> {
> + "classoid", ClassOidAttributeNumber, OIDOID
> + },
> + {
> "ctid", SelfItemPointerAttributeNumber, TIDOID
> },
> {
> Index: src/backend/utils/cache/lsyscache.c
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/backend/utils/cache/lsyscache.c,v
> retrieving revision 1.42
> diff -c -r1.42 lsyscache.c
> *** src/backend/utils/cache/lsyscache.c 2000/06/08 22:37:30 1.42
> --- src/backend/utils/cache/lsyscache.c 2000/06/24 15:25:00
> ***************
> *** 249,254 ****
> --- 249,256 ----
> if (attnum == ObjectIdAttributeNumber ||
> attnum == SelfItemPointerAttributeNumber)
> return 1.0 / (double) ntuples;
> + if (attnum == ClassOidAttributeNumber)
> + return 1.0;
>
> /*
> * VACUUM ANALYZE has not been run for this table. Produce an estimate
> Index: src/include/access/heapam.h
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/include/access/heapam.h,v
> retrieving revision 1.53
> diff -c -r1.53 heapam.h
> *** src/include/access/heapam.h 2000/06/18 22:44:23 1.53
> --- src/include/access/heapam.h 2000/06/24 15:25:02
> ***************
> *** 230,239 ****
> (Datum)((char *)&((tup)->t_self)) \
> ) \
> : \
> ( \
> (Datum)*(unsigned int *) \
> ((char *)(tup)->t_data + heap_sysoffset[-(attnum)-1]) \
> ! ) \
> ) \
> ) \
> )
> --- 230,244 ----
> (Datum)((char *)&((tup)->t_self)) \
> ) \
> : \
> + (((attnum) == ClassOidAttributeNumber) ? \
> ( \
> + (Datum)((tup)->relation->rd_id) \
> + ) \
> + : \
> + ( \
> (Datum)*(unsigned int *) \
> ((char *)(tup)->t_data + heap_sysoffset[-(attnum)-1]) \
> ! )) \
> ) \
> ) \
> )
> Index: src/include/access/htup.h
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/include/access/htup.h,v
> retrieving revision 1.30
> diff -c -r1.30 htup.h
> *** src/include/access/htup.h 2000/06/02 10:20:26 1.30
> --- src/include/access/htup.h 2000/06/24 15:25:02
> ***************
> *** 133,139 ****
> #define MinCommandIdAttributeNumber (-4)
> #define MaxTransactionIdAttributeNumber (-5)
> #define MaxCommandIdAttributeNumber (-6)
> ! #define FirstLowInvalidHeapAttributeNumber (-7)
>
> /* If you make any changes above, the order off offsets in this must change */
> extern long heap_sysoffset[];
> --- 133,140 ----
> #define MinCommandIdAttributeNumber (-4)
> #define MaxTransactionIdAttributeNumber (-5)
> #define MaxCommandIdAttributeNumber (-6)
> ! #define ClassOidAttributeNumber (-7)
> ! #define FirstLowInvalidHeapAttributeNumber (-8)
>
> /* If you make any changes above, the order off offsets in this must change */
> extern long heap_sysoffset[];
> ***************
> *** 156,161 ****
> --- 157,163 ----
> {
> uint32 t_len; /* length of *t_data */
> ItemPointerData t_self; /* SelfItemPointer */
> + Relation relation; /* */
> MemoryContext t_datamcxt; /* */
> HeapTupleHeader t_data; /* */
> } HeapTupleData;
> Index: src/include/catalog/pg_attribute.h
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/include/catalog/pg_attribute.h,v
> retrieving revision 1.59
> diff -c -r1.59 pg_attribute.h
> *** src/include/catalog/pg_attribute.h 2000/06/12 03:40:52 1.59
> --- src/include/catalog/pg_attribute.h 2000/06/24 15:25:04
> ***************
> *** 267,272 ****
> --- 267,273 ----
> DATA(insert OID = 0 ( 1247 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1247 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1247 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1247 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_database
> ***************
> *** 282,287 ****
> --- 283,289 ----
> DATA(insert OID = 0 ( 1262 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1262 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1262 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1262 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_proc
> ***************
> *** 329,334 ****
> --- 331,337 ----
> DATA(insert OID = 0 ( 1255 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1255 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1255 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1255 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_shadow
> ***************
> *** 348,353 ****
> --- 351,357 ----
> DATA(insert OID = 0 ( 1260 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1260 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1260 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1260 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_group
> ***************
> *** 362,367 ****
> --- 366,372 ----
> DATA(insert OID = 0 ( 1261 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1261 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1261 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1261 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_attribute
> ***************
> *** 405,410 ****
> --- 410,416 ----
> DATA(insert OID = 0 ( 1249 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1249 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1249 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1249 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_class
> ***************
> *** 458,463 ****
> --- 464,470 ----
> DATA(insert OID = 0 ( 1259 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1259 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1259 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1259 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_attrdef
> ***************
> *** 473,478 ****
> --- 480,486 ----
> DATA(insert OID = 0 ( 1215 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1215 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1215 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1215 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_relcheck
> ***************
> *** 488,493 ****
> --- 496,502 ----
> DATA(insert OID = 0 ( 1216 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1216 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1216 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1216 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_trigger
> ***************
> *** 513,518 ****
> --- 522,528 ----
> DATA(insert OID = 0 ( 1219 cmin 29 0 4 -4 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1219 xmax 28 0 4 -5 0 -1 -1 t p f i f f));
> DATA(insert OID = 0 ( 1219 cmax 29 0 4 -6 0 -1 -1 t p f i f f));
> + DATA(insert OID = 0 ( 1219 classoid 26 0 4 -7 0 -1 -1 t p f i f f));
>
> /* ----------------
> * pg_variable - this relation is modified by special purpose access
> Index: src/include/catalog/pg_type.h
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/include/catalog/pg_type.h,v
> retrieving revision 1.89
> diff -c -r1.89 pg_type.h
> *** src/include/catalog/pg_type.h 2000/06/05 07:29:01 1.89
> --- src/include/catalog/pg_type.h 2000/06/24 15:25:06
> ***************
> *** 337,342 ****
> --- 337,343 ----
> DATA(insert OID = 1025 ( _tinterval PGUID -1 -1 f b t \054 0 704 array_in array_out array_in array_out i _null_ ));
> DATA(insert OID = 1026 ( _filename PGUID -1 -1 f b t \054 0 605 array_in array_out array_in array_out i _null_ ));
> DATA(insert OID = 1027 ( _polygon PGUID -1 -1 f b t \054 0 604 array_in array_out array_in array_out d _null_ ));
> +
> /*
> * Note: the size of aclitem needs to match sizeof(AclItem) in acl.h.
> * Thanks to some padding, this will be 8 on all platforms.
> Index: src/tools/make_mkid
> ===================================================================
> RCS file: /home/projects/pgsql/cvsroot/pgsql/src/tools/make_mkid,v
> retrieving revision 1.4
> diff -c -r1.4 make_mkid
> *** src/tools/make_mkid 2000/03/31 01:41:27 1.4
> --- src/tools/make_mkid 2000/06/24 15:25:09
> ***************
> *** 1,6 ****
> #!/bin/sh
> find `pwd`/ \( -name _deadcode -a -prune \) -o \
> ! -type f -name '*.[chyl]' -print|sed 's;//;/;g' | mkid
>
> find . -name 'CVS' -prune -o -type d -print |while read DIR
> do
> --- 1,6 ----
> #!/bin/sh
> find `pwd`/ \( -name _deadcode -a -prune \) -o \
> ! -type f -name '*.[chyl]' -print|sed 's;//;/;g' | mkid -
>
> find . -name 'CVS' -prune -o -type d -print |while read DIR
> do

--
Bruce Momjian | http://candle.pha.pa.us
pgman(at)candle(dot)pha(dot)pa(dot)us | (610) 853-3000
+ If your life is a hard drive, | 830 Blythe Avenue
+ Christ can be your backup. | Drexel Hill, Pennsylvania 19026

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Vince Vielhaber 2000-10-10 22:01:26 Re: FreeBSD, OpenBSD, NetBSD templates
Previous Message Jim Mercer 2000-10-10 21:50:30 Re: FreeBSD, OpenBSD, NetBSD templates

Browse pgsql-patches by date

  From Date Subject
Next Message Tom Lane 2000-10-10 22:24:01 Re: [PATCHES] CLASSOID patch
Previous Message Peter Eisentraut 2000-10-10 15:52:01 Re: [PATCHES] Re: [ANNOUNCE] Announce: Release of PyGreSQL version 3.0