OSDN Git Service

pg-rex/syncrep.git
13 years agoDocument that server single-user mode does not do checkpoints or other
Bruce Momjian [Thu, 10 Mar 2011 01:19:59 +0000 (20:19 -0500)]
Document that server single-user mode does not do checkpoints or other
background processing.

13 years agoAdjust the permissions required for COMMENT ON ROLE.
Tom Lane [Wed, 9 Mar 2011 16:28:20 +0000 (11:28 -0500)]
Adjust the permissions required for COMMENT ON ROLE.

Formerly, any member of a role could change the role's comment, as of
course could superusers; but holders of CREATEROLE privilege could not,
unless they were also members.  This led to the odd situation that a
CREATEROLE holder could create a role but then could not comment on it.
It also seems a bit dubious to let an unprivileged user change his own
comment, let alone those of group roles he belongs to.  So, change the
rule to be "you must be superuser to comment on a superuser role, or
hold CREATEROLE to comment on non-superuser roles".  This is the same
as the privilege check for creating/dropping roles, and thus fits much
better with the rule for other object types, namely that only the owner
of an object can comment on it.

In passing, clean up the documentation for COMMENT a little bit.

Per complaint from Owen Jacobson and subsequent discussion.

13 years agoRemove '=' from initdb switch syntax.
Bruce Momjian [Wed, 9 Mar 2011 14:48:05 +0000 (09:48 -0500)]
Remove '=' from initdb switch syntax.

13 years agoImprove wording of initdb and pg_controldata manual pages.
Bruce Momjian [Wed, 9 Mar 2011 14:18:44 +0000 (09:18 -0500)]
Improve wording of initdb and pg_controldata manual pages.

gabrielle <gorthx@gmail.com>

13 years agoRemove 's' from recovery_target_timeline's' from the release note.
Itagaki Takahiro [Wed, 9 Mar 2011 11:00:11 +0000 (20:00 +0900)]
Remove 's' from recovery_target_timeline's' from the release note.

13 years agosynchronous_standby_names is a string parameter.
Itagaki Takahiro [Wed, 9 Mar 2011 10:49:16 +0000 (19:49 +0900)]
synchronous_standby_names is a string parameter.

13 years agoMake alpha release notes more consistent as regards periods.
Robert Haas [Wed, 9 Mar 2011 05:06:02 +0000 (00:06 -0500)]
Make alpha release notes more consistent as regards periods.

13 years agoUpdate alpha release notes for latest commits.
Robert Haas [Wed, 9 Mar 2011 04:59:52 +0000 (23:59 -0500)]
Update alpha release notes for latest commits.

13 years agoA bit more editing for collation documentation.
Tom Lane [Wed, 9 Mar 2011 03:50:15 +0000 (22:50 -0500)]
A bit more editing for collation documentation.

13 years agoFix file descriptor leaks in pg_upgrade in failure code paths.
Bruce Momjian [Wed, 9 Mar 2011 02:35:42 +0000 (21:35 -0500)]
Fix file descriptor leaks in pg_upgrade in failure code paths.

13 years agoCreate "replication and recovery" section in alpha release notes.
Robert Haas [Wed, 9 Mar 2011 01:55:29 +0000 (20:55 -0500)]
Create "replication and recovery" section in alpha release notes.

13 years agoAssorted editing for collation documentation.
Tom Lane [Tue, 8 Mar 2011 22:10:34 +0000 (17:10 -0500)]
Assorted editing for collation documentation.

I made a pass over this to familiarize myself with the feature, and found
some things that could be improved.

13 years agoFix parallel make when running make install before make all
Peter Eisentraut [Tue, 8 Mar 2011 21:49:59 +0000 (23:49 +0200)]
Fix parallel make when running make install before make all

In addition to the

all-foo-recurse: all-bar-recurse

dependencies that constraint the order of the rule execution, we need

install-foo-recurse: install-bar-recurse

dependencies in case one runs make install without a make all first,
as some people apparently do.

13 years agoAdd missing keywords to gram.y's unreserved_keywords list.
Tom Lane [Tue, 8 Mar 2011 21:43:02 +0000 (16:43 -0500)]
Add missing keywords to gram.y's unreserved_keywords list.

We really need an automated check for this ... and did VALIDATE really
need to become a keyword at all, rather than picking some other syntax
using existing keywords?

13 years agoIgnore files built by coverage builds
Peter Eisentraut [Tue, 8 Mar 2011 20:10:00 +0000 (22:10 +0200)]
Ignore files built by coverage builds

13 years agoFix overly strict assertion in SummarizeOldestCommittedSxact(). There's a
Heikki Linnakangas [Tue, 8 Mar 2011 19:01:29 +0000 (21:01 +0200)]
Fix overly strict assertion in SummarizeOldestCommittedSxact(). There's a
race condition where SummarizeOldestCommittedSxact() is called even though
another backend already cleared out all finished sxact entries. That's OK,
RegisterSerializableTransactionInt() can just retry getting a news xact
slot from the available-list when that happens.

