diff options
author | Marc G. Fournier <scrappy@hub.org> | 1996-11-13 20:56:15 +0000 |
---|---|---|
committer | Marc G. Fournier <scrappy@hub.org> | 1996-11-13 20:56:15 +0000 |
commit | 07a65b22554d54455de5bc791a48fb0542f48791 (patch) | |
tree | 8320f9bb483ac60e34af929036a1a5a36c19d827 /src/backend/parser/parser.c | |
parent | 0cec8fe26c4c76bcc72b78c194a1aa026748c6dc (diff) | |
download | postgresql-07a65b22554d54455de5bc791a48fb0542f48791.tar.gz postgresql-07a65b22554d54455de5bc791a48fb0542f48791.zip |
Commit of a *MAJOR* patch from Dan McGuirk <djm@indirect.com>
Changes:
* Unique index capability works using the syntax 'create unique
index'.
* Duplicate OID's in the system tables are removed. I put
little scripts called 'duplicate_oids' and 'find_oid' in
include/catalog that help to find and remove duplicate OID's.
I also moved 'unused_oids' from backend/catalog to
include/catalog, since it has to be in the same directory
as the include files in order to work.
* The backend tries converting the name of a function or aggregate
to all lowercase if the original name given doesn't work (mostly
for compatibility with ODBC).
* You can 'SELECT NULL' to your heart's content.
* I put my _bt_updateitem fix in instead, which uses
_bt_insertonpg so that even if the new key is so big that
the page has to be split, everything still works.
* All literal references to system catalog OID's have been
replaced with references to define'd constants from the catalog
header files.
* I added a couple of node copy functions. I think this was a
preliminary attempt to get rules to work.
Diffstat (limited to 'src/backend/parser/parser.c')
-rw-r--r-- | src/backend/parser/parser.c | 28 |
1 files changed, 14 insertions, 14 deletions
diff --git a/src/backend/parser/parser.c b/src/backend/parser/parser.c index 57e25a68632..89bd5b56a70 100644 --- a/src/backend/parser/parser.c +++ b/src/backend/parser/parser.c @@ -6,7 +6,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/parser/parser.c,v 1.10 1996/11/10 03:30:46 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/parser/parser.c,v 1.11 1996/11/13 20:49:07 scrappy Exp $ * *------------------------------------------------------------------------- */ @@ -216,36 +216,36 @@ parser_typecast(Value *expr, TypeName *typename, int typlen) #if 0 /* fix me */ switch ( CInteger(lfirst(expr)) ) { - case 23: /* int4 */ + case INT4OID: /* int4 */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%d", ((Const*)lnext(expr))->constvalue); break; - case 19: /* char16 */ + case NAMEOID: /* char16 */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%s", ((Const*)lnext(expr))->constvalue); break; - case 18: /* char */ + case CHAROID: /* char */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%c", ((Const)lnext(expr))->constvalue); break; - case 701:/* float8 */ + case FLOAT8OID:/* float8 */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%f", ((Const)lnext(expr))->constvalue); break; - case 25: /* text */ + case TEXTOID: /* text */ const_string = DatumGetPointer(((Const)lnext(expr))->constvalue); const_string = (char *) textout((struct varlena *)const_string); break; - case 705: /* unknown */ + case UNKNOWNOID: /* unknown */ const_string = DatumGetPointer(((Const)lnext(expr))->constvalue); const_string = (char *) textout((struct varlena *)const_string); break; @@ -312,25 +312,25 @@ parser_typecast2(Node *expr, int exprType, Type tp, int typlen) switch (exprType) { case 0: /* NULL */ break; - case 23: /* int4 */ + case INT4OID: /* int4 */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%d", (int) ((Const*)expr)->constvalue); break; - case 19: /* char16 */ + case NAMEOID: /* char16 */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%s", (char*) ((Const*)expr)->constvalue); break; - case 18: /* char */ + case CHAROID: /* char */ const_string = (char *) palloc(256); string_palloced = true; sprintf(const_string,"%c", (char) ((Const*)expr)->constvalue); break; - case 700: /* float4 */ + case FLOAT4OID: /* float4 */ { float32 floatVal = DatumGetFloat32(((Const*)expr)->constvalue); @@ -339,7 +339,7 @@ parser_typecast2(Node *expr, int exprType, Type tp, int typlen) sprintf(const_string,"%f", *floatVal); break; } - case 701:/* float8 */ + case FLOAT8OID:/* float8 */ { float64 floatVal = DatumGetFloat64(((Const*)expr)->constvalue); @@ -348,12 +348,12 @@ parser_typecast2(Node *expr, int exprType, Type tp, int typlen) sprintf(const_string,"%f", *floatVal); break; } - case 25: /* text */ + case TEXTOID: /* text */ const_string = DatumGetPointer(((Const*)expr)->constvalue ); const_string = (char *) textout((struct varlena *)const_string); break; - case 705: /* unknown */ + case UNKNOWNOID: /* unknown */ const_string = DatumGetPointer(((Const*)expr)->constvalue ); const_string = (char *) textout((struct varlena *)const_string); |