]> granicus.if.org Git - postgresql/log
postgresql
16 years agoAdded files containing changes between gram.y and preproc.y.
Michael Meskes [Fri, 14 Nov 2008 10:03:33 +0000 (10:03 +0000)]
Added files containing changes between gram.y and preproc.y.

16 years agoAdding script that generates preproc.y from gram.y to CVS.
Michael Meskes [Fri, 14 Nov 2008 10:01:04 +0000 (10:01 +0000)]
Adding script that generates preproc.y from gram.y to CVS.

16 years agoActually, instead of whining about how type internal might not safely store
Tom Lane [Fri, 14 Nov 2008 02:09:52 +0000 (02:09 +0000)]
Actually, instead of whining about how type internal might not safely store
a pointer, why don't we just fix that.  Every known use of "internal" really
means a pointer anyway.

16 years agoReplace the usage of heap_addheader to create pg_attribute tuples with regular
Alvaro Herrera [Fri, 14 Nov 2008 01:57:42 +0000 (01:57 +0000)]
Replace the usage of heap_addheader to create pg_attribute tuples with regular
heap_form_tuple.  Since this removes the last remaining caller of
heap_addheader, remove it.

Extracted from the column privileges patch from Stephen Frost, with further
code cleanups by me.

16 years agoImplement the basic form of UNNEST, ie unnest(anyarray) returns setof
Tom Lane [Fri, 14 Nov 2008 00:51:47 +0000 (00:51 +0000)]
Implement the basic form of UNNEST, ie unnest(anyarray) returns setof
anyelement.  This lacks the WITH ORDINALITY option, as well as the multiple
input arrays option added in the most recent SQL specs.  But it's still a
pretty useful subset of the spec's functionality, and it is enough to
allow obsoleting contrib/intagg.

16 years agoMinor code clarity improvements in array_agg functions, and add a comment
Tom Lane [Fri, 14 Nov 2008 00:12:08 +0000 (00:12 +0000)]
Minor code clarity improvements in array_agg functions, and add a comment
about how this is playing fast and loose with the type system.

16 years agoMarginal editorial improvements for array_agg patch documentation.
Tom Lane [Thu, 13 Nov 2008 23:01:09 +0000 (23:01 +0000)]
Marginal editorial improvements for array_agg patch documentation.

16 years agoSuppress leap-second-aware timezones in the output of pg_tzenumerate_next,
Tom Lane [Thu, 13 Nov 2008 20:49:38 +0000 (20:49 +0000)]
Suppress leap-second-aware timezones in the output of pg_tzenumerate_next,
and thereby in the pg_timezone_names view.  Although we allow such zones
to be used in certain limited contexts like AT TIME ZONE, we don't allow
them in SET TIME ZONE, and bug #4528 shows that they're more likely to
confuse users than do anything useful.  So hide 'em.  (Note that we don't
even generate these zones when installing our own timezone database.
But they are likely to be present when using a system-provided database.)

16 years agoPrevent synchronous scan during GIN index build, because GIN is optimized
Tom Lane [Thu, 13 Nov 2008 17:42:10 +0000 (17:42 +0000)]
Prevent synchronous scan during GIN index build, because GIN is optimized
for inserting tuples in increasing TID order.  It's not clear whether this
fully explains Ivan Sergio Borgonovo's complaint, but simple testing
confirms that a scan that doesn't start at block 0 can slow GIN build by
a factor of three or four.

Backpatch to 8.3.  Sync scan didn't exist before that.

16 years agoarray_agg aggregate function, as per SQL:2008, but without ORDER BY clause
Peter Eisentraut [Thu, 13 Nov 2008 15:59:51 +0000 (15:59 +0000)]
array_agg aggregate function, as per SQL:2008, but without ORDER BY clause

Rearrange the documentation a bit now that array_agg and xmlagg have similar
semantics and issues.

best of Robert Haas, Jeff Davis, Peter Eisentraut

16 years agoPGDLLIMPORT-ize the global variables referenced in pg_crc.h.
Tom Lane [Thu, 13 Nov 2008 14:42:28 +0000 (14:42 +0000)]
PGDLLIMPORT-ize the global variables referenced in pg_crc.h.
I think this will fix current mingw buildfarm failures for pg_trgm.

16 years agoUpdated parser file to the one generated by the latest version of parse.[awk|pl]...
Michael Meskes [Thu, 13 Nov 2008 11:54:39 +0000 (11:54 +0000)]
Updated parser file to the one generated by the latest version of parse.[awk|pl] from the latest version of gram.y
Some small corrections to test suite.