Reported by YAMAMOTO Takashi, bug #5918.

13 years agoDon't throw a warning if vacuum sees PD_ALL_VISIBLE flag set on a page that
Heikki Linnakangas [Tue, 8 Mar 2011 18:13:52 +0000 (20:13 +0200)]
Don't throw a warning if vacuum sees PD_ALL_VISIBLE flag set on a page that
contains newly-inserted tuples that according to our OldestXmin are not
yet visible to everyone. The value returned by GetOldestXmin() is conservative,
and it can move backwards on repeated calls, so if we see that contradiction
between the PD_ALL_VISIBLE flag and status of tuples on the page, we have to
assume it's because an earlier vacuum calculated a higher OldestXmin value,
and all the tuples really are visible to everyone.

We have received several reports of this bug, with the "PD_ALL_VISIBLE flag
was incorrectly set in relation ..." warning appearing in logs. We were
finally able to hunt it down with David Gould's help to run extra diagnostics
in an environment where this happened frequently.

Also reword the warning, per Robert Haas' suggestion, to not imply that the
PD_ALL_VISIBLE flag is necessarily at fault, as it might also be a symptom
of corruption on a tuple header.

Backpatch to 8.4, where the PD_ALL_VISIBLE flag was introduced.

13 years agoAdjust CHAR() doc mention of pattern matching issues for trailing
Bruce Momjian [Tue, 8 Mar 2011 17:54:00 +0000 (12:54 -0500)]
Adjust CHAR() doc mention of pattern matching issues for trailing
spaces.

13 years agoDocument that char() ignores spaces in non-pattern comparisons, not in
Bruce Momjian [Tue, 8 Mar 2011 16:03:02 +0000 (11:03 -0500)]
Document that char() ignores spaces in non-pattern comparisons, not in
pattern comparisons such as LIKE and regex.

13 years agoAdded new version of ecpg's parser test script which was written by Andy Colson ...
Michael Meskes [Tue, 8 Mar 2011 10:27:32 +0000 (11:27 +0100)]
Added new version of ecpg's parser test script which was written by Andy Colson <andy@squeakycode.net>.

13 years agoTruncate predicate lock manager's SLRU lazily at checkpoint. That's safer
Heikki Linnakangas [Tue, 8 Mar 2011 10:07:29 +0000 (12:07 +0200)]
Truncate predicate lock manager's SLRU lazily at checkpoint. That's safer
than doing it aggressively whenever the tail-XID pointer is advanced, because
this way we don't need to do it while holding SerializableXactHashLock.

This also fixes bug #5915 spotted by YAMAMOTO Takashi, and removes an
obsolete comment spotted by Kevin Grittner.

13 years agoFix behavior when raising plpy.Fatal()
Peter Eisentraut [Mon, 7 Mar 2011 21:01:54 +0000 (23:01 +0200)]
Fix behavior when raising plpy.Fatal()

It should cause a elog(FATAL) error, and it fact it was simply causing
a elog(ERROR).

Jan Urbański

13 years agoReport Python errors from iterators with PLy_elog
Peter Eisentraut [Mon, 7 Mar 2011 20:53:32 +0000 (22:53 +0200)]
Report Python errors from iterators with PLy_elog

This improves reporting, as the error string now includes the actual
Python exception. As a side effect, this no longer sets the errcode to
ERRCODE_DATA_EXCEPTION, which might be considered a feature, as it's
not documented and not clear why iterator errors should be treated
differently.

Jan Urbański

13 years agoImprove description of inquiry functions that accept regclass.
Tom Lane [Mon, 7 Mar 2011 21:21:26 +0000 (16:21 -0500)]
Improve description of inquiry functions that accept regclass.

Per a suggestion from Thom Brown, though this is not his proposed patch.

13 years agoMinor copy-editing in CREATE TRIGGER reference page.
Tom Lane [Mon, 7 Mar 2011 21:00:36 +0000 (16:00 -0500)]
Minor copy-editing in CREATE TRIGGER reference page.

Per suggestions from Thom Brown and Robert Haas.

13 years agoIf recovery_target_timeline is set to 'latest' and standby mode is enabled,
Heikki Linnakangas [Mon, 7 Mar 2011 19:02:40 +0000 (21:02 +0200)]
If recovery_target_timeline is set to 'latest' and standby mode is enabled,
periodically rescan the archive for new timelines, while waiting for new WAL
segments to arrive. This allows you to set up a standby server that follows
the TLI change if another standby server is promoted to master. Before this,
you had to restart the standby server to make it notice the new timeline.

This patch only scans the archive for TLI changes, it won't follow a TLI
change in streaming replication. That is much needed too, but it would be a
much bigger patch than I dare to sneak in this late in the release cycle.

There was discussion on improving the sanity checking of the WAL segments so
that the system would notice more reliably if the new timeline isn't an
ancestor of the current one, but that is not included in this patch.

Reviewed by Fujii Masao.

13 years agoReword alpha release note item on SSI.
Robert Haas [Mon, 7 Mar 2011 18:57:06 +0000 (13:57 -0500)]
Reword alpha release note item on SSI.

