]> granicus.if.org Git - postgresql/log
postgresql
24 years agoA bit of cleanup after SSL patch. Add it to config file, improve
Peter Eisentraut [Wed, 6 Sep 2000 19:54:52 +0000 (19:54 +0000)]
A bit of cleanup after SSL patch. Add it to config file, improve
documentation.

24 years agoCode cleanup of user name and user id handling in the backend. The current
Peter Eisentraut [Wed, 6 Sep 2000 14:15:31 +0000 (14:15 +0000)]
Code cleanup of user name and user id handling in the backend. The current
user is now defined in terms of the user id, the user name is only computed
upon request (for display purposes). This is kind of the opposite of the
previous state, which would maintain the user name and compute the user id
for permission checks.

Besides perhaps saving a few cycles (integer vs string), this now creates a
single point of attack for changing the user id during a connection, for
purposes of "setuid" functions, etc.

24 years agoAdded functions
Jan Wieck [Tue, 5 Sep 2000 20:25:14 +0000 (20:25 +0000)]
Added functions
    quote_ident(text) returns text
    quote_literal(text) returns text

These are handy to build up properly quoted query strings
for the new PL/pgSQL EXECUTE functionality to submit
dynamic DDL statements.

Jan

24 years agoGZIP vs ZIP variable naming messed up
Peter Eisentraut [Tue, 5 Sep 2000 18:45:38 +0000 (18:45 +0000)]
GZIP vs ZIP variable naming messed up

24 years agoGET DIAGNOSTICS statement to PL/pgSQL to access SPI_processed
Jan Wieck [Tue, 5 Sep 2000 09:02:18 +0000 (09:02 +0000)]
GET DIAGNOSTICS statement to PL/pgSQL to access SPI_processed
and SPI_return values. Patch from Philip Warner.

Jan

24 years agoChange initdb to not delete PGDATA directory unless it was created by
Peter Eisentraut [Fri, 1 Sep 2000 13:15:27 +0000 (13:15 +0000)]
Change initdb to not delete PGDATA directory unless it was created by
initdb itself. Refuse to run on existing but non-empty PGDATA directory.

24 years agoFix relative path references so that make knowns which dependencies refer
Peter Eisentraut [Thu, 31 Aug 2000 16:12:35 +0000 (16:12 +0000)]
Fix relative path references so that make knowns which dependencies refer
to one another. Sort out builddir vs srcdir variable namings. Remove some
now obsoleted make variables.

24 years agoAdded EXECUTE command to PL/pgSQL for execution of
Jan Wieck [Thu, 31 Aug 2000 13:26:16 +0000 (13:26 +0000)]
Added EXECUTE command to PL/pgSQL for execution of
dynamic SQL and utility statements.

Jan

24 years agoAbortOutOfAnyTransaction() just before backend exit, to ensure that
Tom Lane [Wed, 30 Aug 2000 20:30:06 +0000 (20:30 +0000)]
AbortOutOfAnyTransaction() just before backend exit, to ensure that
resources are cleaned up if the user disconnected mid-transaction.
Great thanks to Hiroshi for pointing out what should have been obvious...

24 years agoSSL patch from Magnus
Bruce Momjian [Wed, 30 Aug 2000 14:54:24 +0000 (14:54 +0000)]
SSL patch from Magnus

24 years agoImprove the following.
Hiroshi Inoue [Wed, 30 Aug 2000 08:48:55 +0000 (08:48 +0000)]
Improve the following.
 =# create table t (id int4 unique);
NOTICE:  CREATE TABLE/UNIQUE will create implicit index 't_id_key' for table 't'
 =# begin;
 query: drop table t;
NOTICE:  Caution: DROP TABLE cannot be rolled back, so don't abort now
NOTICE:  Caution: DROP INDEX cannot be rolled back, so don't abort now
 =# rollback;
 =# drop table t;
NOTICE:  mdopen: couldn't open t: No such file or directory
NOTICE:  RelationIdBuildRelation: smgropen(t): No such file or directory
NOTICE:  mdopen: couldn't open t: No such file or directory
NOTICE:  mdopen: couldn't open t: No such file or directory
NOTICE:  mdopen: couldn't open t_id_key: No such file or directory
NOTICE:  RelationIdBuildRelation: smgropen(t_id_key): No such file or directory
NOTICE:  mdopen: couldn't open t: No such file or directory
NOTICE:  RelationIdBuildRelation: smgropen(t): No such file or directory
NOTICE:  mdopen: couldn't open t: No such file or directory
ERROR:  cannot open relation t

24 years agoStartup is actually start-up.
Bruce Momjian [Tue, 29 Aug 2000 20:02:09 +0000 (20:02 +0000)]
Startup is actually start-up.

