1. 07 May, 2011 3 commits
  2. 06 May, 2011 3 commits
    • Peter Eisentraut's avatar
      Improve compiler string shown in version() · 8dd2ede3
      Peter Eisentraut authored
      With some compilers such as Clang and ICC emulating GCC, using a
      version string of the form "GCC $version" can be quite misleading.
      Also, a great while ago, the version output from gcc --version started
      including the string "gcc", so it is redundant to repeat that.  In
      order to support ancient GCC versions, we now prefix the result with
      "GCC " only if the version output does not start with a letter.
      8dd2ede3
    • Tom Lane's avatar
      Move RegisterPredicateLockingXid() call to a safer place. · d2088ae9
      Tom Lane authored
      The SSI patch inserted a call of RegisterPredicateLockingXid into
      GetNewTransactionId, which was a bad idea on a couple of grounds.  First,
      it's not necessary to hold XidGenLock while manipulating that shared
      memory, and doing so is bad because XidGenLock is a high-contention lock
      that should be held for as short a time as possible.  (Not to mention that
      it adds an entirely unnecessary deadlock hazard, since we must take
      SerializableXactHashLock as well.)  Second, the specific place where it was
      put was between extending CLOG and advancing nextXid, which could result in
      unpleasant behavior in case of a failure there.  Pull the call out to
      AssignTransactionId, which is much safer and arguably better from a
      modularity standpoint too.
      
      There is more work to do to clean up the failure-before-advancing-nextXid
      issue, but that is a separate change that will need to be back-patched.
      So for the moment I just want to make GetNewTransactionId look the same as
      it did in prior versions.
      d2088ae9
    • Tom Lane's avatar
      Remove precedence labeling of keywords TRUE, FALSE, UNKNOWN, and ZONE. · 12b71645
      Tom Lane authored
      These were labeled with precedences just to avoid attaching explicit
      precedences to the productions in which they were the last terminal symbol.
      Since a terminal symbol precedence marking can affect many other things
      too, it seems like better practice to attach precedence labels to the
      productions, and not mark the terminal symbols.
      
      Ideally we'd also remove the precedence attached to NULL_P, but it turns
      out that we are actually depending on that having a precedence higher than
      POSTFIXOP, else we get a shift/reduce conflict for postfix operators in
      b_expr.  (Which more or less proves my point about these markings having a
      high risk of unexpected consequences.)  For the moment, move NULL_P into
      the set of keywords grouped with IDENT, so that at least it will act
      similarly to non-keywords; and document the interaction.
      12b71645
  3. 05 May, 2011 5 commits
  4. 04 May, 2011 5 commits
  5. 03 May, 2011 2 commits
  6. 02 May, 2011 5 commits
    • Alvaro Herrera's avatar
      Add ID attribute to some sect2's missing it · 155743ad
      Alvaro Herrera authored
      David Fetter
      155743ad
    • Tom Lane's avatar
      Fix pull_up_sublinks' failure to handle nested pull-up opportunities. · dcc685de
      Tom Lane authored
      After finding an EXISTS or ANY sub-select that can be converted to a
      semi-join or anti-join, we should recurse into the body of the sub-select.
      This allows cases such as EXISTS-within-EXISTS to be optimized properly.
      The original coding would leave the lower sub-select as a SubLink, which
      is no better and often worse than what we can do with a join.  Per example
      from Wayne Conrad.
      
      Back-patch to 8.4.  There is a related issue in older versions' handling
      of pull_up_IN_clauses, but they're lame enough anyway about the whole area
      that it seems not worth the extra work to try to fix.
      dcc685de
    • Alvaro Herrera's avatar
      Update some ALTER USER cross-references to ALTER ROLE · 52897e54
      Alvaro Herrera authored
      Greg Smith
      52897e54
    • Peter Eisentraut's avatar
      4b08bf8c
    • Tom Lane's avatar
      Improve aset.c's space management in contexts with small maxBlockSize. · 6755558b
      Tom Lane authored
      The previous coding would allow requests up to half of maxBlockSize to be
      treated as "chunks", but when that actually did happen, we'd waste nearly
      half of the space in the malloc block containing the chunk, if no smaller
      requests came along to fill it.  Avoid this scenario by limiting the
      maximum size of a chunk to 1/8th maxBlockSize, so that we can waste no more
      than 1/8th of the allocated space.  This will not change the behavior at
      all for the default context size parameters (with large maxBlockSize),
      but it will change the behavior when using ALLOCSET_SMALL_MAXSIZE.
      
      In particular, there's no longer a need for spell.c to be overly concerned
      about the request size parameters it uses, so remove a rather unhelpful
      comment about that.
      
      Merlin Moncure, per an idea of Tom Lane's
      6755558b
  7. 01 May, 2011 3 commits
    • Peter Eisentraut's avatar
      Catch errors in for loop in makefile · 5c436a79
      Peter Eisentraut authored
      Add "|| exit" so that the rule aborts when a command fails.
      5c436a79
    • Peter Eisentraut's avatar
      Rewrite installation makefile rules without for loops · b106195b
      Peter Eisentraut authored
      install-sh can install multiple files at once, so for loops are not
      necessary.  This was already changed for the rest of the code some
      time ago, but pgxs.mk was apparently forgotten, and the obsolete
      coding style has now been copied to the PLs as well.
      
      This also fixes the problem that the for loops in question did not
      catch errors.
      b106195b
    • Tom Lane's avatar
      Make CLUSTER lock the old table's toast table before copying data. · 83b75849
      Tom Lane authored
      We must lock out autovacuuming of the old toast table before computing the
      OldestXmin horizon we will use.  Otherwise, autovacuum could start on the
      toast table later, compute a later OldestXmin horizon, and remove as DEAD
      toast tuples that we still need (because we think their parent tuples are
      only RECENTLY_DEAD).  Per further thought about bug #5998.
      83b75849
  8. 30 Apr, 2011 1 commit
  9. 29 Apr, 2011 2 commits
    • Tom Lane's avatar
      Remove special case for xmin == xmax in HeapTupleSatisfiesVacuum(). · 44e4bbf7
      Tom Lane authored
      VACUUM was willing to remove a committed-dead tuple immediately if it was
      deleted by the same transaction that inserted it.  The idea is that such a
      tuple could never have been visible to any other transaction, so we don't
      need to keep it around to satisfy MVCC snapshots.  However, there was
      already an exception for tuples that are part of an update chain, and this
      exception created a problem: we might remove TOAST tuples (which are never
      part of an update chain) while their parent tuple stayed around (if it was
      part of an update chain).  This didn't pose a problem for most things,
      since the parent tuple is indeed dead: no snapshot will ever consider it
      visible.  But MVCC-safe CLUSTER had a problem, since it will try to copy
      RECENTLY_DEAD tuples to the new table.  It then has to copy their TOAST
      data too, and would fail if VACUUM had already removed the toast tuples.
      
      Easiest fix is to get rid of the special case for xmin == xmax.  This may
      delay reclaiming dead space for a little bit in some cases, but it's by far
      the most reliable way to fix the issue.
      
      Per bug #5998 from Mark Reid.  Back-patch to 8.3, which is the oldest
      version with MVCC-safe CLUSTER.
      44e4bbf7
    • Tom Lane's avatar
      Rewrite pg_size_pretty() to avoid compiler bug. · fd2e2d09
      Tom Lane authored
      Convert it to use successive shifts right instead of increasing a divisor.
      This is probably a tad more efficient than the original coding, and it's
      nicer-looking than the previous patch because we don't need a special case
      to avoid overflow in the last branch.  But the real reason to do it is to
      avoid a Solaris compiler bug, as per results from buildfarm member moa.
      fd2e2d09
  10. 28 Apr, 2011 4 commits
  11. 27 Apr, 2011 7 commits
    • Tom Lane's avatar
      Tag 9.1beta1. · 993c5e59
      Tom Lane authored
      993c5e59
    • Tom Lane's avatar
      Make a quick copy-editing pass over the 9.1 release notes. · bb1051eb
      Tom Lane authored
      Also remove the material about this being an alpha release.
      
      The notes still need a lot of work, but they're more or less presentable
      as a beta version now.
      bb1051eb
    • Peter Eisentraut's avatar
      Fix binary upgrade of altered typed tables · b2ef8929
      Peter Eisentraut authored
      Instead of dumping them as CREATE TABLE ... OF, dump them as normal
      tables with the usual special processing for dropped columns, and then
      attach them to the type afterward, using ALTER TABLE ... OF.  This is
      analogous to the existing handling of inherited tables.
      b2ef8929
    • Andrew Dunstan's avatar
      Revert "Force use of "%I64d" format for 64 bit ints on MinGW." · 6693fec0
      Andrew Dunstan authored
      This reverts commit 52d01c2f.
      
      the UINT64_FORMAT bit broke the b uildfarm, so I'm reverting the whole thing pending further investigation.
      6693fec0
    • Magnus Hagander's avatar
      timeline is not needed in BaseBackup() · 6693eb72
      Magnus Hagander authored
      This code was accidentally part of the patch, it's only
      needed for the code that's for 9.2. Not needing the timeline
      also removes the need to call IDENTIFY_SYSTEM.
      
      Noted by Peter E.
      6693eb72
    • Tom Lane's avatar
      Add comments about the need to avoid uninitialized bits in datatype values. · 4f6c75b5
      Tom Lane authored
      There was already one recommendation in the documentation about writing
      C functions to ensure padding bytes are zeroes, but make it stronger.
      
      Also fix an example that was still using direct assignment to a varlena
      length word, which no longer works since the varvarlena changes.
      4f6c75b5
    • Tom Lane's avatar
      Fix array- and path-creating functions to ensure padding bytes are zeroes. · 18c0b4ec
      Tom Lane authored
      Per recent discussion, it's important for all computed datums (not only the
      results of input functions) to not contain any ill-defined (uninitialized)
      bits.  Failing to ensure that can result in equal() reporting that
      semantically indistinguishable Consts are not equal, which in turn leads to
      bizarre and undesirable planner behavior, such as in a recent example from
      David Johnston.  We might eventually try to fix this in a general manner by
      allowing datatypes to define identity-testing functions, but for now the
      path of least resistance is to expect datatypes to force all unused bits
      into consistent states.
      
      Per some testing by Noah Misch, array and path functions seem to be the
      only ones presenting risks at the moment, so I looked through all the
      functions in adt/array*.c and geo_ops.c and fixed them as necessary.  In
      the array functions, the easiest/safest fix is to allocate result arrays
      with palloc0 instead of palloc.  Possibly in future someone will want to
      look into whether we can just zero the padding bytes, but that looks too
      complex for a back-patchable fix.  In the path functions, we already had a
      precedent in path_in for just zeroing the one known pad field, so duplicate
      that code as needed.
      
      Back-patch to all supported branches.
      18c0b4ec