Per Josh Berkus; some additional explanatory text by me.

13 years agoSynchronous replication doc corrections.
Robert Haas [Mon, 7 Mar 2011 16:59:58 +0000 (11:59 -0500)]
Synchronous replication doc corrections.

Thom Brown

13 years agoZero out vacuum_count and related counters in pgstat_recv_tabstat().
Tom Lane [Mon, 7 Mar 2011 16:17:06 +0000 (11:17 -0500)]
Zero out vacuum_count and related counters in pgstat_recv_tabstat().

This fixes an oversight in commit 946045f04d11d246a834b917a2b8bc6e4f884a37
of 2010-08-21, as reported by Itagaki Takahiro.  Also a couple of minor
cosmetic adjustments.

13 years agoDocument the DEFERRABLE option in SET TRANSACTION command.
Heikki Linnakangas [Mon, 7 Mar 2011 08:42:49 +0000 (10:42 +0200)]
Document the DEFERRABLE option in SET TRANSACTION command.

Kevin Grittner

13 years agoBegin error message with lower-case letter.
Heikki Linnakangas [Mon, 7 Mar 2011 08:41:13 +0000 (10:41 +0200)]
Begin error message with lower-case letter.

13 years agoSilence compiler warning about undefined function when compiling without
Heikki Linnakangas [Mon, 7 Mar 2011 07:56:53 +0000 (09:56 +0200)]
Silence compiler warning about undefined function when compiling without
assertions.

13 years agoTighten pg_upgrade check for pre-8.4 toast table name matching.
Bruce Momjian [Mon, 7 Mar 2011 02:57:02 +0000 (21:57 -0500)]
Tighten pg_upgrade check for pre-8.4 toast table name matching.

13 years agoSuppress some "variable might be clobbered by longjmp" warnings.
Tom Lane [Mon, 7 Mar 2011 02:15:48 +0000 (21:15 -0500)]
Suppress some "variable might be clobbered by longjmp" warnings.

Seen with an older gcc version.  I'm not sure these represent any real
risk factor, but still a bit scary.  Anyway we have lots of other
volatile-marked variables in this code, so a couple more won't hurt.

13 years agoFix a couple more missing "static" markers.
Tom Lane [Mon, 7 Mar 2011 01:14:01 +0000 (20:14 -0500)]
Fix a couple more missing "static" markers.

13 years agoAdd missing "static" marker to internal_ping().
Tom Lane [Mon, 7 Mar 2011 01:04:29 +0000 (20:04 -0500)]
Add missing "static" marker to internal_ping().

Per testing with a compiler that doesn't like that.

13 years agoDynamic array required within pg_stat_replication.
Simon Riggs [Mon, 7 Mar 2011 00:26:30 +0000 (00:26 +0000)]
Dynamic array required within pg_stat_replication.

13 years agoCatversion increment for pg_stat_replication changes for syncrep
Simon Riggs [Sun, 6 Mar 2011 23:44:44 +0000 (23:44 +0000)]
Catversion increment for pg_stat_replication changes for syncrep

13 years agoAdd new files for syncrep missed in previous commit
Simon Riggs [Sun, 6 Mar 2011 23:39:14 +0000 (23:39 +0000)]
Add new files for syncrep missed in previous commit

13 years agoFix pg_dump's dump order for collations versus extensions.
Tom Lane [Sun, 6 Mar 2011 23:26:18 +0000 (18:26 -0500)]
Fix pg_dump's dump order for collations versus extensions.

Mixing them together alphabetically won't be nice.  Per my gripe of
2011-02-12.

13 years agoEfficient transaction-controlled synchronous replication.
Simon Riggs [Sun, 6 Mar 2011 22:49:16 +0000 (22:49 +0000)]
Efficient transaction-controlled synchronous replication.
If a standby is broadcasting reply messages and we have named
one or more standbys in synchronous_standby_names then allow
users who set synchronous_replication to wait for commit, which
then provides strict data integrity guarantees. Design avoids
sending and receiving transaction state information so minimises
bookkeeping overheads. We synchronize with the highest priority
standby that is connected and ready to synchronize. Other standbys
can be defined to takeover in case of standby failure.

This version has very strict behaviour; more relaxed options
may be added at a later date.

Simon Riggs and Fujii Masao, with reviews by Yeb Havinga, Jaime
Casanova, Heikki Linnakangas and Robert Haas, plus the assistance
of many other design reviewers.

13 years agoFix incorrect access to pg_index.indcollation.
Tom Lane [Sun, 6 Mar 2011 17:10:50 +0000 (12:10 -0500)]
Fix incorrect access to pg_index.indcollation.

Since this field is after a variable-length field, it can't simply be
accessed via the C struct for pg_index.  Fortunately, the relcache already
did the dirty work of pulling the information out to where it can be
accessed easily, so this is a one-line fix.

Andres Freund