16 years agoRemoved two non-terminals:
Michael Meskes [Thu, 13 Nov 2008 11:10:06 +0000 (11:10 +0000)]
Removed two non-terminals:
- FloatOnly: only used by NumericOnly, instead put the FloatOnly production into NumericOnly
- IntegerOnly: only used by NumericOnly and one ALTER TABLE rule, replacement SignedIconst is already used in several other places

16 years agoFix libpq certificate validation for SSL connections.
Magnus Hagander [Thu, 13 Nov 2008 09:45:25 +0000 (09:45 +0000)]
Fix libpq certificate validation for SSL connections.

Add config parameter "sslverify" to control the verification. Default
is to do full verification.

Clean up some old SSL code that never really worked.

16 years agoArrange to cache the results of looking up a btree predicate proof comparison
Tom Lane [Thu, 13 Nov 2008 00:20:45 +0000 (00:20 +0000)]
Arrange to cache the results of looking up a btree predicate proof comparison
operator.  The result depends only on the two input operators and the proof
direction (imply or refute), so it's easy to cache.  This provides a very
large savings in cases such as Sergey Konoplev's long NOT-IN-list example,
where predtest spends all its time repeatedly figuring out that the same pair
of operators cannot be used to prove anything.  (But of course the O(N^2)
behavior still catches up with you eventually.)  I'm not convinced it buys
a whole lot when constraint_exclusion isn't turned on, but it's not a lot
of added code so we might as well cache all the time.

16 years agoIn predtest.c, install a limit on the number of branches we will process in
Tom Lane [Wed, 12 Nov 2008 23:08:37 +0000 (23:08 +0000)]
In predtest.c, install a limit on the number of branches we will process in
AND, OR, or equivalent clauses: if there are too many (more than 100) just
exit without proving anything.  This ensures that we don't spend O(N^2) time
trying (and most likely failing) to prove anything about very long IN lists
and similar cases.

Also, install a couple of CHECK_FOR_INTERRUPTS calls to ensure that a long
proof attempt can be interrupted.

Per gripe from Sergey Konoplev.

Back-patch the whole patch to 8.2 and just the CHECK_FOR_INTERRUPTS addition
to 8.1.  (The rest of the patch doesn't apply cleanly, and since 8.1 doesn't
show the complained-of behavior anyway, it doesn't seem necessary to work
hard on it.)

16 years agoUpdate URL to Ross Williams' CRC paper.
Alvaro Herrera [Wed, 12 Nov 2008 21:53:46 +0000 (21:53 +0000)]
Update URL to Ross Williams' CRC paper.

Per note from Devrim Gunduz

16 years agoSupport for man page links, if a man page has more than one refname.
Peter Eisentraut [Wed, 12 Nov 2008 16:01:51 +0000 (16:01 +0000)]
Support for man page links, if a man page has more than one refname.

We don't actually use this anywhere, but it might come in handy for dealing
with SELECT/WITH/TABLE.

It works with both the old and the new man page target (for some value of
"works").

16 years agoRemove unnecessary whitespace in refname elements. This confuses the
Peter Eisentraut [Wed, 12 Nov 2008 15:53:34 +0000 (15:53 +0000)]
Remove unnecessary whitespace in refname elements.  This confuses the
man page tools.

16 years agoAdd refentrytitle elements to refentry pages. Their absence confused the
Peter Eisentraut [Wed, 12 Nov 2008 15:52:44 +0000 (15:52 +0000)]
Add refentrytitle elements to refentry pages.  Their absence confused the
man page tools somewhat.

16 years agoDo not use ICONST/SCONST in rules other than Iconst/Sconst.
Michael Meskes [Wed, 12 Nov 2008 15:50:20 +0000 (15:50 +0000)]
Do not use ICONST/SCONST in rules other than Iconst/Sconst.

16 years agoSupport of multibyte encoding for pg_trgm
Teodor Sigaev [Wed, 12 Nov 2008 13:43:54 +0000 (13:43 +0000)]
Support of multibyte encoding for pg_trgm

16 years agoIf we're going to use a SQL function for this, at least make it schema-proof.
Tom Lane [Wed, 12 Nov 2008 13:38:04 +0000 (13:38 +0000)]
If we're going to use a SQL function for this, at least make it schema-proof.

16 years agoarray_length() function, and for SQL compatibility also cardinality()
Peter Eisentraut [Wed, 12 Nov 2008 13:09:28 +0000 (13:09 +0000)]
array_length() function, and for SQL compatibility also cardinality()
function as a special case.