24 years agoInclude kernel error message in failed-to-open file reports.
Tom Lane [Tue, 29 Aug 2000 16:40:19 +0000 (16:40 +0000)]
Include kernel error message in failed-to-open file reports.

24 years agoRevert removal of signed, volatile, and signal handler arg type tests.
Peter Eisentraut [Tue, 29 Aug 2000 09:36:51 +0000 (09:36 +0000)]
Revert removal of signed, volatile, and signal handler arg type tests.

24 years ago * to_char:
Bruce Momjian [Tue, 29 Aug 2000 04:41:48 +0000 (04:41 +0000)]
 * to_char:

  - full support for IW (ISO week) and vice versa conversion for IW too
    (the to_char 'week' support is now complete and I hope correct).

  Thomas, I use for IW code from timestamp.c, for this I create separate
  function date2isoweek() from original 'case DTK_WEEK:' code in the
  timestamp_part(). I mean will better use one code for same feature in
  date_part() and in to_char(). The isoweek2date() is added to timestamp.c
  too. Right?

  IMHO in 7.1 will all to_char's features complete. It is cca 41 templates
  for date/time and cca 21 for numbers.

 * to_ascii:

   - gcc, is it correct now? :-)

  In the patch is documentation for to_char's IW and for to_ascii().

                                                        Karel

24 years agoThis is mostly the same as an earlier patch I
Bruce Momjian [Tue, 29 Aug 2000 04:20:47 +0000 (04:20 +0000)]
This is mostly the same as an earlier patch I
didn't hear anything about, but which would
have broken with the function manager changes
anyway.

Well, this patch checks that a unique constraint
of some form (unique or pk) is on the referenced
columns of an FK constraint and that the columns
in the referencing table exist at creation time.
The former is to move closer to SQL compatibility
and the latter is in answer to a bug report.
I also added a basic check of this functionality
to the alter table and foreign key regression
tests.

Stephan Szabo
sszabo@bigpanda.com

24 years agoHere is a patch against the same cvs tree as the SSL patch (Aug 20).
Bruce Momjian [Tue, 29 Aug 2000 04:15:43 +0000 (04:15 +0000)]
Here is a patch against the same cvs tree as the SSL patch (Aug 20).
I hope I didn't mess the SGML up too bad, but somebody should definitly
look that over. I tried to steal as much as I could from around :-)

This patch updates:
* Installation instructions (paragraph on how to compile with openssl)
* Documentation of pg_hba.conf (added "hostssl" record docs)
* Libpq documentation (added connection option, documentation of
  PQgetssl() function)
* Add section on SSL to "Server Runtime Environment"

If you beleive any particular area needs more attention, please let me know.

//Magnus

24 years agoUpdate obsolete comments.
Tom Lane [Tue, 29 Aug 2000 02:00:38 +0000 (02:00 +0000)]
Update obsolete comments.

24 years agoRemove bogus use of int4out().
Tom Lane [Tue, 29 Aug 2000 00:57:21 +0000 (00:57 +0000)]
Remove bogus use of int4out().

24 years agoMaybe "shared_buffers" is a slightly better name than "shmem_buffers" for -B.
Peter Eisentraut [Mon, 28 Aug 2000 11:57:41 +0000 (11:57 +0000)]
Maybe "shared_buffers" is a slightly better name than "shmem_buffers" for -B.

24 years agoNew configure test for flex, which recognizes only flex but does so in all
Peter Eisentraut [Mon, 28 Aug 2000 11:53:23 +0000 (11:53 +0000)]
New configure test for flex, which recognizes only flex but does so in all
incarnations (I hope). When an acceptable flex version is not found, print
instructive error messages from both configure and the makefiles, so that
users can continue building anyway.

24 years agoClean up callers of AllocateFile and BasicOpenFile to ensure that
Tom Lane [Sun, 27 Aug 2000 21:50:18 +0000 (21:50 +0000)]
Clean up callers of AllocateFile and BasicOpenFile to ensure that
a reasonable error message (including the kernel errno message)
is reported on any file open failure.

24 years agoChange ReleaseLruFile() usage so that if we cannot release any more
Tom Lane [Sun, 27 Aug 2000 21:48:00 +0000 (21:48 +0000)]
Change ReleaseLruFile() usage so that if we cannot release any more
virtual FDs, we just return the ENFILE/EMFILE error to the caller,
rather than immediate elog().  This allows more robust behavior in
the postmaster, which uses AllocateFile() but does not want elog().

24 years agoUpdate FAQ.
Bruce Momjian [Sun, 27 Aug 2000 19:25:31 +0000 (19:25 +0000)]
Update FAQ.