13 years agoImprove pg_upgrade relation name check logic for pre-8.4 servers.
Bruce Momjian [Sun, 6 Mar 2011 11:34:58 +0000 (06:34 -0500)]
Improve pg_upgrade relation name check logic for pre-8.4 servers.

13 years agoUpdate new pg_upgrade comment about pre-8.4 TOAST tables.
Bruce Momjian [Sun, 6 Mar 2011 03:09:35 +0000 (22:09 -0500)]
Update new pg_upgrade comment about pre-8.4 TOAST tables.

13 years agoRestructure pg_upgrade checks because pre-8.4 Postgres did not rename
Bruce Momjian [Sun, 6 Mar 2011 02:12:21 +0000 (21:12 -0500)]
Restructure pg_upgrade checks because pre-8.4 Postgres did not rename
toast file names to match the new relfilenode.

13 years agoFix pg_upgrade to print the proper database name for file transfer
Bruce Momjian [Sun, 6 Mar 2011 01:18:31 +0000 (20:18 -0500)]
Fix pg_upgrade to print the proper database name for file transfer
failures.

13 years agoPrint clearer failure message when pg_upgrade fails due to a fatal
Bruce Momjian [Sun, 6 Mar 2011 00:32:53 +0000 (19:32 -0500)]
Print clearer failure message when pg_upgrade fails due to a fatal
error.

13 years agoFix parallel gmake for extension directory addition in PL languages.
Bruce Momjian [Sat, 5 Mar 2011 23:32:06 +0000 (18:32 -0500)]
Fix parallel gmake for extension directory addition in PL languages.

13 years agoAdd PL extension files to MSVC Install procedure.
Andrew Dunstan [Sat, 5 Mar 2011 21:21:37 +0000 (16:21 -0500)]
Add PL extension files to MSVC Install procedure.

13 years agoAdjust documentation about pg_pltemplate to reflect latest thinking.
Tom Lane [Sat, 5 Mar 2011 20:34:10 +0000 (15:34 -0500)]
Adjust documentation about pg_pltemplate to reflect latest thinking.

It's more likely that pg_pltemplate will go away in the future than
that we'll add additional specialized infrastructure for it.

13 years agoMake plpythonu language use plpython2 shared library directly.
Tom Lane [Sat, 5 Mar 2011 20:13:15 +0000 (15:13 -0500)]
Make plpythonu language use plpython2 shared library directly.

The original scheme for this was to symlink plpython.$DLSUFFIX to
plpython2.$DLSUFFIX, but that doesn't work on Windows, and only
accidentally failed to fail because of the way that CREATE LANGUAGE created
or didn't create new C functions.  My changes of yesterday exposed the
weakness of that approach.  To fix, get rid of the symlink and make
pg_pltemplate show what's really going on.

13 years agoConvert createlang/droplang to use CREATE/DROP EXTENSION.
Tom Lane [Sat, 5 Mar 2011 19:03:06 +0000 (14:03 -0500)]
Convert createlang/droplang to use CREATE/DROP EXTENSION.

In createlang this is a one-line change.  In droplang there's a whole
lot of cruft that can be discarded since the extension mechanism now
manages removal of the language's support functions.

Also, add deprecation notices to these two programs' reference pages,
since per discussion we may toss them overboard altogether in a release
or two.

13 years agoRemove one copy of duplicated alpha4 release note.
Robert Haas [Sat, 5 Mar 2011 18:00:54 +0000 (13:00 -0500)]
Remove one copy of duplicated alpha4 release note.

Noted by Andy Colson

13 years agoUpdate of SQL feature conformance
Peter Eisentraut [Sat, 5 Mar 2011 14:50:03 +0000 (16:50 +0200)]
Update of SQL feature conformance

13 years agoAdd missing word.
Robert Haas [Sat, 5 Mar 2011 14:53:05 +0000 (09:53 -0500)]
Add missing word.

13 years agoFirst cut at 9.1alpha4 release notes.
Robert Haas [Sat, 5 Mar 2011 14:36:19 +0000 (09:36 -0500)]
First cut at 9.1alpha4 release notes.

13 years agoRemove emphasis from 9.1alpha3 items.
Robert Haas [Sat, 5 Mar 2011 12:36:35 +0000 (07:36 -0500)]
Remove emphasis from 9.1alpha3 items.

In preparation for 9.1alpha4 release notes, where only the 9.1alpha4
features will be emphasized.

13 years agoUpdate documentation to reflect that standard PLs are now extensions.
Tom Lane [Sat, 5 Mar 2011 06:08:38 +0000 (01:08 -0500)]
Update documentation to reflect that standard PLs are now extensions.

Recommend use of CREATE EXTENSION rather than plain CREATE LANGUAGE
where relevant.  Encourage PL authors to provide extension wrappers
for their PLs.

13 years agoCreate extension infrastructure for the core procedural languages.
Tom Lane [Sat, 5 Mar 2011 02:51:14 +0000 (21:51 -0500)]
Create extension infrastructure for the core procedural languages.

This mostly just involves creating control, install, and
update-from-unpackaged scripts for them.  However, I had to adjust plperl
and plpython to not share the same support functions between variants,
because we can't put the same function into multiple extensions.

