https://github.com/postgres/postgres

sort by:
Revision Author Date Message Commit Date
af7bab7 Version stamp 8.5alpha3 20 December 2009, 07:31:43 UTC
7d672e1 Fix two small typos in Hot Standby docs. John Naylor 20 December 2009, 03:49:58 UTC
8f649c9 Add documentation why reassigning PL/Python function parameters in the function body can have undesirable outcomes. (bug #5232) 19 December 2009, 22:23:21 UTC
16dc6f0 Add hot standby to release notes 19 December 2009, 20:33:12 UTC
baab7a0 Translation updates 19 December 2009, 20:23:26 UTC
7ba1f8f Convert tabs to spaces in SGML. 19 December 2009, 17:49:50 UTC
0e9c1b1 Sigh, I managed to break the no-links-in-plain-text-docs rule too... 19 December 2009, 05:37:01 UTC
ce1489f Add a whitespace to fix the query to dump large objects. PL/pgSQL-by-default patch broke the code for 8.3 <= server_version < 8.5. 19 December 2009, 04:13:30 UTC
4fca795 Bump catversion to reflect the fact that HS patch changed pg_proc contents, and PG_CONTROL_VERSION to reflect the fact that it changed pg_control contents. (I see we did at least remember to change XLOG_PAGE_MAGIC for the WAL contents changes.) 19 December 2009, 04:08:32 UTC
50b5bec Add missing Id keyword to alter_large_object.sgml. 19 December 2009, 03:29:28 UTC
d37cda2 plpgsql patch broke the MSVC build, too. 19 December 2009, 02:44:06 UTC
d290363 Join in the fun of editorializing on the alpha release notes. 19 December 2009, 02:38:54 UTC
1b612df Update ecpg regression tests to plpgsql installed by default. 19 December 2009, 02:38:51 UTC
40ee42b Update tutorial on the fact that backslash commands are no longer listed in psql's startup banner. 19 December 2009, 02:34:17 UTC
c43d26c Adjust some more places in the documentation to match the fact that plpgsql is now installed by default. 19 December 2009, 01:49:02 UTC
efc16ea Allow read only connections during recovery, known as Hot Standby. Enabled by recovery_connections = on (default) and forcing archive recovery using a recovery.conf. Recovery processing now emulates the original transactions as they are replayed, providing full locking and MVCC behaviour for read only queries. Recovery must enter consistent state before connections are allowed, so there is a delay, typically short, before connections succeed. Replay of recovering transactions can conflict and in some cases deadlock with queries during recovery; these result in query cancellation after max_standby_delay seconds have expired. Infrastructure changes have minor effects on normal running, though introduce four new types of WAL record. New test mode "make standbycheck" allows regression tests of static command behaviour on a standby server while in recovery. Typical and extreme dynamic behaviours have been checked via code inspection and manual testing. Few port specific behaviours have been utilised, though primary testing has been on Linux only so far. This commit is the basic patch. Additional changes will follow in this release to enhance some aspects of behaviour, notably improved handling of conflicts, deadlock detection and query cancellation. Changes to VACUUM FULL are also required. Simon Riggs, with significant and lengthy review by Heikki Linnakangas, including streamlined redesign of snapshot creation and two-phase commit. Important contributions from Florian Pflug, Mark Kirkwood, Merlin Moncure, Greg Stark, Gianni Ciolli, Gabriele Bartolini, Hannu Krosing, Robert Haas, Tatsuo Ishii, Hiroyuki Yamada plus support and feedback from many other community members. 19 December 2009, 01:32:45 UTC
78a0914 binary migration: pg_migrator Add comments about places where system oids have to be preserved for binary migration. 19 December 2009, 00:47:57 UTC
2e9468f Fix a few typos in the latest 8.5alpha3 release notes. 19 December 2009, 00:05:27 UTC
2692274 8.5alpha3 release notes up to Fri Dec 18 21:37:38 2009 +0000 18 December 2009, 22:11:09 UTC
b35b16e Fix link that doesn't work in standalone INSTALL document. 18 December 2009, 21:37:38 UTC
96c102f Install server-side language PL/pgSQL by default. 18 December 2009, 21:28:42 UTC
be3a24d Force the TZ environment variable to be set during initdb. This is to short-circuit the rather expensive identify_system_timezone() procedure, which we have no real need for during initdb since nothing done here depends on the timezone setting. Since we launch quite a few standalone backends during the initdb sequence, this adds up to a significant savings, and seems worth doing to save developer time even though it will hardly matter to end users. Per my report today on pgsql-hackers. 18 December 2009, 18:45:50 UTC
f5fd651 Improve documentation for pg_largeobject changes. Rewrite the documentation in more idiomatic English, and in the process make it somewhat more succinct. Move the discussion of specific large object privileges out of the "server-side functions" section, where it certainly doesn't belong, and into "implementation features". That might not be exactly right either, but it doesn't seem worth creating a new section for this amount of information. Fix a few spelling and layout problems, too. 17 December 2009, 14:36:16 UTC
36d192a Reverting accidently commited changes. 17 December 2009, 07:28:58 UTC
d6de430 Don't unblock SIGQUIT in the SIGQUIT handler This was possibly linked to a deadlock-like situation in glibc syslog code invoked by the ereport call in quickdie(). In any case, a signal handler should not unblock its own signal unless there is a specific reason to. 16 December 2009, 23:05:00 UTC
b63b967 If there is no sigdelset(), define it as a macro. This removes some duplicate code that recreated the identical workaround when the newer signal API is missing. 16 December 2009, 22:55:34 UTC
52fc007 Avoid a premature coercion failure in transformSetOperationTree() when presented with an UNKNOWN-type Var, which can happen in cases where an unknown literal appeared in a subquery. While many such cases will fail later on anyway in the planner, there are some cases where the planner is able to flatten the query and replace the Var by the constant before it has to coerce the union column to the final type. I had added this check in 8.4 to provide earlier/better error detection, but it causes a regression for some cases that worked OK before. Fix by not making the check if the input node is UNKNOWN type and not a Const or Param. If it isn't going to work, it will fail anyway at plan time, with the only real loss being inability to provide an error cursor. Per gripe from Britt Piehler. In passing, rename a couple of variables to remove confusion from an inner scope masking the same variable names in an outer scope. 16 December 2009, 22:24:13 UTC
ff49961 Several fixes for EXPLAIN (FORMAT YAML), plus one for EXPLAIN (FORMAT JSON). ExplainSeparatePlans() was busted for both JSON and YAML output - the present code is a holdover from the original version of my machine-readable explain patch, which didn't have the grouping_stack machinery. Also, fix an odd distribution of labor between ExplainBeginGroup() and ExplainYAMLLineStarting() when marking lists with "- ", with each providing one character. This broke the output format for multi-query statements. Also, fix ExplainDummyGroup() for the YAML output format. Along the way, make the YAML format use escape_yaml() in situations where the JSON format uses escape_json(). Right now, it doesn't matter because all the values are known not to need escaping, but it seems safer this way. Finally, I added some comments to better explain what the YAML output format is doing. Greg Sabino Mullane reported the issues with multi-query statements. Analysis and remaining cleanups by me. 16 December 2009, 22:16:16 UTC
3dfe7e8 Remove spurious '22' that clearly shouldn't be there. David E. Wheeler 16 December 2009, 19:38:54 UTC
d19669e Fixed auto-prepare to not try preparing statements that are not preparable. Bug found and solved by Boszormenyi Zoltan <zb@cybertec.at>, some small adjustments by me. 16 December 2009, 10:15:07 UTC
dd4cd55 Python 3 support in PL/Python Behaves more or less unchanged compared to Python 2, but the new language variant is called plpython3u. Documentation describing the naming scheme is included. 15 December 2009, 22:59:55 UTC
21d11e7 Avoid unnecessary copying of source string when generating a cloned TParser. For long source strings the copying results in O(N^2) behavior, and the multiplier can be significant if wide-char conversion is involved. Andres Freund, reviewed by Kevin Grittner. 15 December 2009, 20:37:17 UTC
a5495cd Add a hook to let loadable modules get control at ProcessUtility execution, and use it to extend contrib/pg_stat_statements to track utility commands. Itagaki Takahiro, reviewed by Euler Taveira de Oliveira. 15 December 2009, 20:04:49 UTC
34d2687 Support ORDER BY within aggregate function calls, at long last providing a non-kluge method for controlling the order in which values are fed to an aggregate function. At the same time eliminate the old implementation restriction that DISTINCT was only supported for single-argument aggregates. Possibly release-notable behavioral change: formerly, agg(DISTINCT x) dropped null values of x unconditionally. Now, it does so only if the agg transition function is strict; otherwise nulls are treated as DISTINCT normally would, ie, you get one copy. Andrew Gierth, reviewed by Hitoshi Harada 15 December 2009, 17:57:48 UTC
6a6efb9 Fix broken markup. 15 December 2009, 15:59:57 UTC
7d67e06 Add \shell and \setshell meta commands to pgbench. \shell command runs an external shell command. \setshell also does the same and sets the result to a variable. original patch by Michael Paquier with some editorialization by Itagaki, and reviewed by Greg Smith. 15 December 2009, 07:17:57 UTC
cddca5e Add an EXPLAIN (BUFFERS) option to show buffer-usage statistics. This patch also removes buffer-usage statistics from the track_counts output, since this (or the global server statistics) is deemed to be a better interface to this information. Itagaki Takahiro, reviewed by Euler Taveira de Oliveira. 15 December 2009, 04:57:48 UTC
6f1bf75 Fix pg_ctl initdb without options. Passing NULL string to snprintf is avoided. 15 December 2009, 00:17:50 UTC
a620d50 Fix a bug introduced when set-returning SQL functions were made inline-able: we have to cope with the possibility that the declared result rowtype contains dropped columns. This fails in 8.4, as per bug #5240. While at it, be more paranoid about inserting binary coercions when inlining. The pre-8.4 code did not really need to worry about that because it could not inline at all in any case where an added coercion could change the behavior of the function's statement. However, when inlining a SRF we allow sorting, grouping, and set-ops such as UNION. In these cases, modifying one of the targetlist entries that the sort/group/setop depends on could conceivably change the behavior of the function's statement --- so don't inline when such a case applies. 14 December 2009, 02:15:54 UTC
84f910a Additional fixes for large object access control. Use pg_largeobject_metadata.oid instead of pg_largeobject.loid to enumerate existing large objects in pg_dump, pg_restore, and contrib modules. 14 December 2009, 00:39:11 UTC
0182d6f Allow LDAP authentication to operate in search+bind mode, meaning it does a search for the user in the directory first, and then binds with the DN found for this user. This allows for LDAP logins in scenarios where the DN of the user cannot be determined simply by prefix and suffix, such as the case where different users are located in different containers. The old way of authentication can be significantly faster, so it's kept as an option. Robert Fleming and Magnus Hagander 12 December 2009, 21:35:21 UTC
a4e035b Fix integer-to-bit-string conversions to handle the first fractional byte correctly when the output bit width is wider than the given integer by something other than a multiple of 8 bits. This has been wrong since I first wrote that code for 8.0 :-(. Kudos to Roman Kononov for being the first to notice, though I didn't use his patch. Per bug #5237. 12 December 2009, 19:24:35 UTC
02490d4 Export ExplainBeginOutput() and ExplainEndOutput() for auto_explain. Without these functions, anyone outside of explain.c can't actually use ExplainPrintPlan, because the ExplainState won't be initialized properly. The user-visible result of this was a crash when using auto_explain with the JSON output format. Report by Euler Taveira de Oliveira. Analysis by Tom Lane. Patch by me. 12 December 2009, 00:35:34 UTC
6b45e3b Arrange to generate different random sequences in the different child processes of a pgbench run, when we are using -j > 1 and are emulating threads via fork(). Otherwise the children all inherit the same random sequence state and produce the same random-number sequence. In the threaded case the different threads will share one RNG state, so they will produce different subsets of one sequence, which is maybe more correlated than a purist would like but will not be "the same". So we leave that case alone. First noticed by Takahiro Itagaki, and is also part of the explanation for the pgbench misbehavior recently reported by Jaime Casanova. 11 December 2009, 21:50:06 UTC
d8e511f Ensure that the result tuple of an EvalPlanQual cycle gets materialized before we zap the input tuple. Otherwise, pass-by-reference columns of the result slot are likely to contain just references to the input tuple, leading to big trouble if the pfree'd space is reused. Per trouble report from Jaime Casanova. This is a new bug in the recent rewrite of EvalPlanQual, so nothing to back-patch. 11 December 2009, 18:14:43 UTC
f1325ce Add large object access control. A new system catalog pg_largeobject_metadata manages ownership and access privileges of large objects. KaiGai Kohei, reviewed by Jaime Casanova. 11 December 2009, 03:34:57 UTC
6457996 Properly define ENABLE_THREAD_SAFETY in conflgure, per suggestion from Peter. 11 December 2009, 02:21:21 UTC
324385d Add YAML to list of EXPLAIN formats. Greg Sabino Mullane, reviewed by Takahiro Itagaki. 11 December 2009, 01:33:35 UTC
db73861 PL/Python array support Support arrays as parameters and return values of PL/Python functions. 10 December 2009, 20:43:40 UTC
a37b001 Add init[db] option to pg_ctl pg_ctl gets a new mode that runs initdb. Adjust the documentation a bit to not assume that initdb is the only way to run database cluster initialization. But don't replace initdb as the canonical way. Author: Zdenek Kotala <Zdenek.Kotala@Sun.COM> 10 December 2009, 06:32:28 UTC
da07641 Fix levenshtein with costs. The previous code multiplied by the cost in only 3 of the 7 relevant locations. Marcin Mank, slightly adjusted by me. 10 December 2009, 01:54:17 UTC
03d7b06 Update release notes for releases 8.4.2, 8.3.9, 8.2.15, 8.1.19, 8.0.23, 7.4.27. 10 December 2009, 00:31:14 UTC
62aba76 Prevent indirect security attacks via changing session-local state within an allegedly immutable index function. It was previously recognized that we had to prevent such a function from executing SET/RESET ROLE/SESSION AUTHORIZATION, or it could trivially obtain the privileges of the session user. However, since there is in general no privilege checking for changes of session-local state, it is also possible for such a function to change settings in a way that might subvert later operations in the same session. Examples include changing search_path to cause an unexpected function to be called, or replacing an existing prepared statement with another one that will execute a function of the attacker's choosing. The present patch secures VACUUM, ANALYZE, and CREATE INDEX/REINDEX against these threats, which are the same places previously deemed to need protection against the SET ROLE issue. GUC changes are still allowed, since there are many useful cases for that, but we prevent security problems by forcing a rollback of any GUC change after completing the operation. Other cases are handled by throwing an error if any change is attempted; these include temp table creation, closing a cursor, and creating or deleting a prepared statement. (In 7.4, the infrastructure to roll back GUC changes doesn't exist, so we settle for rejecting changes of "search_path" in these contexts.) Original report and patch by Gurjeet Singh, additional analysis by Tom Lane. Security: CVE-2009-4136 09 December 2009, 21:57:51 UTC
7aeaa97 Add notes about updating disk and shared memory size information in the documentation when doing new major release. 09 December 2009, 17:03:30 UTC
2367d68 Update size references in installation instructions to be a bit more up-to-date with current versions. 09 December 2009, 16:16:34 UTC
abf23ee Reject certificates with embedded NULLs in the commonName field. This stops attacks where an attacker would put <attack>\0<propername> in the field and trick the validation code that the certificate was for <attack>. This is a very low risk attack since it reuqires the attacker to trick the CA into issuing a certificate with an incorrect field, and the common PostgreSQL deployments are with private CAs, and not external ones. Also, default mode in 8.4 does not do any name validation, and is thus also not vulnerable - but the higher security modes are. Backpatch all the way. Even though versions 8.3.x and before didn't have certificate name validation support, they still exposed this field for the user to perform the validation in the application code, and there is no way to detect this problem through that API. Security: CVE-2009-4034 09 December 2009, 06:37:06 UTC
65ed203 Update time zone data files to tzdata release 2009s: DST law changes in Antarctica, Argentina, Bangladesh, Fiji, Novokuznetsk, Pakistan, Palestine, Samoa, Syria. Also historical corrections for Hong Kong. 09 December 2009, 00:35:32 UTC
28519de Fix a couple of broken links to third-party sites. 08 December 2009, 20:08:30 UTC
ac1b614 Replace broken link to custom local gettext package with one to the main GNU site for gettext. 08 December 2009, 19:22:43 UTC
8df283d Update CVS documentation to be more current and add documentation about git mirror. Remove information about cvsup and documentation that's more about cvs than our use of cvs. Backpatch to 8.4 so we get the git information up on the website as soon as possible. 07 December 2009, 19:19:56 UTC
0cb6556 Add exclusion constraints, which generalize the concept of uniqueness to support any indexable commutative operator, not just equality. Two rows violate the exclusion constraint if "row1.col OP row2.col" is TRUE for each of the columns in the constraint. Jeff Davis, reviewed by Robert Haas 07 December 2009, 05:22:23 UTC
8de7472 Don't use a duplicate OID for aclexplode(). 06 December 2009, 02:55:54 UTC
36f887c Speed up information schema privilege views Instead of expensive cross joins to resolve the ACL, add table-returning function aclexplode() that expands the ACL into a useful form, and join against that. Also, implement the role_*_grants views as a thin layer over the respective *_privileges views instead of essentially repeating the same code twice. fixes bug #4596 by Joachim Wieland, with cleanup by me 05 December 2009, 21:43:36 UTC
636bac6 Information schema documentation Add a sentence of documentation about the differences between the *_privileges and the role_*_grants views. 05 December 2009, 21:31:05 UTC
ab3148b Fix bug in temporary file management with subtransactions. A cursor opened in a subtransaction stays open even if the subtransaction is aborted, so any temporary files related to it must stay alive as well. With the patch, we use ResourceOwners to track open temporary files and don't automatically close them at subtransaction end (though in the normal case temporary files are registered with the subtransaction resource owner and will therefore be closed). At end of top transaction, we still check that there's no temporary files marked as close-at-end-of-transaction open, but that's now just a debugging cross-check as the resource owner cleanup should've closed them already. 03 December 2009, 11:03:29 UTC
dc58805 Clarify what's supposed to happen when a cursor FETCH is rolled back by aborting a subtransaction. Per discussion with Heikki. 02 December 2009, 21:11:12 UTC
8c1c2e3 thread-safety Apply full patch to enable thread-safety by default, e.g. doc changes. 02 December 2009, 14:07:26 UTC
aebc4e6 Preventing intersection of ranges during page split. Changes are only optimization, so don't backpatch. 02 December 2009, 13:13:24 UTC
59ed94a Mark application_name as GUC_REPORT so that the value will be reported back to the client by the server. This might seem pretty pointless but apparently it will help pgbouncer, and perhaps other connection poolers. Anyway it's practically free to do so for the normal use-case where appname is only set in the startup packet --- we're just adding a few more bytes to the initial ParameterStatus response packet. Per comments from Marko Kreen. 02 December 2009, 04:54:10 UTC
3dfcf8c Instead of sending application_name as a SET command after the connection is made, include it in the startup-packet options. This makes it work more like every other libpq connection option, in particular it now has the same response to RESET ALL as the rest. This also saves one network round trip for new applications using application_name. The cost is that if the server is pre-8.5, it'll reject the startup packet altogether, forcing us to retry the entire connection cycle. But on balance we shouldn't be optimizing that case in preference to the behavior with a new server, especially when doing so creates visible behavioral oddities. Per discussion. 02 December 2009, 04:38:35 UTC
925b32b Enable thread safety Enable thread safety on all platforms. This will either be followed up by a more extensive patch, or reverted, depending on the build farm results. 01 December 2009, 23:02:44 UTC
b291c0f psql -f - Adjust psql -f - to behave like a normal file and honor the -1 flag. Report from Robert Haas 01 December 2009, 22:34:33 UTC
0d32342 Teach the regular expression functions to do case-insensitive matching and locale-dependent character classification properly when the database encoding is UTF8. The previous coding worked okay in single-byte encodings, or in any case for ASCII characters, but failed entirely on multibyte characters. The fix assumes that the <wctype.h> functions use Unicode code points as the wchar representation for Unicode, ie, wchar matches pg_wchar. This is only a partial solution, since we're still stupid about non-ASCII characters in multibyte encodings other than UTF8. The practical effect of that is limited, however, since those cases are generally Far Eastern glyphs for which concepts like case-folding don't apply anyway. Certainly all or nearly all of the field reports of problems have been about UTF8. A more general solution would require switching to the platform's wchar representation for all regex operations; which is possible but would have substantial disadvantages. Let's try this and see if it's sufficient in practice. 01 December 2009, 21:00:24 UTC
ef51395 Revert due to Tom's concerns: Add ProcessUtility_hook() to handle all DDL to contrib/pg_stat_statements. 01 December 2009, 02:31:13 UTC
d85cb27 ProcessUtility_hook: Add ProcessUtility_hook() to handle all DDL to contrib/pg_stat_statements. Itagaki Takahiro 01 December 2009, 01:08:46 UTC
29fd97d hstore docs Update hstore docs, mostly word-smithing. David E. Wheeler 30 November 2009, 17:56:09 UTC
891f924 THREAD_SUPPORT There is no reference to THREAD_SUPPORT outside configure, and it is never set, so remove it. 30 November 2009, 16:50:38 UTC
9088542 Avoid core dump on empty thesaurus dictionary. Per report from Robert Gravsjö. 30 November 2009, 16:38:31 UTC
bb1e8be In SRF example, move oldcontext variable definition into the FIRSTCALL branch, which is how most actual code is actually structured. Also fix slight whitespace misalignment. 30 November 2009, 15:49:35 UTC
be64b3e Properly indent SGML. 30 November 2009, 14:47:37 UTC
67ec9ad Fix session-lifespan memory leak when a plperl function is redefined: we have to tell Perl it can release its compiled copy of the function text. Noted by Alexey Klyukin. Back-patch to 8.2 --- the problem exists further back, but this patch won't work without modification, and it's probably not worth the trouble. 29 November 2009, 21:02:16 UTC
2203282 Error when a specified connection service is not found, instead of ignoring it 29 November 2009, 20:14:53 UTC
c19781a Add some opr_sanity checks that the lengths of the various argument-info arrays in a pg_proc entry match. Seems like an easy mistake to make when manually adjusting these values in a pg_proc.h entry. 29 November 2009, 18:53:54 UTC
e527d50 Remove prefix "ERROR:" from some messages, to make everything consistent 29 November 2009, 18:53:44 UTC
0c61cff Make pg_stat_activity.application_name visible to all users, rather than being hidden when current_query is. Relocate it to a column position more consistent with that behavior. Per discussion. 29 November 2009, 18:14:32 UTC
42b2907 Add support for anonymous code blocks (DO blocks) to PL/Perl. Joshua Tolley, reviewed by Brendan Jurd and Tim Bunce 29 November 2009, 03:02:27 UTC
8217cfb Add support for an application_name parameter, which is displayed in pg_stat_activity and recorded in log entries. Dave Page, reviewed by Andres Freund 28 November 2009, 23:38:08 UTC
cb98f61 fsync test tools Add link to exteran fsync testing script and our fsync test tool. 28 November 2009, 16:21:31 UTC
017c47b test_fsync: Improve test descriptions displayed during test_fsync; increase default loops to 5k. 28 November 2009, 15:04:54 UTC
1a95f12 Eliminate a lot of list-management overhead within join_search_one_level by adding a requirement that build_join_rel add new join RelOptInfos to the appropriate list immediately at creation. Per report from Robert Haas, the list_concat_unique_ptr() calls that this change eliminates were taking the lion's share of the runtime in larger join problems. This doesn't do anything to fix the fundamental combinatorial explosion in large join problems, but it should push out the threshold of pain a bit further. Note: because this changes the order in which joinrel lists are built, it might result in changes in selected plans in cases where different alternatives have exactly the same costs. There is one example in the regression tests. 28 November 2009, 00:46:19 UTC
fe83b97 Document ath vacuumdb --analyze does analyze _also_, not in place of vacuum. 27 November 2009, 17:41:26 UTC
bb28e83 Remove */ characters from declare cursor statements before putting them into a comment. 27 November 2009, 16:07:22 UTC
d7d5c68 If no result is given NOTFOUND should be returned. Check for empty result string too. 27 November 2009, 13:32:17 UTC
81a82a1 Added script to check if all rule re-definition in ecpg.addons are indeed used in the build process. If not the build process will stop with an error message. 27 November 2009, 10:00:40 UTC
f0edaec Fix missing end tag, per Jeff Davis. 26 November 2009, 21:20:12 UTC
280744d Added missing files. 26 November 2009, 15:55:57 UTC
c48d48d Forgot to add dynamic cursors to Changelog. 26 November 2009, 15:40:43 UTC
fb9d628 Synced addon rules after some renamings. 26 November 2009, 15:39:26 UTC
a160c42 Added dynamic cursor names to ecpg. Almost the whole patch was done by Boszormenyi Zoltan, with only a minor tweak or two from me. 26 November 2009, 15:06:47 UTC
da29cc8 Simplify psql's new linestyle behavior to default to linestyle=ascii all the time, rather than hoping we can tell whether the terminal supports UTF8 characters. Per discussion. 25 November 2009, 20:26:31 UTC
back to top