1. 16 Nov, 2011 2 commits
    • Tom Lane's avatar
      Code review for range-types catalog entries. · 4509033a
      Tom Lane authored
      Fix assorted infelicities, such as dependency on OIDs that aren't
      hardwired, as well as outright misdeclaration of daterange_canonical(),
      which resulted in crashes if you invoked it directly.  Add some more
      regression tests to try to catch similar mistakes in future.
      4509033a
    • Robert Haas's avatar
      Don't elide blank lines when accumulating psql command history. · ff4fd4bf
      Robert Haas authored
      This can change the meaning of queries, if the blank line happens to
      occur in the middle of a quoted literal, as per complaint from Tomas Vondra.
      
      Back-patch to all supported branches.
      ff4fd4bf
  2. 15 Nov, 2011 4 commits
    • Tom Lane's avatar
      Improve caching in range type I/O functions. · 04da3232
      Tom Lane authored
      Cache the the element type's I/O info across calls, not only the range
      type's info.  In passing, also clean up hash_range a bit more.
      04da3232
    • Tom Lane's avatar
      Restructure function-internal caching in the range type code. · 37ee4b75
      Tom Lane authored
      Move the responsibility for caching specialized information about range
      types into the type cache, so that the catalog lookups only have to occur
      once per session.  Rearrange APIs a bit so that fn_extra caching is
      actually effective in the GiST support code.  (Use of OidFunctionCallN is
      bad enough for performance in itself, but it also prevents the function
      from exploiting fn_extra caching.)
      
      The range I/O functions are still not very bright about caching repeated
      lookups, but that seems like material for a separate patch.
      
      Also, avoid unnecessary use of memcpy to fetch/store the range type OID and
      flags, and don't use the full range_deserialize machinery when all we need
      to see is the flags value.
      
      Also fix API error in range_gist_penalty --- it was failing to set *penalty
      for any case involving an empty range.
      37ee4b75
    • Tom Lane's avatar
      Fix alignment and toasting bugs in range types. · ad50934e
      Tom Lane authored
      A range type whose element type has 'd' alignment must have 'd' alignment
      itself, else there is no guarantee that the element value can be used
      in-place.  (Because range_deserialize uses att_align_pointer which forcibly
      aligns the given pointer, violations of this rule did not lead to SIGBUS
      but rather to garbage data being extracted, as in one of the added
      regression test cases.)
      
      Also, you can't put a toast pointer inside a range datum, since the
      referenced value could disappear with the range datum still present.
      For consistency with the handling of arrays and records, I also forced
      decompression of in-line-compressed bound values.  It would work to store
      them as-is, but our policy is to avoid situations that might result in
      double compression.
      
      Add assorted regression tests for this, and bump catversion because of
      fixes to built-in pg_type entries.
      
      Also some marginal cleanup of inconsistent/unnecessary error checks.
      ad50934e
    • Tom Lane's avatar
      Update oidjoins regression test to match git HEAD. · 4165d5b6
      Tom Lane authored
      This is mostly to add some sanity checking for the pg_range catalog.
      4165d5b6
  3. 14 Nov, 2011 5 commits
    • Tom Lane's avatar
      Return NULL instead of throwing error when desired bound is not available. · 4f9e3306
      Tom Lane authored
      Change range_lower and range_upper to return NULL rather than throwing an
      error when the input range is empty or the relevant bound is infinite.  Per
      discussion, throwing an error seems likely to be unduly hard to work with.
      Also, this is more consistent with the behavior of the constructors, which
      treat NULL as meaning an infinite bound.
      4f9e3306
    • Tom Lane's avatar
      Return FALSE instead of throwing error for comparisons with empty ranges. · 851c83fc
      Tom Lane authored
      Change range_before, range_after, range_adjacent to return false rather
      than throwing an error when one or both input ranges are empty.
      
      The original definition is unnecessarily difficult to use, and also can
      result in undesirable planner failures since the planner could try to
      compare an empty range to something else while deriving statistical
      estimates.  (This was, in fact, the cause of repeatable regression test
      failures on buildfarm member jaguar, as well as intermittent failures
      elsewhere.)
      
      Also tweak rangetypes regression test to not drop all the objects it
      creates, so that the final state of the regression database contains
      some rangetype objects for pg_dump testing.
      851c83fc
    • Tom Lane's avatar
      Fix copyright notices, other minor editing in new range-types code. · f1585362
      Tom Lane authored
      No functional changes in this commit (except I could not resist the
      temptation to re-word a couple of error messages).  This is just manual
      cleanup after pgindent to make the code look reasonably like other PG
      code, in preparation for more detailed code review to come.
      f1585362
    • Bruce Momjian's avatar
      Rerun pgindent with updated typedef list. · 1a2586c1
      Bruce Momjian authored
      1a2586c1
    • Bruce Momjian's avatar
      cdaa45fd
  4. 13 Nov, 2011 2 commits
  5. 12 Nov, 2011 4 commits
  6. 10 Nov, 2011 7 commits
  7. 09 Nov, 2011 8 commits
    • Peter Eisentraut's avatar
    • Heikki Linnakangas's avatar
      Fix bugs in the COPY heap-insert batching patch. · f81648cb
      Heikki Linnakangas authored
      Forgot to call RestoreBkpBlocks() in the redo-function, as pointed out by
      Simon Riggs. In redo of a regular heap insert, it's taken care of in
      heap_redo(), but this new record type uses the heap2 RM, and heap2_redo()
      does not take care of that for you.
      
      Also, failed to reset the vmbuffer and all_visibile_cleared local variables
      after switching to a new buffer.
      f81648cb
    • Peter Eisentraut's avatar
      Clean gettext-files file in clean target · 3ad2c8e1
      Peter Eisentraut authored
      It used to be cleaned in maintainer-clean, but that is inconsistent
      with other cleaning of NLS files in nls-global.mk, and it's also wrong
      overall, because it's not part of the distribution tarball, which is
      the base definition of the maintainer-clean target.
      3ad2c8e1
    • Robert Haas's avatar
      Fix compiler warning. · 452d1d19
      Robert Haas authored
      452d1d19
    • Heikki Linnakangas's avatar
      In COPY, insert tuples to the heap in batches. · d326d9e8
      Heikki Linnakangas authored
      This greatly reduces the WAL volume, especially when the table is narrow.
      The overhead of locking the heap page is also reduced. Reduced WAL traffic
      also makes it scale a lot better, if you run multiple COPY processes at
      the same time.
      d326d9e8
    • Tom Lane's avatar
      Tweak new regression test case for more portability. · 2c30f961
      Tom Lane authored
      Ensure that same index gets selected on 32-bit and 64-bit machines.
      Per buildfarm results.
      2c30f961
    • Tom Lane's avatar
      Fix random discrepancies between parallel_schedule and serial_schedule. · 6d295b64
      Tom Lane authored
      In particular, my previous patch expected the create_index test to run
      before the inherit test; but this was only true in the serial schedule.
      Rearrange this portion of the schedules to be more consistent.
      
      Per buildfarm results.
      6d295b64
    • Tom Lane's avatar
      Wrap appendrel member outputs in PlaceHolderVars in additional cases. · 57664ed2
      Tom Lane authored
      Add PlaceHolderVar wrappers as needed to make UNION ALL sub-select output
      expressions appear non-constant and distinct from each other.  This makes
      the world safe for add_child_rel_equivalences to do what it does.  Before,
      it was possible for that function to add identical expressions to different
      EquivalenceClasses, which logically should imply merging such ECs, which
      would be wrong; or to improperly add a constant to an EquivalenceClass,
      drastically changing its behavior.  Per report from Teodor Sigaev.
      
      The only currently known consequence of this bug is "MergeAppend child's
      targetlist doesn't match MergeAppend" planner failures in 9.1 and later.
      I am suspicious that there may be other failure modes that could affect
      older release branches; but in the absence of any hard evidence, I'll
      refrain from back-patching further than 9.1.
      57664ed2
  8. 08 Nov, 2011 7 commits
  9. 07 Nov, 2011 1 commit