catversion bump forced due to new contents of pg_pltemplate, and because
initdb now installs plpgsql as an extension not a bare language.

Add support for regression testing these as extensions not bare
languages.

Fix a couple of other issues that popped up while testing this: my initial
hack at pg_dump binary-upgrade support didn't work right, and we don't want
an extra schema permissions test after all.

Documentation changes still to come, but I'm committing now to see
whether the MSVC build scripts need work (likely they do).

13 years agoRefactor seclabel.c to use the new check_object_ownership function.
Robert Haas [Fri, 4 Mar 2011 22:26:37 +0000 (17:26 -0500)]
Refactor seclabel.c to use the new check_object_ownership function.

This avoids duplicate (and not-quite-matching) code, and makes the logic
for SECURITY LABEL match COMMENT and ALTER EXTENSION ADD/DROP.

13 years agoDon't allow CREATE TABLE AS to create a column with invalid collation
Peter Eisentraut [Fri, 4 Mar 2011 21:39:44 +0000 (23:39 +0200)]
Don't allow CREATE TABLE AS to create a column with invalid collation

It is possible that an expression ends up with a collatable type but
without a collation.  CREATE TABLE AS could then create a table based
on that.  But such a column cannot be dumped with valid SQL syntax, so
we disallow creating such a column.

per test report from Noah Misch

13 years agoAllow non-superusers to create (some) extensions.
Tom Lane [Fri, 4 Mar 2011 21:08:24 +0000 (16:08 -0500)]
Allow non-superusers to create (some) extensions.

Remove the unconditional superuser permissions check in CREATE EXTENSION,
and instead define a "superuser" extension property, which when false
(not the default) skips the superuser permissions check.  In this case
the calling user only needs enough permissions to execute the commands
in the extension's installation script.  The superuser property is also
enforced in the same way for ALTER EXTENSION UPDATE cases.

In other ALTER EXTENSION cases and DROP EXTENSION, test ownership of
the extension rather than superuserness.  ALTER EXTENSION ADD/DROP needs
to insist on ownership of the target object as well; to do that without
duplicating code, refactor comment.c's big switch for permissions checks
into a separate function in objectaddress.c.

I also removed the superuserness checks in pg_available_extensions and
related functions; there's no strong reason why everybody shouldn't
be able to see that info.

Also invent an IF NOT EXISTS variant of CREATE EXTENSION, and use that
in pg_dump, so that dumps won't fail for installed-by-default extensions.
We don't have any of those yet, but we will soon.

This is all per discussion of wrapping the standard procedural languages
into extensions.  I'll make those changes in a separate commit; this is
just putting the core infrastructure in place.

13 years agoWhen creating a collation, check that the locales can be loaded
Peter Eisentraut [Fri, 4 Mar 2011 20:14:37 +0000 (22:14 +0200)]
When creating a collation, check that the locales can be loaded

This is the same check that would happen later when the collation is
used, but it's friendlier to check the collation already when it is
created.

13 years agoIn initialize_SSL, don't fail unnecessarily when home dir is unavailable.
Tom Lane [Fri, 4 Mar 2011 16:38:45 +0000 (11:38 -0500)]
In initialize_SSL, don't fail unnecessarily when home dir is unavailable.

Instead, just act as though the certificate file(s) are not present.
There is only one case where this need be a hard failure condition: when
sslmode is verify-ca or verify-full, not having a root cert file is an
error.  Change the logic so that we complain only in that case, and
otherwise fall through cleanly.  This is how it used to behave pre-9.0,
but my patch 4ed4b6c54e5fab24ab2624d80e26f7546edc88ad of 2010-05-26 broke
the case.  Per report from Christian Kastner.

13 years agoYou must hold a lock on the heap page when you call
Heikki Linnakangas [Fri, 4 Mar 2011 13:37:09 +0000 (15:37 +0200)]
You must hold a lock on the heap page when you call
CheckForSerializableConflictOut(), because it can set hint bits.

YAMAMOTO Takashi

13 years agoAdd a comment explaining the recent fix for plpython breakage in commit 4c966d9.
Andrew Dunstan [Fri, 4 Mar 2011 00:41:54 +0000 (19:41 -0500)]
Add a comment explaining the recent fix for plpython breakage in commit 4c966d9.

Mostly text supplied by Jan Urbański.

13 years agoFurther refine patch for commenting operator implementation functions.
Tom Lane [Thu, 3 Mar 2011 20:55:47 +0000 (15:55 -0500)]
Further refine patch for commenting operator implementation functions.

Instead of manually maintaining the "implementation of XXX operator"
comments in pg_proc.h, delete all those entries and let initdb create
them via a join.  To let initdb figure out which name to use when there
is a conflict, change the comments for deprecated operators to say they
are deprecated --- which seems like a good thing to do anyway.

13 years agoFix citext's upgrade-from-unpackaged script to set its collation correctly.
Tom Lane [Thu, 3 Mar 2011 18:22:18 +0000 (13:22 -0500)]
Fix citext's upgrade-from-unpackaged script to set its collation correctly.

