1. 01 Sep, 2011 10 commits
    • Michael Meskes's avatar
      63d06ef5
    • Robert Haas's avatar
      Minor improvements to mbregress.sh script. · 48fb49e3
      Robert Haas authored
      1. Use new dropdb --if-exists option, to avoid alarming the user if
         the database being dropped doesn't already exist.
      2. Bail out if createdb fails.
      3. exit 1 if the checks fail.
      4. Make it executable.
      
      Josh Kupershmidt, with some kibitzing by me.
      48fb49e3
    • Robert Haas's avatar
      Userspace access vector cache for contrib/sepgsql. · 4232c4b4
      Robert Haas authored
      KaiGai Kohei
      4232c4b4
    • Robert Haas's avatar
      Fix "is db labeled test?" in chkselinuxenv script. · 3d14bd25
      Robert Haas authored
      Don't test whether the number of labels is numerically equal to zero;
      count(*) isn't going return zero anyway, and the current coding blows
      up if it returns an empty string or an error.
      3d14bd25
    • Bruce Momjian's avatar
      Remove "fmgr.h" include in cube contrib --- caused crash on a Gentoo · d5321842
      Bruce Momjian authored
      builfarm member.
      d5321842
    • Heikki Linnakangas's avatar
      Fix MinGW build, broken by my previous patch to add a setlocale() wrapper · 65e899b2
      Heikki Linnakangas authored
      on Windows. ecpglib doesn't link with libpgport, but picks and compiles
      the .c files it needs individually. To cope with that, move the setlocale()
      wrapper from chklocale.c to a separate setlocale.c file, and include that
      in ecpglib.
      65e899b2
    • Heikki Linnakangas's avatar
      setlocale() on Windows doesn't work correctly if the locale name contains · a88b6e4c
      Heikki Linnakangas authored
      dots. I previously worked around this in initdb, mapping the known
      problematic locale names to aliases that work, but Hiroshi Inoue pointed
      out that that's not enough because even if you use one of the aliases, like
      "Chinese_HKG", setlocale(LC_CTYPE, NULL) returns back the long form, ie.
      "Chinese_Hong Kong S.A.R.". When we try to restore an old locale value by
      passing that value back to setlocale(), it fails. Note that you are affected
      by this bug also if you use one of those short-form names manually, so just
      reverting the hack in initdb won't fix it.
      
      To work around that, move the locale name mapping from initdb to a wrapper
      around setlocale(), so that the mapping is invoked on every setlocale() call.
      
      Also, add a few checks for failed setlocale() calls in the backend. These
      calls shouldn't fail, and if they do there isn't much we can do about it,
      but at least you'll get a warning.
      
      Backpatch to 9.1, where the initdb hack was introduced. The Windows bug
      affects older versions too if you set locale manually to one of the aliases,
      but given the lack of complaints from the field, I'm hesitent to backpatch.
      a88b6e4c
    • Heikki Linnakangas's avatar
      Move the line to undefine setlocale() macro on Win32 outside USE_REPL_SNPRINTF · 8ea02570
      Heikki Linnakangas authored
      ifdef block. It has nothing to do with whether the replacement snprintf
      function is used. It caused no live bug, because the replacement snprintf
      function is always used on Win32, but it was nevertheless misplaced.
      8ea02570
    • Tom Lane's avatar
      Further repair of eqjoinsel ndistinct-clamping logic. · 0d3b231e
      Tom Lane authored
      Examination of examples provided by Mark Kirkwood and others has convinced
      me that actually commit 7f3eba30 was quite
      a few bricks shy of a load.  The useful part of that patch was clamping
      ndistinct for the inner side of a semi or anti join, and the reason why
      that's needed is that it's the only way that restriction clauses
      eliminating rows from the inner relation can affect the estimated size of
      the join result.  I had not clearly understood why the clamping was
      appropriate, and so mis-extrapolated to conclude that we should clamp
      ndistinct for the outer side too, as well as for both sides of regular
      joins.  These latter actions were all wrong, and are reverted with this
      patch.  In addition, the clamping logic is now made to affect the behavior
      of both paths in eqjoinsel_semi, with or without MCV lists to compare.
      When we have MCVs, we suppose that the most common values are the ones
      that are most likely to survive the decimation resulting from a lower
      restriction clause, so we think of the clamping as eliminating non-MCV
      values, or potentially even the least-common MCVs for the inner relation.
      
      Back-patch to 8.4, same as previous fixes in this area.
      0d3b231e
    • Bruce Momjian's avatar
      Fix pg_upgrade to preserve toast relfrozenxids for old 8.3 servers. · 7971a57f
      Bruce Momjian authored
      This fixes a pg_upgrade bug that could lead to query errors when
      clog files are improperly removed.
      
      Backpatch to 8.4, 9.0, 9.1.
      7971a57f
  2. 31 Aug, 2011 2 commits
    • Tom Lane's avatar
      Improve eqjoinsel's ndistinct clamping to work for multiple levels of join. · 97930cf5
      Tom Lane authored
      This patch fixes an oversight in my commit
      7f3eba30 of 2008-10-23.  That patch
      accounted for baserel restriction clauses that reduced the number of rows
      coming out of a table (and hence the number of possibly-distinct values of
      a join variable), but not for join restriction clauses that might have been
      applied at a lower level of join.  To account for the latter, look up the
      sizes of the min_lefthand and min_righthand inputs of the current join,
      and clamp with those in the same way as for the base relations.
      
      Noted while investigating a complaint from Ben Chobot, although this in
      itself doesn't seem to explain his report.
      
      Back-patch to 8.4; previous versions used different estimation methods
      for which this heuristic isn't relevant.
      97930cf5
    • Heikki Linnakangas's avatar
      The replication status values in pg_stat_replication was changed to · 5cfe33fe
      Heikki Linnakangas authored
      lowercase earlier, but documentation was not updated. Update the docs.
      
      Fujii Masao
      5cfe33fe
  3. 30 Aug, 2011 9 commits
    • Tom Lane's avatar
      Fix not-backwards-compatible pg_upgrade test for prepared transactions. · 731ebb64
      Tom Lane authored
      There's no reason for this test to use the undocumented pg_prepared_xact()
      function, when it can use the stable API pg_prepared_xacts instead.
      Fixes breakage against 8.3, as reported by Justin Arnold.
      731ebb64
    • Tom Lane's avatar
      Fix a missed case in code for "moving average" estimate of reltuples. · 5bba65de
      Tom Lane authored
      It is possible for VACUUM to scan no pages at all, if the visibility map
      shows that all pages are all-visible.  In this situation VACUUM has no new
      information to report about the relation's tuple density, so it wasn't
      changing pg_class.reltuples ... but it updated pg_class.relpages anyway.
      That's wrong in general, since there is no evidence to justify changing the
      density ratio reltuples/relpages, but it's particularly bad if the previous
      state was relpages=reltuples=0, which means "unknown tuple density".
      We just replaced "unknown" with "zero".  ANALYZE would eventually recover
      from this, but it could take a lot of repetitions of ANALYZE to do so if
      the relation size is much larger than the maximum number of pages ANALYZE
      will scan, because of the moving-average behavior introduced by commit
      b4b6923e.
      
      The only known situation where we could have relpages=reltuples=0 and yet
      the visibility map asserts everything's visible is immediately following
      a pg_upgrade.  It might be advisable for pg_upgrade to try to preserve the
      relpages/reltuples statistics; but in any case this code is wrong on its
      own terms, so fix it.  Per report from Sergey Koposov.
      
      Back-patch to 8.4, where the visibility map was introduced, same as the
      previous change.
      5bba65de
    • Peter Eisentraut's avatar
      Clean up pg_regress --help output · b83bb97f
      Peter Eisentraut authored
      Put options listing in a less random order, fix capitalization, and
      some typos.
      b83bb97f
    • Peter Eisentraut's avatar
      Some markup cleanup to deconfuse the find_gt_lt tool · aeabbcce
      Peter Eisentraut authored
      Josh Kupershmidt
      aeabbcce
    • Robert Haas's avatar
    • Robert Haas's avatar
      Add --if-exists option to dropdb and dropuser. · 7fe33a51
      Robert Haas authored
      Josh Kupershmidt, with some further editing by me.
      7fe33a51
    • Andrew Dunstan's avatar
      Detect out of date flex in MSVC builds. · 94478aa8
      Andrew Dunstan authored
      Per recent discussion, following a report from Quan Zongliang.
      The same logic is used as in pgbison.pl.
      94478aa8
    • Robert Haas's avatar
      Fix parsing of time string followed by yesterday/today/tomorrow. · 8a3d33c8
      Robert Haas authored
      Previously, 'yesterday 04:00:00'::timestamp didn't do the same thing as
      '04:00:00 yesterday'::timestamp, and the return value from the latter
      was midnight rather than the specified time.
      
      Dean Rasheed, with some stylistic changes
      8a3d33c8
    • Robert Haas's avatar
      Remove some tabs from README file. · eab2ef61
      Robert Haas authored
      Some of the ASCII art expected 8-space tab stops, and some of it
      expected 4-space tab stops.
      
      Per report from YAMAMOTO Takashi.
      eab2ef61
  4. 29 Aug, 2011 5 commits
    • Tom Lane's avatar
      Fix concat_ws() to not insert a separator after leading NULL argument(s). · a5b7640b
      Tom Lane authored
      Per bug #6181 from Itagaki Takahiro.  Also do some marginal code cleanup
      and improve error handling.
      a5b7640b
    • Tom Lane's avatar
      Use a non-locking test in TAS_SPIN() on all IA64 platforms. · be1e8053
      Tom Lane authored
      Per my testing, this works just as well with gcc as it does with HP's
      compiler; and there is no reason to think that the effect doesn't occur
      with icc, either.
      
      Also, rewrite the header comment about enforcing sequencing around spinlock
      operations, per Robert's gripe that it was misleading.
      be1e8053
    • Robert Haas's avatar
      Improve spinlock performance for HP-UX, ia64, non-gcc. · c01c25fb
      Robert Haas authored
      At least on this architecture, it's very important to spin on a
      non-atomic instruction and only retry the atomic once it appears
      that it will succeed.  To fix this, split TAS() into two macros:
      TAS(), for trying to grab the lock the first time, and TAS_SPIN(),
      for spinning until we get it.  TAS_SPIN() defaults to same as TAS(),
      but we can override it when we know there's a better way.
      
      It's likely that some of the other cases in s_lock.h require
      similar treatment, but this is the only one we've got conclusive
      evidence for at present.
      c01c25fb
    • Tom Lane's avatar
      Actually, all of parallel restore's limitations should be tested earlier. · 6e1f1fee
      Tom Lane authored
      On closer inspection, whining in restore_toc_entries_parallel is really
      much too late for any user-facing error case.  The right place to do it
      is at the start of RestoreArchive(), before we've done anything interesting
      (suh as trying to DROP all the targets ...)
      
      Back-patch to 8.4, where parallel restore was introduced.
      6e1f1fee
    • Tom Lane's avatar
      Be more user-friendly about unsupported cases for parallel pg_restore. · d6e7abe4
      Tom Lane authored
      If we are unable to do a parallel restore because the input file is stdin
      or is otherwise unseekable, we should complain and fail immediately, not
      after having done some of the restore.  Complaining once per thread isn't
      so cool either, and the messages should be worded to make it clear this is
      an unsupported case not some weird race-condition bug.  Per complaint from
      Lonni Friedman.
      
      Back-patch to 8.4, where parallel restore was introduced.
      d6e7abe4
  5. 28 Aug, 2011 2 commits
  6. 27 Aug, 2011 10 commits
    • Tom Lane's avatar
      Don't assume that "E" response to NEGOTIATE_SSL_CODE means pre-7.0 server. · a49fbaaf
      Tom Lane authored
      These days, such a response is far more likely to signify a server-side
      problem, such as fork failure.  Reporting "server does not support SSL"
      (in sslmode=require) could be quite misleading.  But the results could
      be even worse in sslmode=prefer: if the problem was transient and the
      next connection attempt succeeds, we'll have silently fallen back to
      protocol version 2.0, possibly disabling features the user needs.
      
      Hence, it seems best to just eliminate the assumption that backing off
      to non-SSL/2.0 protocol is the way to recover from an "E" response, and
      instead treat the server error the same as we would in non-SSL cases.
      
      I tested this change against a pre-7.0 server, and found that there
      was a second logic bug in the "prefer" path: the test to decide whether
      to make a fallback connection attempt assumed that we must have opened
      conn->ssl, which in fact does not happen given an "E" response.  After
      fixing that, the code does indeed connect successfully to pre-7.0,
      as long as you didn't set sslmode=require.  (If you did, you get
      "Unsupported frontend protocol", which isn't completely off base
      given the server certainly doesn't support SSL.)
      
      Since there seems no reason to believe that pre-7.0 servers exist anymore
      in the wild, back-patch to all supported branches.
      a49fbaaf
    • Peter Eisentraut's avatar
    • Tom Lane's avatar
      Ensure we discard unread/unsent data when abandoning a connection attempt. · 724e30c9
      Tom Lane authored
      There are assorted situations wherein PQconnectPoll() will abandon a
      connection attempt and try again with different parameters (eg, SSL versus
      not SSL).  However, the code forgot to discard any pending data in libpq's
      I/O buffers when doing this.  In at least one case (server returns E
      message during SSL negotiation), there is unread input data which bollixes
      the next connection attempt.  I have not checked to see whether this is
      possible in the other cases where we close the socket and retry, but it
      seems like a matter of good defensive programming to add explicit
      buffer-flushing code to all of them.
      
      This is one of several issues exposed by Daniel Farina's report of
      misbehavior after a server-side fork failure.
      
      This has been wrong since forever, so back-patch to all supported branches.
      724e30c9
    • Bruce Momjian's avatar
      Allow more include files to be compiled in their own by adding missing · 4bd7333b
      Bruce Momjian authored
      include dependencies.
      
      Modify pgcompinclude to skip a common fcinfo error.
      4bd7333b
    • Bruce Momjian's avatar
      Add support for #elif to pgrminclude. · d010391a
      Bruce Momjian authored
      d010391a
    • Peter Eisentraut's avatar
      Implement the information schema with_hierarchy column · fd5b397c
      Peter Eisentraut authored
      In PostgreSQL, this is included in the SELECT privilege, so show YES
      or NO depending on whether SELECT is granted.
      fd5b397c
    • Peter Eisentraut's avatar
      Spelling improvement · 3104cc89
      Peter Eisentraut authored
      3104cc89
    • Bruce Momjian's avatar
      68c019a5
    • Bruce Momjian's avatar
      Change references of CVS to .git. · e7088713
      Bruce Momjian authored
      e7088713
    • Bruce Momjian's avatar
      Add postgres.h to *.c files for pg_upgrade, ltree, and btree_gist, and · f1312b5e
      Bruce Momjian authored
      remove from local *.h files.
      
      Per suggestion from Alvaro.
      f1312b5e
  7. 26 Aug, 2011 2 commits