1. 18 Apr, 2010 3 commits
  2. 16 Apr, 2010 4 commits
  3. 15 Apr, 2010 7 commits
  4. 14 Apr, 2010 5 commits
    • Tom Lane's avatar
      Fix plpgsql's exec_eval_expr() to ensure it returns a sane type OID · f7c5ff3d
      Tom Lane authored
      even when the expression is a query that returns no rows.
      
      So far as I can tell, the only caller that actually fails when a garbage
      OID is returned is exec_stmt_case(), which is new in 8.4 --- in all other
      cases, we might make a useless trip through casting logic, but we won't
      fail since the isnull flag will be set.  Hence, backpatch only to 8.4,
      just in case there are apps out there that aren't expecting an error to
      be thrown if the query returns more or less than one column.  (Which seems
      unlikely, since the error would be thrown if the query ever did return a
      row; but it's possible there's some never-exercised code out there.)
      
      Per report from Mario Splivalo.
      f7c5ff3d
    • Tom Lane's avatar
      Fix a problem introduced by my patch of 2010-01-12 that revised the way · 73981cb4
      Tom Lane authored
      relcache reload works.  In the patched code, a relcache entry in process of
      being rebuilt doesn't get unhooked from the relcache hash table; which means
      that if a cache flush occurs due to sinval queue overrun while we're
      rebuilding it, the entry could get blown away by RelationCacheInvalidate,
      resulting in crash or misbehavior.  Fix by ensuring that an entry being
      rebuilt has positive refcount, so it won't be seen as a target for removal
      if a cache flush occurs.  (This will mean that the entry gets rebuilt twice
      in such a scenario, but that's okay.)  It appears that the problem can only
      arise within a transaction that has previously reassigned the relfilenode of
      a pre-existing table, via TRUNCATE or a similar operation.  Per bug #5412
      from Rusty Conover.
      
      Back-patch to 8.2, same as the patch that introduced the problem.
      I think that the failure can't actually occur in 8.2, since it lacks the
      rd_newRelfilenodeSubid optimization, but let's make it work like the later
      branches anyway.
      
      Patch by Heikki, slightly editorialized on by me.
      73981cb4
    • Robert Haas's avatar
      Typo fix. Kevin Grittner. · 9d137a75
      Robert Haas authored
      9d137a75
    • Simon Riggs's avatar
      Fix minor typo in comment in xlog.c · 55d7556a
      Simon Riggs authored
      55d7556a
    • Bruce Momjian's avatar
      0993d294
  5. 13 Apr, 2010 4 commits
  6. 12 Apr, 2010 6 commits
  7. 09 Apr, 2010 3 commits
  8. 08 Apr, 2010 2 commits
    • Magnus Hagander's avatar
      Proceed to look for the next timezone when matching a localized · 6efb081e
      Magnus Hagander authored
      Windows timezone name where the information in the registry is
      incomplete, instead of aborting.
      
      This fixes cases when the registry information is incomplete for
      a timezone that is alphabetically before the one that is in use.
      
      Per report from Alexander Forschner
      6efb081e
    • Robert Haas's avatar
      Make smart shutdown work in combination with Hot Standby/Streaming Replication. · 1c850fa8
      Robert Haas authored
      At present, killing the startup process does not release any locks it holds,
      so we must wait to stop the startup and walreceiver processes until all
      read-only backends have exited.  Without this patch, the startup and
      walreceiver processes never exit, so the server gets permanently stuck in
      a half-shutdown state.
      
      Fujii Masao, with review, docs, and comment adjustments by me.
      1c850fa8
  9. 07 Apr, 2010 5 commits
  10. 06 Apr, 2010 1 commit