Although there remains some debate about how CREATE TYPE should represent
the collation property, this doesn't really affect what we need to do in
citext's script, so go ahead and fix that.

13 years agoRun a portal's cleanup hook immediately when pushing it to DONE state.
Tom Lane [Thu, 3 Mar 2011 18:03:34 +0000 (13:03 -0500)]
Run a portal's cleanup hook immediately when pushing it to DONE state.

This works around the problem noted by Yamamoto Takashi in bug #5906,
that there were code paths whereby we could reach AtCleanup_Portals
with a portal's cleanup hook still unexecuted.  The changes I made
a few days ago were intended to prevent that from happening, and
I think that on balance it's still a good thing to avoid, so I don't
want to remove the Assert in AtCleanup_Portals.  Hence do this instead.

13 years agoAdded new version of ecpg's parser generator script. This one was written by
Michael Meskes [Thu, 3 Mar 2011 12:43:50 +0000 (13:43 +0100)]
Added new version of ecpg's parser generator script. This one was written by
Andy Colson <andy@squeakycode.net>.

13 years agoAdd tab-completion for table name after JOIN.
Heikki Linnakangas [Thu, 3 Mar 2011 07:42:02 +0000 (09:42 +0200)]
Add tab-completion for table name after JOIN.

Andrey Popp

13 years agoAdd -lm to SHLIB_LINK for contrib/btree_gist.
Tom Lane [Thu, 3 Mar 2011 06:43:38 +0000 (01:43 -0500)]
Add -lm to SHLIB_LINK for contrib/btree_gist.

Now that btree_gist contains a reference to isinf(), this is necessary
at least on some platforms.  Per buildfarm.

13 years agoMark operator implementation functions as such in their comments.
Tom Lane [Thu, 3 Mar 2011 06:33:19 +0000 (01:33 -0500)]
Mark operator implementation functions as such in their comments.

Historically, we've not had separate comments for built-in pg_operator
entries, but relied on the comments for the underlying functions.  The
trouble with this approach is that there isn't much of anything to suggest
to users that they'd be better off using the operators instead.  So, move
all the relevant comments into pg_operator, and give each underlying
function a comment that just says "implementation of XXX operator".
There are only about half a dozen cases where it seems reasonable to use
the underlying function interchangeably with the operator; in these cases
I left the same comment in place on the function as on the operator.

While at it, establish a policy that every built-in function and operator
entry should have a comment: there are now queries in the opr_sanity
regression test that will complain if one doesn't.  This only required
adding a dozen or two more entries than would have been there anyway.

I also spent some time trying to eliminate gratuitous inconsistencies in
the style of the comments, though it's hopeless to suppose that more won't
creep in soon enough.

Per my proposal of 2010-10-15.

13 years agoAdd collations to information_schema.usage_privileges
Peter Eisentraut [Wed, 2 Mar 2011 21:10:41 +0000 (23:10 +0200)]
Add collations to information_schema.usage_privileges

This is faked information like for domains.

13 years agoAdd 'collatable' to the Parameters section of CREATE TYPE.
Tom Lane [Wed, 2 Mar 2011 21:11:05 +0000 (16:11 -0500)]
Add 'collatable' to the Parameters section of CREATE TYPE.

13 years agoAdd KNNGIST support to contrib/btree_gist.
Tom Lane [Wed, 2 Mar 2011 19:43:24 +0000 (14:43 -0500)]
Add KNNGIST support to contrib/btree_gist.

This extends GiST's support for nearest-neighbor searches to many of the
standard data types.

Teodor Sigaev

13 years agoSupport for DragonFly BSD
Peter Eisentraut [Wed, 2 Mar 2011 19:15:28 +0000 (21:15 +0200)]
Support for DragonFly BSD

Mapped to NetBSD, the closest existing match.  (Even though DragonFly
BSD is derived from FreeBSD, the shared library version numbering
matches NetBSD, and the rest is mostly the same among all BSD
variants.)

per "Rumko"

13 years agoFix erroneous documentation of the syntax of CREATE CONSTRAINT TRIGGER.
Tom Lane [Wed, 2 Mar 2011 16:39:18 +0000 (11:39 -0500)]
Fix erroneous documentation of the syntax of CREATE CONSTRAINT TRIGGER.

The grammar requires a specific ordering of the clauses, but the
documentation showed a different order.  This error was introduced in
commit b47953f9c69d48a9261bd643e3170017b93f6337, which merged the CREATE
CONSTRAINT TRIGGER documentation into the CREATE TRIGGER page.  There is
no code bug AFAICS.

13 years agoCorrect mistaken claims about EXPLAIN ANALYZE's handling of triggers.
Tom Lane [Wed, 2 Mar 2011 16:17:03 +0000 (11:17 -0500)]
Correct mistaken claims about EXPLAIN ANALYZE's handling of triggers.

