- 12 Jan, 2006 6 commits
- 
- 
Neil Conway authoredprepared statements, per report from David Wheeler. 
- 
Andrew Dunstan authored
- 
Neil Conway authoredfmgr_info(), in the TopMemoryContext. I couldn't see that the code actually leaked, but in general I think it's fragile to assume that pfree'ing an FmgrInfo along with its fn_extra field is enough to reclaim all the resources allocated by fmgr_info(). I changed the code to do its allocations in a new child context of TopMemoryContext, MbProcContext. When we want to release the allocations we can just reset the context, which is cleaner. 
- 
Tom Lane authoredour own command (or more generally, xmin = our xact and cmin >= current command ID) should not be seen as good. Else we may try to update rows we already updated. This error was inserted last August while fixing the even bigger problem that the old coding wouldn't see *any* tuples inserted by our own transaction as good. Per report from Euler Taveira de Oliveira. 
- 
Tom Lane authoredIt seems that recent gcc versions can optimize away calls to these functions even when the functions do not exist on the platform, resulting in a bogus positive result. Avoid this by using a non-constant argument and ensuring that the function result is not simply discarded. Per report from François Laupretre. 
- 
Tom Lane authoredcertainly. Per report from George Woodring. 
 
- 
- 11 Jan, 2006 7 commits
- 
- 
Tom Lane authored
- 
Neil Conway authoredof the CREATE CONVERSION syntax, for consistency with the other SQL reference pages. 
- 
Bruce Momjian authored
- 
Bruce Momjian authored> * -Add sleep() function, remove from regress.c 
- 
Tom Lane authoredReplace the former ad-hoc implementation used in the regression tests. Joachim Wieland 
- 
Neil Conway authoredrather than "return expr;" -- the latter style is used in most of the tree. I kept the parentheses when they were necessary or useful because the return expression was complex. 
- 
Neil Conway authored
 
- 
- 10 Jan, 2006 5 commits
- 
- 
Tom Lane authored
- 
Neil Conway authorednon-NULL during the guts of plpgsql_exec_trigger() and plpgsql_exec_function(). Therefore, we can remove the NULL check, per discussion on -patches. 
- 
Tom Lane authoredlisted in the column's most-common-values statistics entry. This gives us an exact selectivity result for the portion of the column population represented by the MCV list, which can be a big leg up in accuracy if that's a large fraction of the population. The heuristics involving pattern contents and prefix are applied only to the part of the population not included in the MCV list. 
- 
Andrew Dunstan authoredremove unneeded defines for uid_t and gid_t, which conflict with perl's typedefs. 
- 
Neil Conway authoredone argument at a time and then inserting the argument into a Python list via PyList_SetItem(). This "steals" the reference to the argument: that is, the reference to the new list member is now held by the Python list itself. This works fine, except if an elog occurs. This causes the function's PG_CATCH() block to be invoked, which decrements the reference counts on both the current argument and the list of arguments. If the elog happens to occur during the second or subsequent iteration of the loop, the reference count on the current argument will be decremented twice. The fix is simple: set the local pointer to the current argument to NULL immediately after adding it to the argument list. This ensures that the Py_XDECREF() in the PG_CATCH() block doesn't double-decrement. 
 
- 
- 09 Jan, 2006 4 commits
- 
- 
Bruce Momjian authored< * %Allow pooled connections to list all prepared statements > * -%Allow pooled connections to list all prepared statements 
- 
Tom Lane authoredoperator names. This is needed when dumping operator definitions that have COMMUTATOR (or similar) links to operators in other schemas. Apparently Daniel Whitter is the first person ever to try this :-( 
- 
Peter Eisentraut authoredbehavior. 
- 
Neil Conway authoredand change two elogs into ereports because they could actually occur in practice. 
 
- 
- 08 Jan, 2006 5 commits
- 
- 
Andrew Dunstan authoredRationalise perl header inclusions via a common include file, which also declares routines in plperl.c and spi_internal.c used in other files. Along the way, also stop perl from hijacking stdio and other stuff on Windows. 
- 
Tom Lane authoreddifference between USE_ASSERT_CHECKING and not: the assert_enabled variable is always there. 
- 
Tom Lane authoredStefan Kaltenbrunner. 
- 
Tom Lane authoredand nail a couple more system indexes into cache. This doesn't make any difference in normal system operation, but when forcing constant cache resets it's difficult to get through the rules regression test without these changes. 
- 
Neil Conway authoredaccess information about the prepared statements that are available in the current session. Original patch from Joachim Wieland, various improvements by Neil Conway. The "statement" column of the view contains the literal query string sent by the client, without any rewriting or pretty printing. This means that prepared statements created via SQL will be prefixed with "PREPARE ... AS ", whereas those prepared via the FE/BE protocol will not. That is unfortunate, but discussion on -patches did not yield an efficient way to improve this, and there is some merit in returning exactly what the client sent to the backend. Catalog version bumped, regression tests updated. 
 
- 
- 07 Jan, 2006 3 commits
- 
- 
Tom Lane authoreduse it. While it normally has been opened earlier during btree index build, testing shows that it's possible for the link to be closed again if an sinval reset occurs while the index is being built. 
- 
Tom Lane authored
- 
Tom Lane authoreddead and have become unreferenced. Before 8.1, such members were left for AtEOXact_CatCache() to clean up, but now AtEOXact_CatCache isn't supposed to have anything to do. In an assert-enabled build this bug leads to an assertion failure at transaction end, but in a non-assert build the dead member is effectively just a small memory leak. Per report from Jeremy Drake. 
 
- 
- 06 Jan, 2006 7 commits
- 
- 
Tom Lane authoredan INSERT target list during rule rewriting. Per report from John Supplee. 
- 
Bruce Momjian authored
- 
Tom Lane authored
- 
Tom Lane authoredrather than elog(FATAL), when there is no more room in ShmemBackendArray. This is a security issue since too many connection requests arriving close together could cause the postmaster to shut down, resulting in denial of service. Reported by Yoshiyuki Asaba, fixed by Magnus Hagander. 
- 
Tom Lane authored
- 
Tom Lane authoredThe consequences of overwriting a non-empty page are bad enough that we should not omit this test in production builds. 
- 
Tom Lane authoredthe relation but it finds a pre-existing valid buffer. The buffer does not correspond to any page known to the kernel, so we *must* do smgrextend to ensure that the space becomes allocated. The 7.x branches all do this correctly, but the corner case got lost somewhere during 8.0 bufmgr rewrites. (My fault no doubt :-( ... I think I assumed that such a buffer must be not-BM_VALID, which is not so.) 
 
- 
- 05 Jan, 2006 3 commits
- 
- 
Bruce Momjian authored> > * Allow SERIAL sequences to inherit permissions from the base table? 
- 
Bruce Momjian authored
- 
Bruce Momjian authored< stable logging probably can not have indexes. [wallog] > stable logging probably can not have indexes. [walcontrol] 
 
-