This version still has the suspicious behavior of returning null for an
empty array (rather than zero), but this may need a wholesale revision of
empty array behavior, currently under discussion.

Jim Nasby, Robert Haas, Peter Eisentraut

16 years agoFix off-by-one error in autovacuum shmem struct sizing. This could lead to
Heikki Linnakangas [Wed, 12 Nov 2008 10:10:32 +0000 (10:10 +0000)]
Fix off-by-one error in autovacuum shmem struct sizing. This could lead to
autovacuum worker sending SIGUSR1 signal to wrong process, per Zou Yong's
report.

Backpatch to 8.3.

16 years agoClean up the ancient decision to show only two fractional-seconds digits
Tom Lane [Wed, 12 Nov 2008 01:36:20 +0000 (01:36 +0000)]
Clean up the ancient decision to show only two fractional-seconds digits
in "postgres_verbose" intervalstyle, and the equally arbitrary decision to
show at least two fractional-seconds digits in most other datetime display
styles.  This results in some minor changes in the expected regression test
outputs.

Also, coalesce a lot of repetitive code in datetime.c into subroutines,
for clarity and ease of maintenance.  In particular this roughly halves
the number of #ifdef HAVE_INT64_TIMESTAMP segments.

Ron Mayer, with some additional kibitzing from Tom Lane

16 years agoDetect and error out on inability to get proper linkage information required for...
Andrew Dunstan [Wed, 12 Nov 2008 00:00:05 +0000 (00:00 +0000)]
Detect and error out on inability to get proper linkage information required for plperl, usually due to absence of perl ExtUtils::Embed module. Backpatch as far as 8.1.

16 years agoMention the tup_fetched column in pg_stat_database.
Magnus Hagander [Tue, 11 Nov 2008 20:06:21 +0000 (20:06 +0000)]
Mention the tup_fetched column in pg_stat_database.

Greg Sabino Mullane

16 years agoEnsure that the phrels sets of PlaceHolderVars appearing in an AppendRelInfo's
Tom Lane [Tue, 11 Nov 2008 19:05:21 +0000 (19:05 +0000)]
Ensure that the phrels sets of PlaceHolderVars appearing in an AppendRelInfo's
translated_vars list get updated when pulling up an appendrel member.  It's
not clear that this really matters at present, since relatively little gets
done with the outputs of an appendrel child relation; but it probably will
come back to bite us sometime if we leave them with the wrong values.

16 years agoGet rid of adjust_appendrel_attr_needed(), which has been broken ever since
Tom Lane [Tue, 11 Nov 2008 18:13:32 +0000 (18:13 +0000)]
Get rid of adjust_appendrel_attr_needed(), which has been broken ever since
we extended the appendrel mechanism to support UNION ALL optimization.  The
reason nobody noticed was that we are not actually using attr_needed data for
appendrel children; hence it seems more reasonable to rip it out than fix it.
Back-patch to 8.2 because an Assert failure is possible in corner cases.
Per examination of an example from Jim Nasby.

In HEAD, also get rid of AppendRelInfo.col_mappings, which is quite inadequate
to represent UNION ALL situations; depend entirely on translated_vars instead.

16 years agoMake psql report "SSL connection (unknown cipher)" when libpq has set
Magnus Hagander [Tue, 11 Nov 2008 15:01:53 +0000 (15:01 +0000)]
Make psql report "SSL connection (unknown cipher)" when libpq has set
up a SSL connection, but psql is compiled without support for it.

Not a really realistic use-case, but the patch also cuts down on
the number of places with #ifdef's...

16 years agoFix sloppy omission of now-required #include's.
Tom Lane [Tue, 11 Nov 2008 14:17:02 +0000 (14:17 +0000)]
Fix sloppy omission of now-required #include's.

16 years agoChange error messages to print the physical path, like
Heikki Linnakangas [Tue, 11 Nov 2008 13:19:16 +0000 (13:19 +0000)]
Change error messages to print the physical path, like
"base/11517/3767_fsm", instead of symbolic names like "1663/11517/3767/1",
per Alvaro's suggestion. I didn't change the messages in the higher-level
index, heap and FSM routines, though, where the fork is implicit.

16 years agoReplaced manually synced preproc.y by the one created by the new script.
Michael Meskes [Tue, 11 Nov 2008 11:41:24 +0000 (11:41 +0000)]
Replaced manually synced preproc.y by the one created by the new script.
Adapted regression test files accordingly.