Time spent executing AFTER triggers is not included in the runtime of the
associated ModifyTable node; in my patch of yesterday I confused queuing of
these triggers with their actual execution.  Spotted by Marko Tiikkaja.

13 years agoFix plpython breakage detected on certain Fedora machines on buildfarm.
Andrew Dunstan [Tue, 1 Mar 2011 23:59:31 +0000 (18:59 -0500)]
Fix plpython breakage detected on certain Fedora machines on buildfarm.

Patch from Jan Urbański.

13 years agoAdditional PL/Python regression test expected file
Peter Eisentraut [Tue, 1 Mar 2011 21:35:18 +0000 (23:35 +0200)]
Additional PL/Python regression test expected file

plpython_subtransaction test needs a separate expected file
specifically for Python 2.5.

13 years agoChange pg_last_xlog_receive_location() not to move backwards. That makes
Heikki Linnakangas [Tue, 1 Mar 2011 18:46:57 +0000 (20:46 +0200)]
Change pg_last_xlog_receive_location() not to move backwards. That makes
it a lot more useful for determining which standby is most up-to-date,
for example. There was long discussions on whether overwriting existing
existing WAL makes sense to begin with, and whether we should do some more
extensive variable renaming, but this change nevertheless seems quite
uncontroversial.

Fujii Masao, reviewed by Jeff Janes, Robert Haas, Stephen Frost.

13 years agoFix bugs in Serializable Snapshot Isolation.
Heikki Linnakangas [Tue, 1 Mar 2011 17:05:16 +0000 (19:05 +0200)]
Fix bugs in Serializable Snapshot Isolation.

Change the way UPDATEs are handled. Instead of maintaining a chain of
tuple-level locks in shared memory, copy any existing locks on the old
tuple to the new tuple at UPDATE. Any existing page-level lock needs to
be duplicated too, as a lock on the new tuple. That was neglected
previously.

Store xmin on tuple-level predicate locks, to distinguish a lock on an old
already-recycled tuple from a new tuple at the same physical location.
Failure to distinguish them caused loops in the tuple-lock chains, as
reported by YAMAMOTO Takashi. Although we don't use the chain representation
of UPDATEs anymore, it seems like a good idea to store the xmin to avoid
some false positives if no other reason.

CheckSingleTargetForConflictsIn now correctly handles the case where a lock
that's being held is not reflected in the local lock table. That happens
if another backend acquires a lock on our behalf due to an UPDATE or a page
split.

PredicateLockPageCombine now retains locks for the page that is being
removed, rather than removing them. This prevents a potentially dangerous
false-positive inconsistency where the local lock table believes that a lock
is held, but it is actually not.

Dan Ports and Kevin Grittner

13 years agoDump the COLLATABLE attribute in CREATE TYPE
Peter Eisentraut [Tue, 1 Mar 2011 16:45:34 +0000 (18:45 +0200)]
Dump the COLLATABLE attribute in CREATE TYPE

This was previously omitted by accident.

13 years agoUpdate discussion of EXPLAIN to reflect existence of ModifyTable nodes.
Tom Lane [Tue, 1 Mar 2011 16:36:01 +0000 (11:36 -0500)]
Update discussion of EXPLAIN to reflect existence of ModifyTable nodes.

Back-patch to 9.0, since this was changed then.

13 years agoInclude the target table in EXPLAIN output for ModifyTable nodes.
Tom Lane [Tue, 1 Mar 2011 16:32:13 +0000 (11:32 -0500)]
Include the target table in EXPLAIN output for ModifyTable nodes.

Per discussion, this seems important for plans involving writable CTEs,
since there can now be more than one ModifyTable node in the plan.

To retain the same formatting as for target tables of scan nodes, we
show only one target table, which will be the parent table in case of
an UPDATE or DELETE on an inheritance tree.  Individual child tables
can be determined by inspecting the child plan trees if needed.

13 years agoAvoid excessive Hot Standby feedback messages.
Robert Haas [Tue, 1 Mar 2011 16:32:23 +0000 (11:32 -0500)]
Avoid excessive Hot Standby feedback messages.

Without this patch, when wal_receiver_status_interval=0, indicating that no
status messages should be sent, Hot Standby feedback messages are instead sent
extremely frequently.

Fujii Masao, with documentation changes by me.

13 years agoRearrange snapshot handling to make rule expansion more consistent.
Tom Lane [Tue, 1 Mar 2011 04:27:18 +0000 (23:27 -0500)]
Rearrange snapshot handling to make rule expansion more consistent.

With this patch, portals, SQL functions, and SPI all agree that there
should be only a CommandCounterIncrement between the queries that are
generated from a single SQL command by rule expansion.  Fetching a whole
new snapshot now happens only between original queries.  This is equivalent
to the existing behavior of EXPLAIN ANALYZE, and it was judged to be the
best choice since it eliminates one source of concurrency hazards for
rules.  The patch should also make things marginally faster by reducing the
number of snapshot push/pop operations.

The patch removes pg_parse_and_rewrite(), which is no longer used anywhere.
There was considerable discussion about more aggressive refactoring of the
query-processing functions exported by postgres.c, but for the moment
nothing more has been done there.

