1. 04 Mar, 2012 4 commits
    • Tom Lane's avatar
      Improve histogram-filling loop in new compute_array_stats() code. · 4fb694ae
      Tom Lane authored
      Do "frac" arithmetic in int64 to prevent overflow with large statistics
      targets, and improve the comments so people have some chance of
      understanding how it works.
      
      Alexander Korotkov and Tom Lane
      4fb694ae
    • Magnus Hagander's avatar
      More carefully validate xlog location string inputs · 141b8982
      Magnus Hagander authored
      Now that we have validate_xlog_location, call it from the previously
      existing functions taking xlog locatoins as a string input.
      
      Suggested by Fujii Masao
      141b8982
    • Magnus Hagander's avatar
      Add function pg_xlog_location_diff to help comparisons · bc5ac368
      Magnus Hagander authored
      Comparing two xlog locations are useful for example when calculating
      replication lag.
      
      Euler Taveira de Oliveira, reviewed by Fujii Masao, and some cleanups
      from me
      bc5ac368
    • Tom Lane's avatar
      Collect and use element-frequency statistics for arrays. · 0e5e167a
      Tom Lane authored
      This patch improves selectivity estimation for the array <@, &&, and @>
      (containment and overlaps) operators.  It enables collection of statistics
      about individual array element values by ANALYZE, and introduces
      operator-specific estimators that use these stats.  In addition,
      ScalarArrayOpExpr constructs of the forms "const = ANY/ALL (array_column)"
      and "const <> ANY/ALL (array_column)" are estimated by treating them as
      variants of the containment operators.
      
      Since we still collect scalar-style stats about the array values as a
      whole, the pg_stats view is expanded to show both these stats and the
      array-style stats in separate columns.  This creates an incompatible change
      in how stats for tsvector columns are displayed in pg_stats: the stats
      about lexemes are now displayed in the array-related columns instead of the
      original scalar-related columns.
      
      There are a few loose ends here, notably that it'd be nice to be able to
      suppress either the scalar-style stats or the array-element stats for
      columns for which they're not useful.  But the patch is in good enough
      shape to commit for wider testing.
      
      Alexander Korotkov, reviewed by Noah Misch and Nathan Boley
      0e5e167a
  2. 03 Mar, 2012 2 commits
  3. 02 Mar, 2012 7 commits
    • Peter Eisentraut's avatar
      Fix incorrect uses of gzFile · d923125b
      Peter Eisentraut authored
      gzFile is already a pointer, so code like
      
      gzFile *handle = gzopen(...)
      
      is wrong.
      
      This used to pass silently because gzFile used to be defined as void*,
      and you can assign a void* to a void**.  But somewhere between zlib
      versions 1.2.3.4 and 1.2.6, the definition of gzFile was changed to
      struct gzFile_s *, and with that new definition this usage causes
      compiler warnings.
      
      So remove all those extra pointer decorations.
      
      There is a related issue in pg_backup_archiver.h, where
      
      FILE       *FH;             /* General purpose file handle */
      
      is used throughout pg_dump as sometimes a real FILE* and sometimes a
      gzFile handle, which also causes warnings now.  This is not yet fixed
      here, because it might need more code restructuring.
      d923125b
    • Peter Eisentraut's avatar
      Re-add "make check" target in src/test/isolation/Makefile · 8e5f4300
      Peter Eisentraut authored
      This effectively reverts 7886cc73,
      which was done under the impression that isolationtester needs libpq,
      which it no longer does (and never really did).
      8e5f4300
    • Tom Lane's avatar
      Allow child-relation entries to be made in ec_has_const EquivalenceClasses. · 44634e47
      Tom Lane authored
      This fixes an oversight in commit 11cad29c,
      which introduced MergeAppend plans.  Before that happened, we never
      particularly cared about the sort ordering of scans of inheritance child
      relations, since appending their outputs together would destroy any
      ordering anyway.  But now it's important to be able to match child relation
      sort orderings to those of the surrounding query.  The original coding of
      add_child_rel_equivalences skipped ec_has_const EquivalenceClasses, on the
      originally-correct grounds that adding child expressions to them was
      useless.  The effect of this is that when a parent variable is equated to
      a constant, we can't recognize that index columns on the equivalent child
      variables are not sort-significant; that is, we can't recognize that a
      child index on, say, (x, y) is able to generate output in "ORDER BY y"
      order when there is a clause "WHERE x = constant".  Adding child
      expressions to the (x, constant) EquivalenceClass fixes this, without any
      downside that I can see other than a few more planner cycles expended on
      such queries.
      
      Per recent gripe from Robert McGehee.  Back-patch to 9.1 where MergeAppend
      was introduced.
      44634e47
    • Peter Eisentraut's avatar
      Add COLLATION FOR expression · 6688d287
      Peter Eisentraut authored
      reviewed by Jaime Casanova
      6688d287
    • Peter Eisentraut's avatar
      ecpg: Clean up some const usage · d41f510c
      Peter Eisentraut authored
      d41f510c
    • Magnus Hagander's avatar
      Add a rule to optionally build docs with the stylesheet from the website · 8efb0bc5
      Magnus Hagander authored
      For those of us who prefer the formatting of the docs using the
      website stylesheets. Use "make STYLE=website draft" (for example) to use.
      
      The stylesheet itself is referenced directly to the website, so there
      is currently no copy of it stored in the source repository. Thus, docs
      built with it will only look correct if the browser can access the website
      when viewing them.
      8efb0bc5
    • Heikki Linnakangas's avatar
      When a GiST page is split during index build, it might not have a buffer. · 2502f459
      Heikki Linnakangas authored
      Previously it was thought that it's impossible as the code stands, because
      insertions create buffers as tuples are cascaded downwards, and index
      split also creaters buffers eagerly for all halves. But the example from
      Jay Levitt demonstrates that it can happen, when the root page is split.
      It's in fact OK if the buffer doesn't exist, so we just need to remove the
      sanity check. In fact, we've been discussing the possibility of destroying
      empty buffers to conserve memory, which would render the sanity check
      completely useless anyway.
      
      Fix by Alexander Korotkov
      2502f459
  4. 01 Mar, 2012 4 commits
    • Peter Eisentraut's avatar
      Small possible clarification in pg_basebackup reference page · bc8765e9
      Peter Eisentraut authored
      The <literal> markup is not visible as distinct on man pages, which
      creates a bit of confusion when looking at the documentation of the
      pg_basebackup -l option.  Rather than reinventing the entire font
      system for man pages to remedy this, just put some quotes around this
      particular case, which should also help in other output formats.
      bc8765e9
    • Peter Eisentraut's avatar
      Don't link pg_isolation_regress with libpq · 36a1a8c3
      Peter Eisentraut authored
      It's not necessary and can only create confusion about which libpq
      installation should be used.
      
      Also remove some dead code from the makefile that was apparently
      copied from elsewhere.
      36a1a8c3
    • Peter Eisentraut's avatar
      psql: Improve error display for psql -f - · 89c2f573
      Peter Eisentraut authored
      Running "psql -f -" used to print
      
      psql:<stdin>:1: ERROR:  blah
      
      but that got broken between 8.4 and 9.0 (commit
      b291c0fb), and now it printed
      
      psql:-:1: ERROR:  blah
      
      This reverts to the old behavior and cleans up some code that was left
      dead or useless by the mentioned commit.
      89c2f573
    • Alvaro Herrera's avatar
      Remove TOAST table from pg_database · 3433c6ba
      Alvaro Herrera authored
      The only toastable column now is datacl, but we don't really support
      long ACLs anyway.  The TOAST table should have been removed when the
      pg_db_role_setting catalog was introduced in commit
      2eda8dfb, but I forgot to do that.
      
      Per -hackers discussion on March 2011.
      3433c6ba
  5. 29 Feb, 2012 5 commits
    • Tom Lane's avatar
      Simplify references to backslash-doubling in func.sgml. · a5c1a196
      Tom Lane authored
      Several places were still written as though standard_conforming_strings
      didn't exist, much less be the default.  Now that it is on by default,
      we can simplify the text and just insert occasional notes suggesting that
      you might have to think harder if it's turned off.  Per discussion of a
      suggestion from Hannes Frederic Sowa.
      
      Back-patch to 9.1 where standard_conforming_strings was made the default.
      a5c1a196
    • Heikki Linnakangas's avatar
      Correctly detect SSI conflicts of prepared transactions after crash. · d6a72719
      Heikki Linnakangas authored
      A prepared transaction can get new conflicts in and out after preparing, so
      we cannot rely on the in- and out-flags stored in the statefile at prepare-
      time. As a quick fix, make the conservative assumption that after a restart,
      all prepared transactions are considered to have both in- and out-conflicts.
      That can lead to unnecessary rollbacks after a crash, but that shouldn't be
      a big problem in practice; you don't want prepared transactions to hang
      around for a long time anyway.
      
      Dan Ports
      d6a72719
    • Tom Lane's avatar
      Fix MSVC builds for previous patch's addition of a src/port file. · 8cae5810
      Tom Lane authored
      (And why in the world is this OBJS list not being scraped from the
      corresponding Makefile?)
      8cae5810
    • Alvaro Herrera's avatar
      Fix typo in comment · 58e9f974
      Alvaro Herrera authored
      Haifeng Liu
      58e9f974
    • Tom Lane's avatar
      Move CRC tables to libpgport, and provide them in a separate include file. · 5c02a00d
      Tom Lane authored
      This makes it much more convenient to build tools for Postgres that are
      separately compiled and require a matching CRC implementation.
      
      To prevent multiple copies of the CRC polynomial tables being introduced
      into the postgres binaries, they are now included in the static library
      libpgport that is mainly meant for replacement system functions.  That
      seems like a bit of a kludge, but there's no better place.
      
      This cleans up building of the tools pg_controldata and pg_resetxlog,
      which previously had to build their own copies of pg_crc.o.
      
      In the future, external programs that need access to the CRC tables can
      include the tables directly from the new header file pg_crc_tables.h.
      
      Daniel Farina, reviewed by Abhijit Menon-Sen and Tom Lane
      5c02a00d
  6. 28 Feb, 2012 3 commits
    • Tom Lane's avatar
      Fix thinko in new match_join_clauses_to_index() logic. · 0140a11b
      Tom Lane authored
      We don't need to constrain the other side of an indexable join clause to
      not be below an outer join; an example here is
      
      SELECT FROM t1 LEFT JOIN t2 ON t1.a = t2.b LEFT JOIN t3 ON t2.c = t3.d;
      
      We can consider an inner indexscan on t3.d using c = d as indexqual, even
      though t2.c is potentially nulled by a previous outer join.  The comparable
      logic in orindxpath.c has always worked that way, but I was being overly
      cautious here.
      0140a11b
    • Peter Eisentraut's avatar
      Add const qualifiers where they are accidentally cast away · 973e9fb2
      Peter Eisentraut authored
      This only produces warnings under -Wcast-qual, but it's more correct
      and consistent in any case.
      973e9fb2
    • Alvaro Herrera's avatar
      psql: when tab-completing, use quotes on file names that need them · 41e3c94c
      Alvaro Herrera authored
      psql backslash commands that deal with file or directory names require
      quotes around those that have spaces, single quotes, or backslashes.
      However, tab-completing such names does not provide said quotes, and is
      thus almost useless with them.
      
      This patch fixes the problem by having a wrapper function around
      rl_filename_completion_function that dequotes on input and quotes on
      output.  This eases dealing with such names.
      
      Author: Noah Misch
      41e3c94c
  7. 27 Feb, 2012 2 commits
    • Alvaro Herrera's avatar
      ALTER TABLE: skip FK validation when it's safe to do so · cb3a7c2b
      Alvaro Herrera authored
      We already skip rewriting the table in these cases, but we still force a
      whole table scan to validate the data.  This can be skipped, and thus
      we can make the whole ALTER TABLE operation just do some catalog touches
      instead of scanning the table, when these two conditions hold:
      
      (a) Old and new pg_constraint.conpfeqop match exactly.  This is actually
      stronger than needed; we could loosen things by way of operator
      families, but it'd require a lot more effort.
      
      (b) The functions, if any, implementing a cast from the foreign type to
      the primary opcintype are the same.  For this purpose, we can consider a
      binary coercion equivalent to an exact type match.  When the opcintype
      is polymorphic, require that the old and new foreign types match
      exactly.  (Since ri_triggers.c does use the executor, the stronger check
      for polymorphic types is no mere future-proofing.  However, no core type
      exercises its necessity.)
      
      Author: Noah Misch
      
      Committer's note: catalog version bumped due to change of the Constraint
      node.  I can't actually find any way to have such a node in a stored
      rule, but given that we have "out" support for them, better be safe.
      cb3a7c2b
    • Peter Eisentraut's avatar
      Call check_keywords.pl in maintainer-check · 9bf8603c
      Peter Eisentraut authored
      For that purpose, have check_keywords.pl print errors to stderr and
      return a useful exit status.
      9bf8603c
  8. 26 Feb, 2012 3 commits
    • Tom Lane's avatar
      Fix some more bugs in GIN's WAL replay logic. · 1b630751
      Tom Lane authored
      In commit 4016bdef I fixed a bunch of
      ginxlog.c bugs having to do with not handling XLogReadBuffer failures
      correctly.  However, in ginRedoUpdateMetapage and ginRedoDeleteListPages,
      I unaccountably thought that failure to read the metapage would be
      impossible and just put in an elog(PANIC) call.  This is of course wrong:
      failure is exactly what will happen if the index got dropped (or rebuilt)
      between creation of the WAL record and the crash we're trying to recover
      from.  I believe this explains Nicholas Wilson's recent report of these
      errors getting reached.
      
      Also, fix memory leak in forgetIncompleteSplit.  This wasn't of much
      concern when the code was written, but in a long-running standby server
      page split records could be expected to accumulate indefinitely.
      
      Back-patch to 8.4 --- before that, GIN didn't have a metapage.
      1b630751
    • Peter Eisentraut's avatar
      Remove useless cast · b5c077c3
      Peter Eisentraut authored
      b5c077c3
    • Peter Eisentraut's avatar
      Remove useless const qualifier · 66f0cf7d
      Peter Eisentraut authored
      Claiming that the typevar argument to DefineCompositeType() is const
      was a plain lie.  A similar case in DefineVirtualRelation() was
      already changed in passing in commit 1575fbcb.  Also clean up the now
      unnecessary casts that used to cast away the const.
      66f0cf7d
  9. 25 Feb, 2012 3 commits
  10. 24 Feb, 2012 7 commits
    • Tom Lane's avatar
      Merge dissect() into cdissect() to remove a pile of near-duplicate code. · 4dd78bf3
      Tom Lane authored
      The "uncomplicated" case isn't materially less complicated than the full
      case, certainly not enough so to justify duplicating nearly 500 lines
      of code.  The only extra work being done in the full path is zaptreesubs,
      which is very cheap compared to everything else being done here, and
      besides that I'm less than convinced that it's not needed in some cases
      even without backrefs.
      4dd78bf3
    • Tom Lane's avatar
      Avoid repeated creation/freeing of per-subre DFAs during regex search. · 58735947
      Tom Lane authored
      In nested sub-regex trees, lower-level nodes created DFAs and then
      destroyed them again before exiting, which is a bit dumb considering that
      the recursive search is likely to call those nodes again later.  Instead
      cache each created DFA until the end of pg_regexec().  This is basically a
      space for time tradeoff, in that it might increase the maximum memory
      usage.  However, in most regex patterns there are not all that many subre
      nodes, so not that many DFAs --- and in any case, the peak usage occurs
      when reaching the bottom recursion level, and except for alternation cases
      that's going to be the same anyway.
      58735947
    • Tom Lane's avatar
      Remove useless "retry memory" logic within regex engine. · 3cbfe485
      Tom Lane authored
      Apparently some primordial version of Spencer's engine needed cdissect()
      and child functions to be able to continue matching from a previous
      position when re-called.  That is dead code, though, since trivial
      inspection shows that cdissect can never be entered without having
      previously done zapmem which resets the relevant retry counter.  I have
      also verified experimentally that no case in the Tcl regression tests
      reaches cdissect with a nonzero retry value.  Accordingly, remove that
      logic.  This doesn't really save any noticeable number of cycles in itself,
      but it is one step towards making dissect() and cdissect() equivalent,
      which will allow removing hundreds of lines of near-duplicated code.
      
      Since struct subre's "retry" field is no longer particularly related to
      any kind of retry, rename it to "id".  As of this commit it's only used
      for identifying a subre node in debug printouts, so you might think we
      should get rid of the field entirely; but I have a plan for another use.
      3cbfe485
    • Bruce Momjian's avatar
      Mention original ctags option name. · 1fbacbf9
      Bruce Momjian authored
      1fbacbf9
    • Bruce Momjian's avatar
      Update src/tools/make_ctags to avoid Exuberant tags option · 7c19f9d1
      Bruce Momjian authored
      that has been renamed and undocumented since 2003;  instead, use the
      documented option.  Add comments.
      7c19f9d1
    • Peter Eisentraut's avatar
      3aa42c25
    • Peter Eisentraut's avatar
      9cfd800a