16 years agoAdd an explicit caution about how to use pg_do_encoding_conversion with
Tom Lane [Tue, 11 Nov 2008 03:01:20 +0000 (03:01 +0000)]
Add an explicit caution about how to use pg_do_encoding_conversion with
non-null-terminated input.  Per discussion with ITAGAKI Takahiro.

16 years agoAdd support for input and output of interval values formatted per ISO 8601;
Tom Lane [Tue, 11 Nov 2008 02:42:33 +0000 (02:42 +0000)]
Add support for input and output of interval values formatted per ISO 8601;
specifically, we can input either the "format with designators" or the
"alternative format", and we can output the former when IntervalStyle is set
to iso_8601.

Ron Mayer

16 years agoFix a case of string building.
Alvaro Herrera [Mon, 10 Nov 2008 21:49:16 +0000 (21:49 +0000)]
Fix a case of string building.

16 years agoFix bugs in sqlchar_to_unicode and unicode_to_sqlchar: both were measuring
Tom Lane [Mon, 10 Nov 2008 18:02:20 +0000 (18:02 +0000)]
Fix bugs in sqlchar_to_unicode and unicode_to_sqlchar: both were measuring
the length of a UTF8 character with pg_mblen (wrong if DB encoding isn't
UTF8), and the latter was blithely assuming that a static buffer would somehow
revert to all zeroes for each use.

16 years agoFix 'Q' format char parsing in the new to_timestamp() code. Used to crash.
Heikki Linnakangas [Mon, 10 Nov 2008 17:36:53 +0000 (17:36 +0000)]
Fix 'Q' format char parsing in the new to_timestamp() code. Used to crash.

16 years agoAdd a --locale switch to createdb, to ease the creation of databases with
Alvaro Herrera [Mon, 10 Nov 2008 16:25:41 +0000 (16:25 +0000)]
Add a --locale switch to createdb, to ease the creation of databases with
different locales.  This is just syntactical sweetener over --lc-collate and
--lc-ctype.  Per discussion.

While at it, properly document --lc-ctype and --lc-collate in SGML docs,
which apparently were forgotten (or purposefully ommited?) when they were
created.

16 years agopg_do_encoding_conversion cannot return NULL (at least not unless the input
Tom Lane [Mon, 10 Nov 2008 15:18:40 +0000 (15:18 +0000)]
pg_do_encoding_conversion cannot return NULL (at least not unless the input
is NULL), so remove some useless tests for the case.

16 years agoFix old bug in contrib/sslinfo: X509_NAME_to_text freed the BIO_s_mem buffer
Tom Lane [Mon, 10 Nov 2008 14:57:38 +0000 (14:57 +0000)]
Fix old bug in contrib/sslinfo: X509_NAME_to_text freed the BIO_s_mem buffer
it was using too soon.  In a situation where pg_do_encoding_conversion is
a no-op, this led to garbage data returned.

In HEAD, also modify the code that's ensuring null termination to make it
a tad more obvious what's happening.

16 years agoMake relhasrules and relhastriggers work like relhasindex, namely we let
Tom Lane [Mon, 10 Nov 2008 00:49:37 +0000 (00:49 +0000)]
Make relhasrules and relhastriggers work like relhasindex, namely we let
VACUUM reset them to false rather than trying to clean 'em up during DROP.

16 years agoReplace pg_class.reltriggers with relhastriggers, which is just a boolean hint
Tom Lane [Sun, 9 Nov 2008 21:24:33 +0000 (21:24 +0000)]
Replace pg_class.reltriggers with relhastriggers, which is just a boolean hint
("there might be triggers") rather than an exact count.  This is necessary
catalog infrastructure for the upcoming patch to reduce the strength of
locking needed for trigger addition/removal.  Split out and committed
separately for ease of reviewing/testing.

In passing, also get rid of the unused pg_class columns relukeys, relfkeys,
and relrefs, which haven't been maintained in many years and now have no
chance of ever being maintained (because of wishing to avoid locking).

Simon Riggs

16 years agoAdd a startup check that pg_xlog and pg_xlog/archive_status exist.
Tom Lane [Sun, 9 Nov 2008 17:51:15 +0000 (17:51 +0000)]
Add a startup check that pg_xlog and pg_xlog/archive_status exist.
If the latter doesn't exist, automatically recreate it.  (We don't do
this for pg_xlog, though, per discussion.)

Jonah Harris