I also took the opportunity to refactor snapmgr.c's API slightly: the
former PushUpdatedSnapshot() has been split into two functions.

Marko Tiikkaja, reviewed by Steve Singer and Tom Lane

13 years agoUnbreak vpath builds broken by commit 474a42473adf9b18417242f1fc0691a857ec578b.
Andrew Dunstan [Tue, 1 Mar 2011 02:31:39 +0000 (21:31 -0500)]
Unbreak vpath builds broken by commit 474a42473adf9b18417242f1fc0691a857ec578b.

13 years agoRename pg_stat_replication.apply_location to replay_location.
Robert Haas [Mon, 28 Feb 2011 17:48:46 +0000 (12:48 -0500)]
Rename pg_stat_replication.apply_location to replay_location.

For consistency with pg_last_xlog_replay_location.  Per discussion.

13 years agoFix regression tests after PL/Python custom SPI exceptions patch
Peter Eisentraut [Mon, 28 Feb 2011 17:43:36 +0000 (19:43 +0200)]
Fix regression tests after PL/Python custom SPI exceptions patch

13 years agoPL/Python custom SPI exceptions
Peter Eisentraut [Mon, 28 Feb 2011 16:41:10 +0000 (18:41 +0200)]
PL/Python custom SPI exceptions

This provides a separate exception class for each error code that the
backend defines, as well as the ability to get the SQLSTATE from the
exception object.

Jan Urbański, reviewed by Steve Singer

13 years agoAdd documentation for data-modifying statements in WITH clauses.
Tom Lane [Mon, 28 Feb 2011 06:17:18 +0000 (01:17 -0500)]
Add documentation for data-modifying statements in WITH clauses.

Marko Tiikkaja, somewhat reworked by Tom

13 years agoDocument that last vacuum statistics and counts are for non-FULL vacuums.
Bruce Momjian [Sun, 27 Feb 2011 23:03:49 +0000 (18:03 -0500)]
Document that last vacuum statistics and counts are for non-FULL vacuums.

13 years agoPL/Python explicit subtransactions
Peter Eisentraut [Sun, 27 Feb 2011 15:09:56 +0000 (17:09 +0200)]
PL/Python explicit subtransactions

Adds a context manager, obtainable by plpy.subtransaction(), to run a
group of statements in a subtransaction.

Jan Urbański, reviewed by Steve Singer, additional scribbling by me

13 years agoRemove remaining expected file for Python 2.2
Peter Eisentraut [Sun, 27 Feb 2011 12:00:19 +0000 (14:00 +0200)]
Remove remaining expected file for Python 2.2

We don't have complete expected coverage for Python 2.2 anyway, so it
doesn't seem worth keeping this one around that no one appears to be
updating anyway.  Visual inspection of the differences ought to be
good enough for those few who care about this obsolete Python version.

13 years agoRefactor the executor's API to support data-modifying CTEs better.
Tom Lane [Sun, 27 Feb 2011 18:43:29 +0000 (13:43 -0500)]
Refactor the executor's API to support data-modifying CTEs better.

The originally committed patch for modifying CTEs didn't interact well
with EXPLAIN, as noted by myself, and also had corner-case problems with
triggers, as noted by Dean Rasheed.  Those problems show it is really not
practical for ExecutorEnd to call any user-defined code; so split the
cleanup duties out into a new function ExecutorFinish, which must be called
between the last ExecutorRun call and ExecutorEnd.  Some Asserts have been
added to these functions to help verify correct usage.

It is no longer necessary for callers of the executor to call
AfterTriggerBeginQuery/AfterTriggerEndQuery for themselves, as this is now
done by ExecutorStart/ExecutorFinish respectively.  If you really need to
suppress that and do it for yourself, pass EXEC_FLAG_SKIP_TRIGGERS to
ExecutorStart.

Also, refactor portal commit processing to allow for the possibility that
PortalDrop will invoke user-defined code.  I think this is not actually
necessary just yet, since the portal-execution-strategy logic forces any
non-pure-SELECT query to be run to completion before we will consider
committing.  But it seems like good future-proofing.

13 years agoBe less detailed about reporting shared memory failure by avoiding the
Bruce Momjian [Sun, 27 Feb 2011 17:21:25 +0000 (12:21 -0500)]
Be less detailed about reporting shared memory failure by avoiding the
output of actual Postgres parameter _values_ related to shared memory,
and suggesting that these are only possible parameters to reduce.

13 years agoFix verbose display of REPLICATION role attribute
Magnus Hagander [Sun, 27 Feb 2011 11:35:31 +0000 (12:35 +0100)]
Fix verbose display of REPLICATION role attribute

Josh Kupershmidt

13 years agoFix markup for pg_options_to_table() to report the return column names,
Bruce Momjian [Sun, 27 Feb 2011 08:50:12 +0000 (03:50 -0500)]
Fix markup for pg_options_to_table() to report the return column names,
per suggestion from Andrew.