1. 22 Dec, 2010 2 commits
    • Magnus Hagander's avatar
      Add PQlibVersion() function to libpq · de9a4c27
      Magnus Hagander authored
      This function is like the PQserverVersion() function except
      it returns the version of libpq, making it possible for a client
      program or driver to determine which version of libpq is in
      use at runtime, and not just at link time.
      
      Suggested by Harald Armin Massa and several others.
      de9a4c27
    • Robert Haas's avatar
      Use memcmp() rather than strncmp() when shorter string length is known. · 32ba2b51
      Robert Haas authored
      It appears that this will be faster for all but the shortest strings;
      at least one some platforms, memcmp() can use word-at-a-time comparisons.
      
      Noah Misch, somewhat pared down.
      32ba2b51
  2. 21 Dec, 2010 2 commits
    • Robert Haas's avatar
      Fix typos. · c5160b7e
      Robert Haas authored
      Andreas Karlsson
      c5160b7e
    • Robert Haas's avatar
      Work around unfortunate getppid() behavior on BSD-ish systems. · 24ecde77
      Robert Haas authored
      On MacOS X, and apparently also on other BSD-derived systems, attaching
      a debugger causes getppid() to return the pid of the debugging process
      rather than the actual parent PID.  As a result, debugging the
      autovacuum launcher, startup process, or WAL sender on such systems
      causes it to exit, because the previous coding of PostmasterIsAlive()
      detects postmaster death by testing whether getppid() == PostmasterPid.
      
      Work around that behavior by checking the return value of getppid()
      more carefully.  If it's PostmasterPid, the postmaster must be alive;
      if it's 1, assume the postmaster is dead.  If it's any other value,
      assume we've been debugged and fall through to the less-reliable
      kill() test.
      
      Review by Tom Lane.
      24ecde77
  3. 20 Dec, 2010 2 commits
  4. 19 Dec, 2010 4 commits
    • Magnus Hagander's avatar
      Remove thread dumping constant that requires newer Platform SDK · d382828f
      Magnus Hagander authored
      Since we're not multithreaded it only provides marginally useful
      information, and it does require a newer version of the Platform SDK
      than we target. We may want to reconsider this in the future along
      with a fix for MinGW.
      d382828f
    • Tom Lane's avatar
      Fix up handling of simple-form CASE with constant test expression. · 1b19e2c0
      Tom Lane authored
      eval_const_expressions() can replace CaseTestExprs with constants when
      the surrounding CASE's test expression is a constant.  This confuses
      ruleutils.c's heuristic for deparsing simple-form CASEs, leading to
      Assert failures or "unexpected CASE WHEN clause" errors.  I had put in
      a hack solution for that years ago (see commit
      514ce7a3 of 2006-10-01), but bug #5794
      from Peter Speck shows that that solution failed to cover all cases.
      
      Fortunately, there's a much better way, which came to me upon reflecting
      that Peter's "CASE TRUE WHEN" seemed pretty redundant: we can "simplify"
      the simple-form CASE to the general form of CASE, by simply omitting the
      constant test expression from the rebuilt CASE construct.  This is
      intuitively valid because there is no need for the executor to evaluate
      the test expression at runtime; it will never be referenced, because any
      CaseTestExprs that would have referenced it are now replaced by constants.
      This won't save a whole lot of cycles, since evaluating a Const is pretty
      cheap, but a cycle saved is a cycle earned.  In any case it beats kluging
      ruleutils.c still further.  So this patch improves const-simplification
      and reverts the previous change in ruleutils.c.
      
      Back-patch to all supported branches.  The bug exists in 8.1 too, but it's
      out of warranty.
      1b19e2c0
    • Tom Lane's avatar
      Fix erroneous parsing of tsquery input "... & !(subexpression) | ..." · abc10262
      Tom Lane authored
      After parsing a parenthesized subexpression, we must pop all pending
      ANDs and NOTs off the stack, just like the case for a simple operand.
      Per bug #5793.
      
      Also fix clones of this routine in contrib/intarray and contrib/ltree,
      where input of types query_int and ltxtquery had the same problem.
      
      Back-patch to all supported versions.
      abc10262
    • Magnus Hagander's avatar
      Support for collecting crash dumps on Windows · dcb09b59
      Magnus Hagander authored
      Add support for collecting "minidump" style crash dumps on
      Windows, by setting up an exception handling filter. Crash
      dumps will be generated in PGDATA/crashdumps if the directory
      is created (the existance of the directory is used as on/off
      switch for the generation of the dumps).
      
      Craig Ringer and Magnus Hagander
      dcb09b59
  5. 18 Dec, 2010 2 commits
  6. 17 Dec, 2010 5 commits
  7. 16 Dec, 2010 11 commits
  8. 15 Dec, 2010 2 commits
  9. 14 Dec, 2010 4 commits
  10. 13 Dec, 2010 4 commits
  11. 12 Dec, 2010 2 commits