16 years agoAdd some documentation about handling of fractions in interval input.
Tom Lane [Sun, 9 Nov 2008 17:09:48 +0000 (17:09 +0000)]
Add some documentation about handling of fractions in interval input.
(It's always worked like this, but we never documented it before.)

16 years agoAdd a new GUC variable called "IntervalStyle" that decouples interval output
Tom Lane [Sun, 9 Nov 2008 00:28:35 +0000 (00:28 +0000)]
Add a new GUC variable called "IntervalStyle" that decouples interval output
from DateStyle, and create a new interval style that produces output matching
the SQL standard (at least for interval values that fall within the standard's
restrictions).  IntervalStyle is also used to resolve the conflict between the
standard and traditional Postgres rules for interpreting negative interval
input.

Ron Mayer

16 years agoFix recently added code for SQL years-months interval syntax so that
Tom Lane [Sat, 8 Nov 2008 20:51:49 +0000 (20:51 +0000)]
Fix recently added code for SQL years-months interval syntax so that
it behaves correctly for a leading minus sign, zero year value, and
nonzero month value.  Per discussion with Ron Mayer.

16 years agoAdd some more citext test cases, per David Wheeler. Also remove the
Tom Lane [Fri, 7 Nov 2008 23:17:30 +0000 (23:17 +0000)]
Add some more citext test cases, per David Wheeler.  Also remove the
citext-to-and-from-xml tests, since those caused variation between
installations with or without libxml without really proving much.  Instead
repurpose citext_1.out as the expected results in glibc en_US (and probably
other) locales.

16 years agoImprove documentation of pg_typeof, per gripe from David Wheeler.
Tom Lane [Fri, 7 Nov 2008 22:54:41 +0000 (22:54 +0000)]
Improve documentation of pg_typeof, per gripe from David Wheeler.

16 years agoImplement ALTER DATABASE SET TABLESPACE to move a whole database (or at least
Tom Lane [Fri, 7 Nov 2008 18:25:07 +0000 (18:25 +0000)]
Implement ALTER DATABASE SET TABLESPACE to move a whole database (or at least
as much of it as lives in its default tablespace) to a new tablespace.

Guillaume Lelarge, with some help from Bernd Helmle and Tom Lane

16 years agoImprove bulk-insert performance by keeping the current target buffer pinned
Tom Lane [Thu, 6 Nov 2008 20:51:15 +0000 (20:51 +0000)]
Improve bulk-insert performance by keeping the current target buffer pinned
(but not locked, as that would risk deadlocks).  Also, make it work in a small
ring of buffers to avoid having bulk inserts trash the whole buffer arena.

Robert Haas, after an idea of Simon Riggs'.

16 years agoImprove psql's \dC command to take a pattern parameter. Casts are shown
Tom Lane [Thu, 6 Nov 2008 15:18:36 +0000 (15:18 +0000)]
Improve psql's \dC command to take a pattern parameter.  Casts are shown
if their source or target types match the pattern (using the same definition
of "match" as \dT does).  Per recent discussion.

16 years agoThe logic in systable_beginscan to translate heap attribute numbers to
Heikki Linnakangas [Thu, 6 Nov 2008 13:07:08 +0000 (13:07 +0000)]
The logic in systable_beginscan to translate heap attribute numbers to
index column numbers needs to handle the case where you have more than
one scankey on the same index column. toast_fetch_datum_slice() needs it.

16 years agoThis maneuver really requires a comment ...
Tom Lane [Wed, 5 Nov 2008 20:17:18 +0000 (20:17 +0000)]
This maneuver really requires a comment ...

16 years agochange fix for suppress_redundant_updates_trigger() where relation has Oids, to only...
Andrew Dunstan [Wed, 5 Nov 2008 19:15:15 +0000 (19:15 +0000)]
change fix for suppress_redundant_updates_trigger() where relation has Oids, to only apply if present Oid is invalid, per second thought from TGL

16 years agofix suppress_redundant_updates_trigger() where relation has Oids, per gripe from...
Andrew Dunstan [Wed, 5 Nov 2008 18:49:28 +0000 (18:49 +0000)]
fix suppress_redundant_updates_trigger() where relation has Oids, per gripe from KaiGai Kohei

16 years agoA few additional test cases for array functionality
Peter Eisentraut [Wed, 5 Nov 2008 12:27:09 +0000 (12:27 +0000)]
A few additional test cases for array functionality

16 years agoRename several aliases for PLpgSQL_datum.dno to also be called dno.
Tom Lane [Wed, 5 Nov 2008 00:07:54 +0000 (00:07 +0000)]
Rename several aliases for PLpgSQL_datum.dno to also be called dno.
Hopefully this will forestall future confusion about their roles.

Jonah Harris

16 years agoDocument that SSL is only possible on tcp/ip connections in the
Bruce Momjian [Tue, 4 Nov 2008 22:40:40 +0000 (22:40 +0000)]
Document that SSL is only possible on tcp/ip connections in the
postgresql.conf 'ssl' section.

16 years agoDocument that 'sslmode' is ignored for Unix domain socket communication;
Bruce Momjian [Tue, 4 Nov 2008 22:36:07 +0000 (22:36 +0000)]
Document that 'sslmode' is ignored for Unix domain socket communication;
backpatch to 8.3.X.

16 years agoRevert unwanted patch, per Tom.
Alvaro Herrera [Tue, 4 Nov 2008 21:00:15 +0000 (21:00 +0000)]
Revert unwanted patch, per Tom.

16 years agoRemove unused rfno from PLpgSQL_recfield
Alvaro Herrera [Tue, 4 Nov 2008 20:58:46 +0000 (20:58 +0000)]
Remove unused rfno from PLpgSQL_recfield

Jonah Harris

16 years agoFix bug introduced in recent patch to make plpython cope with OUT arguments:
Tom Lane [Tue, 4 Nov 2008 15:16:48 +0000 (15:16 +0000)]
Fix bug introduced in recent patch to make plpython cope with OUT arguments:
the proc->argnames array has to be initialized to zero immediately on creation,
since the error recovery path will try to free its elements.

16 years agoExperimental new support for building man pages via docbook2x, an XSL-based
Peter Eisentraut [Tue, 4 Nov 2008 14:58:22 +0000 (14:58 +0000)]
Experimental new support for building man pages via docbook2x, an XSL-based
tool chain.  With some polishing, this might help us get rid of our ancient
and crufty man page build mechanism.

16 years agoADD array_ndims function
Peter Eisentraut [Tue, 4 Nov 2008 14:49:12 +0000 (14:49 +0000)]
ADD array_ndims function

Author: Robert Haas <robertmhaas@gmail.com>

16 years agoFix compiler warning about uninitialized variable
Peter Eisentraut [Tue, 4 Nov 2008 11:04:06 +0000 (11:04 +0000)]
Fix compiler warning about uninitialized variable

16 years agoAdd missing colon to docs.
Bruce Momjian [Tue, 4 Nov 2008 04:18:50 +0000 (04:18 +0000)]
Add missing colon to docs.

16 years agoRemove tabs from SGML file.
Bruce Momjian [Tue, 4 Nov 2008 00:59:45 +0000 (00:59 +0000)]
Remove tabs from SGML file.

16 years agoDisallow LOCK TABLE outside a transaction block (or function), since this case
Tom Lane [Tue, 4 Nov 2008 00:57:19 +0000 (00:57 +0000)]
Disallow LOCK TABLE outside a transaction block (or function), since this case
almost certainly represents user error.  Per a gripe from Sebastian Böhm
and subsequent discussion.

16 years agoFix compiler warnings (including a seriously bogus elog call); minor
Tom Lane [Tue, 4 Nov 2008 00:29:39 +0000 (00:29 +0000)]
Fix compiler warnings (including a seriously bogus elog call); minor
code beautification.

16 years agoUse bool for a boolean flag.
Tom Lane [Mon, 3 Nov 2008 23:49:07 +0000 (23:49 +0000)]
Use bool for a boolean flag.

16 years agoAllow uuid_in() to parse a wider variety of variant input formats for the UUID
Peter Eisentraut [Mon, 3 Nov 2008 22:14:40 +0000 (22:14 +0000)]
Allow uuid_in() to parse a wider variety of variant input formats for the UUID
data type.  This patch takes the approach of allowing an optional hyphen after
each group of four hex digits.

Author: Robert Haas <robertmhaas@gmail.com>

16 years agoDept of second thoughts: seems it'd be safer if pg_typeof is marked
Tom Lane [Mon, 3 Nov 2008 21:09:17 +0000 (21:09 +0000)]
Dept of second thoughts: seems it'd be safer if pg_typeof is marked
stable not immutable, since it depends on system catalog contents.

16 years agoClean up the messy semantics (not to mention inefficiency) of PageGetTempPage
Tom Lane [Mon, 3 Nov 2008 20:47:49 +0000 (20:47 +0000)]
Clean up the messy semantics (not to mention inefficiency) of PageGetTempPage
by splitting it into three functions with better-defined behaviors.

Zdenek Kotala

16 years agosuppress_redundant_updates_trigger function.
Andrew Dunstan [Mon, 3 Nov 2008 20:17:21 +0000 (20:17 +0000)]
suppress_redundant_updates_trigger function.

16 years agoFix silly typo in previous commit.
Alvaro Herrera [Mon, 3 Nov 2008 19:26:07 +0000 (19:26 +0000)]
Fix silly typo in previous commit.

16 years agoFix TransactionIdSetStatusBit so that it doesn't try to change a transaction
Alvaro Herrera [Mon, 3 Nov 2008 19:24:03 +0000 (19:24 +0000)]
Fix TransactionIdSetStatusBit so that it doesn't try to change a transaction
from COMMITTED to SUBCOMMITTED during recovery.  This wasn't previously
possible, but it is now due to the recent changes on clog commit protocol for
subtransactions.

Simon Riggs

16 years agoFix two error-recovery bugs in describeOneTableDetails(), and make the code
Tom Lane [Mon, 3 Nov 2008 19:08:56 +0000 (19:08 +0000)]
Fix two error-recovery bugs in describeOneTableDetails(), and make the code
to dump sequence values cope with sequences outside the search path and/or
having names that need quoting.  No back-patch needed because these are new
problems in 8.4.

Kris Jurka  (also a little bit of code beautification by tgl)

16 years agoReduce the acceptable staleness of pgstat data for autovacuum, per the
Alvaro Herrera [Mon, 3 Nov 2008 19:03:41 +0000 (19:03 +0000)]
Reduce the acceptable staleness of pgstat data for autovacuum, per the
longstanding note in the source that this patch removes.

16 years agoAdd pg_typeof() function.
Tom Lane [Mon, 3 Nov 2008 17:51:13 +0000 (17:51 +0000)]
Add pg_typeof() function.

Brendan Jurd

16 years agoSmall shell syntax improvement.
Bruce Momjian [Mon, 3 Nov 2008 15:56:47 +0000 (15:56 +0000)]
Small shell syntax improvement.

16 years agoUpdate URL to Docbook DSSSL stylesheets, per Gabriele Bartolini.
Alvaro Herrera [Mon, 3 Nov 2008 15:39:38 +0000 (15:39 +0000)]
Update URL to Docbook DSSSL stylesheets, per Gabriele Bartolini.

16 years agoFix mistakes in comment headers
Alvaro Herrera [Mon, 3 Nov 2008 15:10:17 +0000 (15:10 +0000)]
Fix mistakes in comment headers

16 years agoFix incorrect comment in SSL code
Magnus Hagander [Mon, 3 Nov 2008 14:18:57 +0000 (14:18 +0000)]
Fix incorrect comment in SSL code

16 years agoChange the pgstat logic so that the stats collector writes the stats file only
Tom Lane [Mon, 3 Nov 2008 01:17:08 +0000 (01:17 +0000)]
Change the pgstat logic so that the stats collector writes the stats file only
upon requests from backends, rather than on a fixed 500msec cycle.  (There's
still throttling logic to ensure it writes no more often than once per
500msec, though.)  This should result in a significant reduction in stats file
write traffic in typical scenarios where the stats are demanded only
infrequently.

This approach also means that the former difficulty with changing
stats_temp_directory on-the-fly has gone away, so remove the caution about
that as well as the thrashing we did to minimize the trouble window.

In passing, also fix pgstat_report_stat() so that we will send a stats
message if we have function call stats but not table stats to report;
this fixes a bug in the recent patch to support function-call stats.

Martin Pihlak

16 years agoRemove the last vestiges of the MAKE_PTR/MAKE_OFFSET mechanism. We haven't
Tom Lane [Sun, 2 Nov 2008 21:24:52 +0000 (21:24 +0000)]
Remove the last vestiges of the MAKE_PTR/MAKE_OFFSET mechanism.  We haven't
allowed different processes to have different addresses for the shmem segment
in quite a long time, but there were still a few places left that used the
old coding convention.  Clean them up to reduce confusion and improve the
compiler's ability to detect pointer type mismatches.

Kris Jurka

16 years agoRemove all uses of the deprecated functions heap_formtuple, heap_modifytuple,
Tom Lane [Sun, 2 Nov 2008 01:45:28 +0000 (01:45 +0000)]
Remove all uses of the deprecated functions heap_formtuple, heap_modifytuple,
and heap_deformtuple in favor of the newer functions heap_form_tuple et al
(which do the same things but use bool control flags instead of arbitrary
char values).  Eliminate the former duplicate coding of these functions,
reducing the deprecated functions to mere wrappers around the newer ones.
We can't get rid of them entirely because add-on modules probably still
contain many instances of the old coding style.

Kris Jurka

16 years agoMove from strcmp to strncmp to be more tolerant for changes to the parser.
Michael Meskes [Sat, 1 Nov 2008 19:53:35 +0000 (19:53 +0000)]
Move from strcmp to strncmp to be more tolerant for changes to the parser.

16 years agoUse string component in index structure.
Michael Meskes [Sat, 1 Nov 2008 12:42:14 +0000 (12:42 +0000)]
Use string component in index structure.

16 years agoDo not eat memory even in case of an out-of-memory error.
Michael Meskes [Sat, 1 Nov 2008 08:55:21 +0000 (08:55 +0000)]
Do not eat memory even in case of an out-of-memory error.

16 years agoSimplify ExecutorRun's API and save some trivial number of cycles by having
Tom Lane [Fri, 31 Oct 2008 21:07:55 +0000 (21:07 +0000)]
Simplify ExecutorRun's API and save some trivial number of cycles by having
it just return void instead of sometimes returning a TupleTableSlot.  SQL
functions don't need that anymore, and noplace else does either.  Eliminating
the return value also means one less hassle for the ExecutorRun hook functions
that will be supported beginning in 8.4.

16 years agoUpdate FSM on WAL replay. This is a bit limited; the FSM is only updated
Heikki Linnakangas [Fri, 31 Oct 2008 19:40:27 +0000 (19:40 +0000)]
Update FSM on WAL replay. This is a bit limited; the FSM is only updated
on non-full-page-image WAL records, and quite arbitrarily, only if there's
less than 20% free space on the page after the insert/update (not on HOT
updates, though). The 20% cutoff should avoid most of the overhead, when
replaying a bulk insertion, for example, while ensuring that pages that
are full are marked as full in the FSM.

This is mostly to avoid the nasty worst case scenario, where you replay
from a PITR archive, and the FSM information in the base backup is really
out of date. If there was a lot of pages that the outdated FSM claims to
have free space, but don't actually have any, the first unlucky inserter
after the recovery would traverse through all those pages, just to find
out that they're full. We didn't have this problem with the old FSM
implementation, because we simply threw the FSM information away on a
non-clean shutdown.

16 years agoAllow SQL-language functions to return the output of an INSERT/UPDATE/DELETE
Tom Lane [Fri, 31 Oct 2008 19:37:56 +0000 (19:37 +0000)]
Allow SQL-language functions to return the output of an INSERT/UPDATE/DELETE
RETURNING clause, not just a SELECT as formerly.

A side effect of this patch is that when a set-returning SQL function is used
in a FROM clause, performance is improved because the output is collected into
a tuplestore within the function, rather than using the less efficient
value-per-call mechanism.

16 years agoAdded missing ';'
Michael Meskes [Fri, 31 Oct 2008 16:36:13 +0000 (16:36 +0000)]
Added missing ';'

16 years agoUnite ReadBufferWithFork, ReadBufferWithStrategy, and ZeroOrReadBuffer
Heikki Linnakangas [Fri, 31 Oct 2008 15:05:00 +0000 (15:05 +0000)]
Unite ReadBufferWithFork, ReadBufferWithStrategy, and ZeroOrReadBuffer
functions into one ReadBufferExtended function, that takes the strategy
and mode as argument. There's three modes, RBM_NORMAL which is the default
used by plain ReadBuffer(), RBM_ZERO, which replaces ZeroOrReadBuffer, and
a new mode RBM_ZERO_ON_ERROR, which allows callers to read corrupt pages
without throwing an error. The FSM needs the new mode to recover from
corrupt pages, which could happend if we crash after extending an FSM file,
and the new page is "torn".

Add fork number to some error messages in bufmgr.c, that still lacked it.

16 years agoThe conversion rule from postgres.sgml to postgres.xml didn't work with
Peter Eisentraut [Fri, 31 Oct 2008 14:35:30 +0000 (14:35 +0000)]
The conversion rule from postgres.sgml to postgres.xml didn't work with
BSD sed.  So write it in Perl, which is more portable and a bit faster, too.
We already use Perl for standard documentation builds, so this imposes no
additional requirement.

16 years agoAdd test case for CREATE CAST.
Heikki Linnakangas [Fri, 31 Oct 2008 09:17:17 +0000 (09:17 +0000)]
Add test case for CREATE CAST.

16 years agoAdd support for user-defined I/O conversion casts.
Heikki Linnakangas [Fri, 31 Oct 2008 08:39:22 +0000 (08:39 +0000)]
Add support for user-defined I/O conversion casts.

16 years agoMessage improvement
Peter Eisentraut [Fri, 31 Oct 2008 07:15:11 +0000 (07:15 +0000)]
Message improvement
(also backported to 8.3)