24 years agoRemove configure tests for `signed', `volatile', and signal handler args;
Peter Eisentraut [Sun, 27 Aug 2000 19:00:41 +0000 (19:00 +0000)]
Remove configure tests for `signed', `volatile', and signal handler args;
the harm potential outweighs the possible benefits.

24 years agoChange pg_mblen and pg_encoding_mblen return types from void
Tatsuo Ishii [Sun, 27 Aug 2000 10:40:48 +0000 (10:40 +0000)]
Change pg_mblen and pg_encoding_mblen return types from void
to int so that they return the number of whcars.

24 years agoUpdate FAQ.
Bruce Momjian [Sun, 27 Aug 2000 03:55:20 +0000 (03:55 +0000)]
Update FAQ.

24 years agoTired of seeing these warnings ...
Tom Lane [Sat, 26 Aug 2000 21:56:23 +0000 (21:56 +0000)]
Tired of seeing these warnings ...

24 years agoRename BITSPERBYTE to BITS_PER_BYTE to avoid conflict with <values.h>
Tom Lane [Sat, 26 Aug 2000 21:53:44 +0000 (21:53 +0000)]
Rename BITSPERBYTE to BITS_PER_BYTE to avoid conflict with <values.h>
on some platforms.

24 years agoFix AC_FUNC_ACCEPT_ARGTYPES to accept `const struct sockaddr *' as second
Peter Eisentraut [Sat, 26 Aug 2000 21:11:45 +0000 (21:11 +0000)]
Fix AC_FUNC_ACCEPT_ARGTYPES to accept `const struct sockaddr *' as second
argument, change the order of tests for the third argument to be safe
against missing prototypes, and make it fail hard if none of the
combinations succeed.

24 years agoThis file seems not to have been updated for the most
Tom Lane [Sat, 26 Aug 2000 19:47:41 +0000 (19:47 +0000)]
This file seems not to have been updated for the most
recent change to geometry.sql.

24 years agoUpdate platform FAQs
Peter Eisentraut [Sat, 26 Aug 2000 19:34:24 +0000 (19:34 +0000)]
Update platform FAQs

24 years agoRemove old FAQ files.
Bruce Momjian [Sat, 26 Aug 2000 18:46:17 +0000 (18:46 +0000)]
Remove old FAQ files.

24 years agoUpdate FAQ.
Bruce Momjian [Sat, 26 Aug 2000 18:20:55 +0000 (18:20 +0000)]
Update FAQ.

24 years agoAdd pg-config utility that stores some configuration parameters other
Peter Eisentraut [Sat, 26 Aug 2000 13:08:16 +0000 (13:08 +0000)]
Add pg-config utility that stores some configuration parameters other
packages can use to configure their build.

E.g.,
$ pg-config --libdir
/usr/local/pgsql/lib

