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/analyze.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/analyze.c')
-rw-r--r-- | src/backend/parser/analyze.c | 50 |
1 files changed, 49 insertions, 1 deletions
diff --git a/src/backend/parser/analyze.c b/src/backend/parser/analyze.c index b9c13dd7b95..874023c1872 100644 --- a/src/backend/parser/analyze.c +++ b/src/backend/parser/analyze.c @@ -7,7 +7,7 @@ * * * IDENTIFICATION - * $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.14 1996/11/10 03:01:10 momjian Exp $ + * $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.15 1996/11/13 20:48:55 scrappy Exp $ * *------------------------------------------------------------------------- */ @@ -77,6 +77,9 @@ static void AddAggToParseState(ParseState *pstate, Aggreg *aggreg); static void finalizeAggregates(ParseState *pstate, Query *qry); static void parseCheckAggregates(ParseState *pstate, Query *qry); +static bool is_lowercase(char *string); +static void make_lowercase(char *string); + /***************************************************************************** * *****************************************************************************/ @@ -1869,6 +1872,30 @@ ParseComplexProjection(ParseState *pstate, return NULL; } +static bool is_lowercase(char *string) +{ + int i; + + for(i = 0; i < strlen(string); i++) { + if(string[i] >= 'A' && string[i] <= 'Z') { + return false; + } + } + + return true; +} + +static void make_lowercase(char *string) +{ + int i; + + for(i = 0; i < strlen(string); i++) { + if(string[i] >= 'A' && string[i] <= 'Z') { + string[i] = (string[i] - 'A') + 'a'; + } + } +} + static Node * ParseFunc(ParseState *pstate, char *funcname, List *fargs, int *curr_resno) { @@ -1987,6 +2014,27 @@ ParseFunc(ParseState *pstate, char *funcname, List *fargs, int *curr_resno) AddAggToParseState(pstate, aggreg); return (Node*)aggreg; + } else { + /* try one more time with lowercase --djm 8/17/96 */ + if(!is_lowercase(funcname)) { + char *lowercase_funcname = strdup(funcname); + + make_lowercase(lowercase_funcname); + if (strcmp(lowercase_funcname, "count") == 0) + basetype = 0; + else + basetype = exprType(lfirst(fargs)); + if (SearchSysCacheTuple(AGGNAME, + PointerGetDatum(lowercase_funcname), + ObjectIdGetDatum(basetype), + 0, 0)) { + Aggreg *aggreg = ParseAgg(lowercase_funcname, + basetype, lfirst(fargs)); + + AddAggToParseState(pstate, aggreg); + return (Node*)aggreg; + } + } } } } |