1. 19 Sep, 2009 4 commits
  2. 18 Sep, 2009 5 commits
  3. 17 Sep, 2009 5 commits
  4. 16 Sep, 2009 1 commit
  5. 15 Sep, 2009 3 commits
    • Tom Lane's avatar
      Fix two distinct errors in creation of GIN_INSERT_LISTPAGE xlog records. · 384cad5c
      Tom Lane authored
      In practice these mistakes were always masked when full_page_writes was on,
      because XLogInsert would always choose to log the full page, and then
      ginRedoInsertListPage wouldn't try to do anything.  But with full_page_writes
      off a WAL replay failure was certain.
      
      The GIN_INSERT_LISTPAGE record type could probably be eliminated entirely
      in favor of using XLOG_HEAP_NEWPAGE, but I refrained from doing that now
      since it would have required a significantly more invasive patch.
      
      In passing do a little bit of code cleanup, including making the accounting
      for free space on GIN list pages more precise.  (This wasn't a bug as the
      errors were always in the conservative direction.)
      
      Per report from Simon.  Back-patch to 8.4 which contains the identical code.
      384cad5c
    • Michael Meskes's avatar
    • Tom Lane's avatar
      Fix possible buffer overrun and/or unportable behavior in pg_md5_encrypt() · 9a3f5301
      Tom Lane authored
      if salt_len == 0.  This seems to be mostly academic, since nearly all calling
      code paths guarantee nonempty salt; the only case that doesn't is
      PQencryptPassword where the caller could mistakenly pass an empty username.
      So, fix it but don't bother backpatching.  Per ljb.
      9a3f5301
  6. 14 Sep, 2009 1 commit
  7. 13 Sep, 2009 4 commits
    • Tom Lane's avatar
      Write psql's ~/.psql_history file using history_truncate_file() and · e97281c4
      Tom Lane authored
      append_history(), if libreadline is new enough to have those functions
      (they seem to be present at least since 4.2; but libedit may not have them).
      This gives significantly saner behavior when two or more sessions overlap in
      their use of the history file; although having two sessions exit at just the
      same time is still perilous to your history.  The behavior of \s remains
      unchanged, ie, overwrite whatever was there.
      Per bug #5052 from Marek Wójtowicz.
      e97281c4
    • Peter Eisentraut's avatar
      Fix Unicode support in PL/Python · eb62398f
      Peter Eisentraut authored
      Check calls of PyUnicode_AsEncodedString() for NULL return, probably
      because the encoding name is not known.  Add special treatment for
      SQL_ASCII, which Python definitely does not know.
      
      Since using SQL_ASCII produces errors in the regression tests when
      non-ASCII characters are involved, we have to put back various regression
      test result variants.
      eb62398f
    • Peter Eisentraut's avatar
      6689ce3e
    • Heikki Linnakangas's avatar
      Don't error out if recycling or removing an old WAL segment fails at the end · 7f2a10fe
      Heikki Linnakangas authored
      of checkpoint. Although the checkpoint has been written to WAL at that point
      already, so that all data is safe, and we'll retry removing the WAL segment at
      the next checkpoint, if such a failure persists we won't be able to remove any
      other old WAL segments either and will eventually run out of disk space. It's
      better to treat the failure as non-fatal, and move on to clean any other WAL
      segment and continue with any other end-of-checkpoint cleanup.
      
      We don't normally expect any such failures, but on Windows it can happen with
      some anti-virus or backup software that lock files without FILE_SHARE_DELETE
      flag.
      
      Also, the loop in pgrename() to retry when the file is locked was broken. If a
      file is locked on Windows, you get ERROR_SHARE_VIOLATION, not
      ERROR_ACCESS_DENIED, at least on modern versions. Fix that, although I left
      the check for ERROR_ACCESS_DENIED in there as well (presumably it was correct
      in some environment), and added ERROR_LOCK_VIOLATION to be consistent with
      similar checks in pgwin32_open(). Reduce the timeout on the loop from 30s to
      10s, on the grounds that since it's been broken, we've effectively had a
      timeout of 0s and no-one has complained, so a smaller timeout is actually
      closer to the old behavior. A longer timeout would mean that if recycling a
      WAL file fails because it's locked for some reason, InstallXLogFileSegment()
      will hold ControlFileLock for longer, potentially blocking other backends, so
      a long timeout isn't totally harmless.
      
      While we're at it, set errno correctly in pgrename().
      
      Backpatch to 8.2, which is the oldest version supported on Windows. The xlog.c
      changes would make sense on other platforms and thus on older versions as
      well, but since there's no such locking issues on other platforms, it's not
      worth it.
      7f2a10fe
  8. 12 Sep, 2009 7 commits
    • Joe Conway's avatar
      plug dblink resource leak · d6119d80
      Joe Conway authored
      dblink generates orphaned connections when called with a connection string,
      fail_on_error = true, and an ERROR occurs. Discovery and patch by
      Tatsuhito Kasahara. Introduced in 8.4.
      d6119d80
    • Peter Eisentraut's avatar
      Add Unicode support in PL/Python · 4ab6ebf3
      Peter Eisentraut authored
      PL/Python now accepts Unicode objects where it previously only accepted string
      objects (for example, as return value).  Unicode objects are converted to the
      PostgreSQL server encoding as necessary.
      
      This change is also necessary for future Python 3 support, which treats all
      strings as Unicode objects.
      
      Since this removes the error conditions that the plpython_unicode test file
      tested for, the alternative result files are no longer necessary.
      4ab6ebf3
    • Tom Lane's avatar
      Rewrite the planner's handling of materialized plan types so that there is · 9bb34281
      Tom Lane authored
      an explicit model of rescan costs being different from first-time costs.
      The costing of Material nodes in particular now has some visible relationship
      to the actual runtime behavior, where before it was essentially fantasy.
      This also fixes up a couple of places where different materialized plan types
      were treated differently for no very good reason (probably just oversights).
      
      A couple of the regression tests are affected, because the planner now chooses
      to put the other relation on the inside of a nestloop-with-materialize.
      So far as I can see both changes are sane, and the planner is now more
      consistently following the expectation that it should prefer to materialize
      the smaller of two relations.
      
      Per a recent discussion with Robert Haas.
      9bb34281
    • Tom Lane's avatar
      Improve GRANT reference page's description of object ownership · 5f1b32dd
      Tom Lane authored
      privileges by mentioning the possibility of granting membership in
      the owning role.
      5f1b32dd
    • Tom Lane's avatar
      Install a hopefully-temporary workaround for Snow Leopard readdir() bug. · 325aeb4a
      Tom Lane authored
      If Apple doesn't fix that reasonably soon, we'll have to consider
      back-patching a workaround; but for now, just hack it in HEAD so that
      we can get buildfarm reports on HEAD from OS X machines.
      Per Jan Otto.
      325aeb4a
    • Peter Eisentraut's avatar
    • Tom Lane's avatar
      Fix assertion failure when a SELECT DISTINCT ON expression is volatile. · d5a4b69c
      Tom Lane authored
      In this case we generate two PathKey references to the expression (one for
      DISTINCT and one for ORDER BY) and they really need to refer to the same
      EquivalenceClass.  However get_eclass_for_sort_expr was being overly paranoid
      and creating two different EC's.  Correct behavior is to use the SortGroupRef
      index to decide whether two references to volatile expressions that are
      equal() (ie textually equivalent) should be considered the same.
      
      Backpatch to 8.4.  Possibly this should be changed in 8.3 as well, but
      I'll refrain in the absence of evidence of a visible failure in that branch.
      
      Per bug #5049.
      d5a4b69c
  9. 11 Sep, 2009 2 commits
  10. 10 Sep, 2009 3 commits
  11. 09 Sep, 2009 2 commits
    • Peter Eisentraut's avatar
      Fix/improve bytea and boolean support in PL/Python · 3ab8b7fa
      Peter Eisentraut authored
      Before, PL/Python converted data between SQL and Python by going
      through a C string representation.  This broke for bytea in two ways:
      
      - On input (function parameters), you would get a Python string that
        contains bytea's particular external representation with backslashes
        etc., instead of a sequence of bytes, which is what you would expect
        in a Python environment.  This problem is exacerbated by the new
        bytea output format.
      
      - On output (function return value), null bytes in the Python string
        would cause truncation before the data gets stored into a bytea
        datum.
      
      This is now fixed by converting directly between the PostgreSQL datum
      and the Python representation.
      
      The required generalized infrastructure also allows for other
      improvements in passing:
      
      - When returning a boolean value, the SQL datum is now true if and
        only if Python considers the value that was passed out of the
        PL/Python function to be true.  Previously, this determination was
        left to the boolean data type input function.  So, now returning
        'foo' results in true, because Python considers it true, rather than
        false because PostgreSQL considers it false.
      
      - On input, we can convert the integer and float types directly to
        their Python equivalents without having to go through an
        intermediate string representation.
      
      original patch by Caleb Welton, with updates by myself
      3ab8b7fa
    • Tom Lane's avatar
      Fix bug with WITH RECURSIVE immediately inside WITH RECURSIVE. 99% of the · 255f66ef
      Tom Lane authored
      code was already okay with this, but the hack that obtained the output
      column types of a recursive union in advance of doing real parse analysis
      of the recursive union forgot to handle the case where there was an inner
      WITH clause available to the non-recursive term.  Best fix seems to be to
      refactor so that we don't need the "throwaway" parse analysis step at all.
      Instead, teach the transformSetOperationStmt code to set up the CTE's output
      column information after it's processed the non-recursive term normally.
      Per report from David Fetter.
      255f66ef
  12. 08 Sep, 2009 3 commits
    • Tom Lane's avatar
      Remove any -arch switches given in ExtUtils::Embed's ldopts from our · d69a419e
      Tom Lane authored
      perl_embed_ldflags setting.  On OS X it seems that ExtUtils::Embed is
      trying to force a universal binary to be built, but you need to specify
      that a lot further upstream if you want Postgres built that way; the only
      result of including -arch in perl_embed_ldflags is some warnings at the
      plperl.so link step.  Per my complaint and Jan Otto's suggestion.
      d69a419e
    • Tom Lane's avatar
      Add a boolean GUC parameter "bonjour" to control whether a Bonjour-enabled · eeb6cb14
      Tom Lane authored
      build actually attempts to advertise itself via Bonjour.  Formerly it always
      did so, which meant that packagers had to decide for their users whether
      this behavior was wanted or not.  The default is "off" to be on the safe
      side, though this represents a change in the default behavior of a
      Bonjour-enabled build.  Per discussion.
      eeb6cb14
    • Tom Lane's avatar
      Replace use of the long-deprecated Bonjour API DNSServiceRegistrationCreate · 59b9f3d3
      Tom Lane authored
      with the not-so-deprecated DNSServiceRegister.  This patch shouldn't change
      any user-visible behavior, it just gets rid of a deprecation warning in
      --with-bonjour builds.  The new code will fail on OS X releases before 10.3,
      but it seems unlikely that anyone will want to run Postgres 8.5 on 10.2.
      59b9f3d3