`pg-config --configure' stores the configure command line.

24 years agoTweak btree insertion to avoid O(N^2) slowdown with large numbers of
Tom Lane [Fri, 25 Aug 2000 23:13:33 +0000 (23:13 +0000)]
Tweak btree insertion to avoid O(N^2) slowdown with large numbers of
equal keys.  See discussion of today's date in pghackers list.

24 years agoAvoid creating a TOAST table if we can prove that the maximum tuple
Tom Lane [Fri, 25 Aug 2000 18:05:54 +0000 (18:05 +0000)]
Avoid creating a TOAST table if we can prove that the maximum tuple
length is < TOAST_TUPLE_THRESHOLD, even with toastable column types
present.  For example, CREATE TABLE foo (f1 int, f2 varchar(100))
does not require a toast table, even though varchar is a toastable
type.

24 years agoFix typos and inconsistancies found by He Weiping
Thomas G. Lockhart [Fri, 25 Aug 2000 15:17:50 +0000 (15:17 +0000)]
Fix typos and inconsistancies found by He Weiping
 (aka Henry) <laser@zhangmai.com.cn>.
Fix new problems in insert.sgml and create_function.sgml which kept jade
 from completing.

24 years agoChange return type of:
Tatsuo Ishii [Fri, 25 Aug 2000 14:24:09 +0000 (14:24 +0000)]
Change return type of:
       pg_mb2wchar(const unsigned char *, pg_wchar *);
       pg_mb2wchar_with_len(const unsigned char *, pg_wchar *, int);
from void to int. Now they return the number of
wide chars.

24 years agoMake the location of the Kerberos server key file run time configurable
Peter Eisentraut [Fri, 25 Aug 2000 10:00:35 +0000 (10:00 +0000)]
Make the location of the Kerberos server key file run time configurable
(rather than compile time). For libpq, even when Kerberos support is
compiled in, the default user name should still fall back to geteuid()
if it can't be determined via the Kerberos system.

A couple of fixes for string type configuration parameters, now that there
is one.

24 years agoDocumentation updates to reflect TOAST and new-style fmgr.
Tom Lane [Thu, 24 Aug 2000 23:59:38 +0000 (23:59 +0000)]
Documentation updates to reflect TOAST and new-style fmgr.

24 years agoDocumentation updates to reflect TOAST and new-style fmgr.
Tom Lane [Thu, 24 Aug 2000 23:36:29 +0000 (23:36 +0000)]
Documentation updates to reflect TOAST and new-style fmgr.

24 years agoGetAttributeByName and GetAttributeByNum should be declared to return
Tom Lane [Thu, 24 Aug 2000 23:34:11 +0000 (23:34 +0000)]
GetAttributeByName and GetAttributeByNum should be declared to return
Datum, not char*, for portability's sake.

24 years agoUpdate funcs tutorial for new function manager.
Tom Lane [Thu, 24 Aug 2000 23:32:43 +0000 (23:32 +0000)]
Update funcs tutorial for new function manager.

24 years agoSQL-language functions are now callable in ordinary fmgr contexts ...
Tom Lane [Thu, 24 Aug 2000 03:29:15 +0000 (03:29 +0000)]
SQL-language functions are now callable in ordinary fmgr contexts ...
for example, an SQL function can be used in a functional index.  (I make
no promises about speed, but it'll work ;-).)  Clean up and simplify
handling of functions returning sets.

24 years agoComment fixes from Larry Rosenman" <ler@lerctr.org>.
Thomas G. Lockhart [Wed, 23 Aug 2000 13:44:14 +0000 (13:44 +0000)]
Comment fixes from Larry Rosenman" <ler@lerctr.org>.

24 years agoAdd functions to convert to and from text, and to truncate to MAC OUI.
Thomas G. Lockhart [Wed, 23 Aug 2000 06:04:49 +0000 (06:04 +0000)]
Add functions to convert to and from text, and to truncate to MAC OUI.
Remove hardcoded macaddr_manuf(), which had really old, obsolete info.
 Replace this with some contrib/mac/ code to maniag OUI info from IEEE.

24 years agoCreate and manage information on MAC address OUIs
Thomas G. Lockhart [Wed, 23 Aug 2000 06:02:23 +0000 (06:02 +0000)]
Create and manage information on MAC address OUIs
 (Organizationally Unique Identifiers).
 This is the manufacturer's code in the MAC address.

24 years agoFix several <ulink> tags which refer to e-mail addresses
Thomas G. Lockhart [Wed, 23 Aug 2000 05:59:11 +0000 (05:59 +0000)]
Fix several <ulink> tags which refer to e-mail addresses
 but were missing the "mailto:" prefix.
Fix typo.
Thanks to Neil Conway <nconway@klamath.dyndns.org> for the heads-up.

24 years agoFix plpgsql lexer to accept Windows-style and Mac-style newlines as
Tom Lane [Tue, 22 Aug 2000 14:59:28 +0000 (14:59 +0000)]
Fix plpgsql lexer to accept Windows-style and Mac-style newlines as
newlines.

24 years agoMake scanner multibyte aware. Currently it may produce an incorrect
Tatsuo Ishii [Tue, 22 Aug 2000 13:01:20 +0000 (13:01 +0000)]
Make scanner multibyte aware. Currently it may produce an incorrect
multibyte sequence while truncating identifiers.

24 years agoMake makeObjectName multibyte aware. Currently, it may produce
Tatsuo Ishii [Tue, 22 Aug 2000 12:59:04 +0000 (12:59 +0000)]
Make makeObjectName multibyte aware. Currently, it may produce
incorrect multibyte sequence while truncating too long names.

24 years agoAdd multibyte support for both LIKE and ILIKE
Tatsuo Ishii [Tue, 22 Aug 2000 06:33:57 +0000 (06:33 +0000)]
Add multibyte support for both LIKE and ILIKE
Eliminate up-to-4-times memory allocation problem

24 years agoFix a many-legged critter reported by chifungfan@yahoo.com: under the
Tom Lane [Tue, 22 Aug 2000 04:06:22 +0000 (04:06 +0000)]
Fix a many-legged critter reported by chifungfan@yahoo.com: under the
right circumstances a hash join executed as a DECLARE CURSOR/FETCH
query would crash the backend.  Problem as seen in current sources was
that the hash tables were stored in a context that was a child of
TransactionCommandContext, which got zapped at completion of the FETCH
command --- but cursor cleanup executed at COMMIT expected the tables
to still be valid.  I haven't chased down the details as seen in 7.0.*
but I'm sure it's the same general problem.

24 years agoAdd some more Assert checks.
Tom Lane [Tue, 22 Aug 2000 04:00:10 +0000 (04:00 +0000)]
Add some more Assert checks.

24 years agoMove pg_checkretval out of the planner (where it never belonged) into
Tom Lane [Mon, 21 Aug 2000 20:55:31 +0000 (20:55 +0000)]
Move pg_checkretval out of the planner (where it never belonged) into
pg_proc.c (where it's actually used).  Fix it to correctly handle tlists
that contain resjunk target items, and improve error messages.  This
addresses bug reported by Krupnikov 6-July-00.

24 years agoFix format_type() to display correct lengths for BIT/BIT VARYING.
Tom Lane [Mon, 21 Aug 2000 18:23:18 +0000 (18:23 +0000)]
Fix format_type() to display correct lengths for BIT/BIT VARYING.
Also, make it depend on type OIDs rather than type names for more
consistency with rest of backend.

24 years agofmgr interface mopup work. Use new DatumGetBool and BoolGetDatum
Tom Lane [Mon, 21 Aug 2000 17:22:36 +0000 (17:22 +0000)]
fmgr interface mopup work.  Use new DatumGetBool and BoolGetDatum
macros where appropriate (the code used to have several different ways
of doing that, including Int32, Int8, UInt8, ...).  Remove last few
references to float32 and float64 typedefs --- it's all float4/float8
now.  The typedefs themselves should probably stay in c.h for a release
or two, though, to avoid breaking user-written C functions.

24 years agoFirst pass at integrating BIT and BIT VARYING code from Adriaan Joubert.
Tom Lane [Mon, 21 Aug 2000 04:48:57 +0000 (04:48 +0000)]
First pass at integrating BIT and BIT VARYING code from Adriaan Joubert.
Update functions to new-style fmgr, make BIT and VARBIT be binary-
equivalent, add entries to allow these types to be btree indexed,
correct a few bugs.  BIT/VARBIT are now toastable, too.
NOTE: initdb forced due to catalog updates.

24 years agoStandardize on just one spelling of BITSPERBYTE.
Tom Lane [Sun, 20 Aug 2000 19:31:37 +0000 (19:31 +0000)]
Standardize on just one spelling of BITSPERBYTE.

24 years agocoupla minor fixes in the `make dist' support code
Peter Eisentraut [Sun, 20 Aug 2000 15:55:15 +0000 (15:55 +0000)]
coupla minor fixes in the `make dist' support code

24 years agoSubstitute libdir into createlang as last resort so one doesn't have to set
Peter Eisentraut [Sun, 20 Aug 2000 11:56:29 +0000 (11:56 +0000)]
Substitute libdir into createlang as last resort so one doesn't have to set
PGLIB or use any option anymore.

24 years agoIntroduce HAVE_UNIX_SOCKETS symbol to replace repeatedly listing all the
Peter Eisentraut [Sun, 20 Aug 2000 10:55:35 +0000 (10:55 +0000)]
Introduce HAVE_UNIX_SOCKETS symbol to replace repeatedly listing all the
unsupported platforms.

24 years agoMake functional indexes accept binary-compatible functions, for example
Tom Lane [Sun, 20 Aug 2000 00:44:19 +0000 (00:44 +0000)]
Make functional indexes accept binary-compatible functions, for example
CREATE INDEX fooi ON foo (lower(f1)) where f1 is varchar rather than text.

24 years ago./configure --without-CXX errroneously tried to use a C++ compiler named "no"
Peter Eisentraut [Sat, 19 Aug 2000 23:39:36 +0000 (23:39 +0000)]
./configure --without-CXX errroneously tried to use a C++ compiler named "no"

reported by Mark Hollomon

24 years agoClean up handling of variable-free qual clauses. System now does the
Tom Lane [Sun, 13 Aug 2000 02:50:35 +0000 (02:50 +0000)]
Clean up handling of variable-free qual clauses.  System now does the
right thing with variable-free clauses that contain noncachable functions,
such as 'WHERE random() < 0.5' --- these are evaluated once per
potential output tuple.  Expressions that contain only Params are
now candidates to be indexscan quals --- for example, 'var = ($1 + 1)'
can now be indexed.  Cope with RelabelType nodes atop potential indexscan
variables --- this oversight prevents 7.0.* from recognizing some
potentially indexscanable situations.

24 years agoMop-up for removal of ':' and ';' operators ... like, say, actually
Tom Lane [Sat, 12 Aug 2000 05:15:24 +0000 (05:15 +0000)]
Mop-up for removal of ':' and ';' operators ... like, say, actually
take 'em out of pg_operator.  Also remove from scan.l's set of legal
operator characters.  Update documentation.

24 years agoFix ruleutils to produce correct output for array assignment, such
Tom Lane [Sat, 12 Aug 2000 04:04:53 +0000 (04:04 +0000)]
Fix ruleutils to produce correct output for array assignment, such
as UPDATE foo SET arr[3] = 42.

24 years agoUpdate comments for some parse node types.
Tom Lane [Fri, 11 Aug 2000 23:46:54 +0000 (23:46 +0000)]
Update comments for some parse node types.

24 years agocopyObject() and equal() now know about all parse-time node types,
Tom Lane [Fri, 11 Aug 2000 23:45:35 +0000 (23:45 +0000)]
copyObject() and equal() now know about all parse-time node types,
including utility statements.  Still can't copy or compare executor
state, but at present that doesn't seem to be necessary.  This makes
it possible to execute most (all?) utility statements in plpgsql.
Had to change parsetree representation of CreateTrigStmt so that it
contained only legal Nodes, and not bare string constants.

24 years agoRemove debugging Assert that should never have been committed in the
Tom Lane [Fri, 11 Aug 2000 18:35:50 +0000 (18:35 +0000)]
Remove debugging Assert that should never have been committed in the
first place :-(

24 years agoMake debug_assertions default to ON, when compiled in at all, for
Tom Lane [Fri, 11 Aug 2000 18:31:10 +0000 (18:31 +0000)]
Make debug_assertions default to ON, when compiled in at all, for
backwards compatibility with old behavior.

24 years agoCREATE btree INDEX takes dead tuples into account when old transactions
Hiroshi Inoue [Thu, 10 Aug 2000 02:33:20 +0000 (02:33 +0000)]
CREATE btree INDEX takes dead tuples into account when old transactions
are running.

24 years agoReimplement MULTIBYTE support (oops). Not tested, but it does compile.
Thomas G. Lockhart [Wed, 9 Aug 2000 14:13:03 +0000 (14:13 +0000)]
Reimplement MULTIBYTE support (oops). Not tested, but it does compile.

24 years agoRemove 'func_tlist' from Func expression nodes, likewise 'param_tlist'
Tom Lane [Tue, 8 Aug 2000 15:43:12 +0000 (15:43 +0000)]
Remove 'func_tlist' from Func expression nodes, likewise 'param_tlist'
from Param nodes, per discussion a few days ago on pghackers.  Add new
expression node type FieldSelect that implements the functionality where
it's actually needed.  Clean up some other unused fields in Func nodes
as well.
NOTE: initdb forced due to change in stored expression trees for rules.

24 years agoBuf fix to pg_restire -S option in getopts
Philip Warner [Tue, 8 Aug 2000 11:48:59 +0000 (11:48 +0000)]
Buf fix to pg_restire -S option in getopts

24 years agoTOAST mop-up work: update comments for tuple-size-related symbols such
Tom Lane [Mon, 7 Aug 2000 20:16:13 +0000 (20:16 +0000)]
TOAST mop-up work: update comments for tuple-size-related symbols such
as MaxHeapAttributeNumber.  Increase MaxAttrSize to something more
reasonable (given what it's used for, namely checking char(n) declarations,
I didn't make it the full 1G that it could theoretically be --- 10Mb
seemed a more reasonable number).  Improve calculation of MaxTupleSize.

24 years agoFix incorrect example of CAST syntax (was missing required parentheses).
Tom Lane [Mon, 7 Aug 2000 19:53:27 +0000 (19:53 +0000)]
Fix incorrect example of CAST syntax (was missing required parentheses).

24 years ago- version # change in header
Philip Warner [Mon, 7 Aug 2000 12:39:37 +0000 (12:39 +0000)]
- version # change in header
CVs: ----------------------------------------------------------------------

24 years ago- Support for iscachable when dumping functions
Philip Warner [Mon, 7 Aug 2000 12:32:54 +0000 (12:32 +0000)]
- Support for iscachable when dumping functions

24 years agoAllow LIKE and ILIKE as TokenId (and hence ColId) to make sure that they
Thomas G. Lockhart [Mon, 7 Aug 2000 06:54:51 +0000 (06:54 +0000)]
Allow LIKE and ILIKE as TokenId (and hence ColId) to make sure that they
 are allowed in the func_name production. Otherwise, we can't define
 more like() and ilike() functions for new data types.

24 years agoClean up code to remove the explicit backslash cruft.
Thomas G. Lockhart [Mon, 7 Aug 2000 01:45:00 +0000 (01:45 +0000)]
Clean up code to remove the explicit backslash cruft.
If the backslash default is still wanted, just pass a backslash
 to MatchText() for the two-parameter callable routines.

24 years agoInclude the case-insensitive LIKE prototypes.
Thomas G. Lockhart [Mon, 7 Aug 2000 01:43:35 +0000 (01:43 +0000)]
Include the case-insensitive LIKE prototypes.

24 years agoForgot to update the regression test output.
Thomas G. Lockhart [Mon, 7 Aug 2000 01:43:14 +0000 (01:43 +0000)]
Forgot to update the regression test output.

24 years agoClean up bogosities in use of random(3) and srandom(3) --- do not assume
Tom Lane [Mon, 7 Aug 2000 00:51:42 +0000 (00:51 +0000)]
Clean up bogosities in use of random(3) and srandom(3) --- do not assume
that RAND_MAX applies to them, since it doesn't.  Instead add a
config.h parameter MAX_RANDOM_VALUE.  This is currently set at 2^31-1
but could be auto-configured if that ever proves necessary.  Also fix
some outright bugs like calling srand() where srandom() is appropriate.

24 years agoImplement LIKE/ESCAPE. Change parser to use like()/notlike()
Thomas G. Lockhart [Sun, 6 Aug 2000 18:13:42 +0000 (18:13 +0000)]
Implement LIKE/ESCAPE. Change parser to use like()/notlike()
 rather than the "~~" operator; this made it easy to add ESCAPE features.
Implement ILIKE, NOT ILIKE, and the ESCAPE clause for them.
 afaict this is not MultiByte clean, but lots of other stuff isn't either.
Fix up underlying support code for LIKE/NOT LIKE.
 Things should be faster and does not require internal string copying.
Update regression test to add explicit checks for
 LIKE/NOT LIKE/ILIKE/NOT ILIKE.
Remove colon and semi-colon operators as threatened in 7.0.
Implement SQL99 COMMIT/AND NO CHAIN.
 Throw elog(ERROR) on COMMIT/AND CHAIN per spec
 since we don't yet support it.
Implement SQL99 CREATE/DROP SCHEMA as equivalent to CREATE DATABASE.
 This is only a stopgap or demo since schemas will have another
 implementation soon.
Remove a few unused production rules to get rid of warnings
 which crept in on the last commit.
Fix up tabbing in some places by removing embedded spaces.

24 years agoImplement LIKE/ESCAPE. Change parser to use like()/notlike()
Thomas G. Lockhart [Sun, 6 Aug 2000 18:06:44 +0000 (18:06 +0000)]
Implement LIKE/ESCAPE. Change parser to use like()/notlike()
 rather than the "~~" operator; this made it easy to add ESCAPE features.
Implement ILIKE, NOT ILIKE, and the ESCAPE clause for them.
 afaict this is not MultiByte clean, but lots of other stuff isn't either.
Fix up underlying support code for LIKE/NOT LIKE.
 Things should be faster and does not require internal string copying.
Update regression test to add explicit checks for
 LIKE/NOT LIKE/ILIKE/NOT ILIKE.
Remove colon and semi-colon operators as threatened in 7.0.
Implement SQL99 COMMIT/AND NO CHAIN.
 Throw elog(ERROR) on COMMIT/AND CHAIN per spec
 since we don't yet support it.
Implement SQL99 CREATE/DROP SCHEMA as equivalent to CREATE DATABASE.
 This is only a stopgap or demo since schemas will have another
 implementation soon.
Remove a few unused production rules to get rid of warnings
 which crept in on the last commit.
Fix up tabbing in some places by removing embedded spaces.

24 years agoSupport SQL99 embedded double-quote syntax for quoted identifiers.
Thomas G. Lockhart [Sun, 6 Aug 2000 17:50:48 +0000 (17:50 +0000)]
Support SQL99 embedded double-quote syntax for quoted identifiers.
Allow this in the parser and in pg_dump, but it is probably not enough
 for a complete solution.
Better to have the feature started then never here.

24 years agoToast all the system-table columns that seem to need it. It turns out
Tom Lane [Sun, 6 Aug 2000 04:40:08 +0000 (04:40 +0000)]
Toast all the system-table columns that seem to need it.  It turns out
that giving pg_proc a toast table required solving the same problems
we'd have to solve for pg_class --- pg_proc is one of the relations
that gets bootstrapped in relcache.c.  Solution is to go back at the
end of initialization and read in the *real* pg_class row to replace
the phony entry created by formrdesc().  This should work as long as
there's no need to touch any toasted values during initialization,
which seems a reasonable assumption.
Although I did not add a toast-table for every single system table
with a varlena attribute, I believe that it would work to just do
ALTER TABLE pg_class CREATE TOAST TABLE.  So anyone who's really
intent on having several thousand ACL entries for a rel could do it.
NOTE: I didn't force initdb, but you must do one to see the effects
of this patch.

24 years agoClean up inefficiency in ExecRelCheck, and cause it to do the right
Tom Lane [Sun, 6 Aug 2000 04:26:40 +0000 (04:26 +0000)]
Clean up inefficiency in ExecRelCheck, and cause it to do the right
thing when there are multiple result relations.  Formerly, during
something like 'UPDATE foo*', foo's constraints and *only* foo's
constraints would be applied to all foo's children.  Wrong-o ...

24 years agoEnsure that catcache 'busy' flags are reset at transaction abort.
Tom Lane [Sun, 6 Aug 2000 04:17:47 +0000 (04:17 +0000)]
Ensure that catcache 'busy' flags are reset at transaction abort.
Without this, an elog during cache-entry load leaves that catcache
unusable.  elog in that segment of code is pretty unusual but it can
happen.

24 years agoCopy sub-Query nodes to avoid trouble when same sub-Query is linked to
Tom Lane [Sun, 6 Aug 2000 04:13:22 +0000 (04:13 +0000)]
Copy sub-Query nodes to avoid trouble when same sub-Query is linked to
multiple times in the parsetree (can happen in COALESCE or BETWEEN
contexts, for example).  This is a pretty grotty solution --- it will
do for now, but perhaps we can do better when we redesign querytrees.
What we need is a consistent policy about whether querytrees should be
considered read-only structures or not ...

24 years ago> I had to back out the patch. It only compiles with multi-byte enabled.
Bruce Momjian [Sat, 5 Aug 2000 14:59:29 +0000 (14:59 +0000)]
> I had to back out the patch. It only compiles with multi-byte enabled.

 Ooops, I forget... here it is again.

> > >  If encoding is not supported returns ERROR.

 and if multibyte not enabled too....

 Thanks.

                                Karel
~

24 years ago- Minor fix to create temp table for xrefs
Philip Warner [Sat, 5 Aug 2000 10:02:28 +0000 (10:02 +0000)]
- Minor fix to create temp table for xrefs

24 years ago- Only disable triggers for the table being loaded
Philip Warner [Sat, 5 Aug 2000 09:57:46 +0000 (09:57 +0000)]
- Only disable triggers for the table being loaded
- disable triggers prior to BLOB load
- better query for loading blob xrefs
- Fixes to error handling code

24 years agoBack out to_ascii patch from Karel.
Bruce Momjian [Fri, 4 Aug 2000 20:46:47 +0000 (20:46 +0000)]
Back out to_ascii patch from Karel.

24 years agoAdd missing files from Karel, tip from Jan.
Bruce Momjian [Fri, 4 Aug 2000 20:22:52 +0000 (20:22 +0000)]
Add missing files from Karel, tip from Jan.

24 years ago to_ascii( text )
Bruce Momjian [Fri, 4 Aug 2000 15:45:12 +0000 (15:45 +0000)]
 to_ascii( text )

        - encode 'text' from database encoding to ASCII

        to_ascii('\256\341k')

 to_ascii( text, int4 )

        - encode 'text' from 'int4' encoding to ASCII

          to_ascii('\256\341k', 8)

 to_ascii( text, name )

        - encode 'text' from 'name' encoding to ASCII

          to_ascii('\256\341k', 'LATIN2')

  Now is supported LATIN1, LATIN2, WIN1250. For other character sets I
haven't good resources. Add new encoding is easy...

 If encoding is not supported returns ERROR.

 Note --- not exists total corect conversion to ASCII, this function try
        convert chars those is _probably_ interpret-able in ASCII for
        others use ' '. But for example for all Czech characters it is
        sufficient ... hmm Chinese / JAP and other complicated langs
have
        bad luck here :-(

                                                Karel

24 years agoSubclasses inherit constraints of super classes properly
Hiroshi Inoue [Fri, 4 Aug 2000 06:12:11 +0000 (06:12 +0000)]
Subclasses inherit constraints of super classes properly

24 years agoFix tuptoaster bugs induced by making bytea toastable. Durn thing was
Tom Lane [Fri, 4 Aug 2000 04:16:17 +0000 (04:16 +0000)]
Fix tuptoaster bugs induced by making bytea toastable.  Durn thing was
trying to toast tuples inserted into toast tables!  Fix is two-pronged:
first, ensure all columns of a toast table are marked attstorage='p',
and second, alter the target chunk size so that it's less than the
threshold for trying to toast a tuple.  (Code tried to do that but the
expression was wrong.)  A few cosmetic cleanups in tuptoaster too.
NOTE: initdb forced due to change in toaster chunk-size.