1. 18 Mar, 2013 2 commits
    • Robert Haas's avatar
      Extend object-access hook machinery to support post-alter events. · 05f3f9c7
      Robert Haas authored
      This also slightly widens the scope of what we support in terms of
      post-create events.
      
      KaiGai Kohei, with a few changes, mostly to the comments, by me
      05f3f9c7
    • Tom Lane's avatar
      Improve signal-handler lockout mechanism in timeout.c. · 6ac7facd
      Tom Lane authored
      Rather than doing a fairly-expensive setitimer() call to prevent interrupts
      from happening, let's just invent a simple boolean flag that the signal
      handler is required to check.  This is not only faster but considerably
      more robust than before, since the previous code effectively assumed that
      only ITIMER_REAL events would ever fire the SIGALRM handler, which is
      obviously something that can be broken easily by third-party code.
      
      Zoltán Böszörményi and Tom Lane
      6ac7facd
  2. 17 Mar, 2013 9 commits
    • Tom Lane's avatar
      Use pqsignal() in contrib programs rather than calling signal(2) directly. · 3c07fbf4
      Tom Lane authored
      The semantics of signal(2) are more variable than one could wish; in
      particular, on strict-POSIX platforms the signal handler will be reset
      to SIG_DFL when the signal is delivered.  This demonstrably breaks
      pg_test_fsync's use of SIGALRM.  The other changes I made are not
      absolutely necessary today, because the called handlers all exit the
      program anyway.  But it seems like a good general practice to use
      pqsignal() exclusively in Postgres code, now that we have it available
      everywhere.
      3c07fbf4
    • Tom Lane's avatar
      Re-include pqsignal() in libpq. · b1fae823
      Tom Lane authored
      We need this in non-ENABLE_THREAD_SAFETY builds, and also to satisfy
      the exports.txt entry; while it might be a good idea to remove the
      latter, I'm hesitant to do so except in the context of an intentional
      ABI break.  At least we don't have a separately maintained source file
      for it anymore.
      b1fae823
    • Tom Lane's avatar
      initdb needs pqsignal() even on Windows. · e2a203a1
      Tom Lane authored
      I had thought we weren't using this version of pqsignal() at all on
      Windows, but that's wrong --- initdb is using it (and coping with the
      POSIX-ish semantics of bare signal() :-().  So allow the file to be
      built in WIN32+FRONTEND case, and add it to the MSVC build logic.
      e2a203a1
    • Tom Lane's avatar
      Fix inclusions in pgbench.c. · 8c41cb69
      Tom Lane authored
      Apparently this was depending on pqsignal.h for <signal.h>.
      Not sure why I didn't see the failure on my other machine.
      8c41cb69
    • Tom Lane's avatar
      Fix inclusions in pg_receivexlog.c. · c68b5eff
      Tom Lane authored
      Apparently this was depending on pqsignal.h for <signal.h>.
      Not sure why I didn't see the failure on my other machine.
      c68b5eff
    • Tom Lane's avatar
      Move pqsignal() to libpgport. · da5aeccf
      Tom Lane authored
      We had two copies of this function in the backend and libpq, which was
      already pretty bogus, but it turns out that we need it in some other
      programs that don't use libpq (such as pg_test_fsync).  So put it where
      it probably should have been all along.  The signal-mask-initialization
      support in src/backend/libpq/pqsignal.c stays where it is, though, since
      we only need that in the backend.
      da5aeccf
    • Tom Lane's avatar
      Add lock_timeout configuration parameter. · d43837d0
      Tom Lane authored
      This GUC allows limiting the time spent waiting to acquire any one
      heavyweight lock.
      
      In support of this, improve the recently-added timeout infrastructure
      to permit efficiently enabling or disabling multiple timeouts at once.
      That reduces the performance hit from turning on lock_timeout, though
      it's still not zero.
      
      Zoltán Böszörményi, reviewed by Tom Lane,
      Stephen Frost, and Hari Babu
      d43837d0
    • Peter Eisentraut's avatar
      d2bef5f7
    • Peter Eisentraut's avatar
      ea1aee88
  3. 15 Mar, 2013 3 commits
    • Tom Lane's avatar
      Improve the documentation about commit_delay. · 70ec2f8f
      Tom Lane authored
      Clarify the docs explaining what commit_delay does, and add a
      recommendation about a useful value for it, namely half of the single-page
      fsync time reported by pg_test_fsync.  This is informed by testing of
      the new-in-9.3 implementation of commit_delay; in prior versions it
      was far harder to arrive at a useful setting.
      
      In passing, do some wordsmithing and markup-fixing in the same general
      area.
      
      Also, change pg_test_fsync's default time-per-test from 2 seconds to 5.
      The old value was about the minimum at which the results could be taken
      seriously at all, and so seems a tad optimistic as a default.
      
      Peter Geoghegan, reviewed by Noah Misch; some additional editing by me
      70ec2f8f
    • Tom Lane's avatar
      Improve error reporting in code that checks for buffer refcount leaks. · dcafdbcd
      Tom Lane authored
      Formerly we just Assert'ed that each refcount was zero, which was quick
      and easy but failed to provide a good overview of what was wrong.
      Change the code so that we'll call PrintBufferLeakWarning() for each
      buffer with a nonzero refcount, and then Assert at the end of the loop.
      This costs nothing in runtime and might ease diagnosis of some bugs.
      
      Greg Smith, reviewed by Satoshi Nagayasu, further tweaked by me
      dcafdbcd
    • Tom Lane's avatar
      Extend format() to handle field width and left/right alignment. · 73e7025b
      Tom Lane authored
      This change adds some more standard sprintf() functionality to format().
      
      Pavel Stehule, reviewed by Dean Rasheed and Kyotaro Horiguchi
      73e7025b
  4. 14 Mar, 2013 10 commits
    • Tom Lane's avatar
      Avoid inserting no-op Limit plan nodes. · 1a1832eb
      Tom Lane authored
      This was discussed in connection with the patch to avoid inserting no-op
      Result nodes, but not actually implemented therein.
      1a1832eb
    • Kevin Grittner's avatar
      Revert unnecessary change in MV call to checkRuleResultList(). · fb60e729
      Kevin Grittner authored
      Due to a misreading of the function's comment block, there was an
      unneeded change to a call in rewriteDefine.c.  There is, in fact
      no reason to pass false for a MV; it should be true just like a
      view.
      
      Fixes issue pointed out by Tom Lane
      fb60e729
    • Kevin Grittner's avatar
      Add regression test for MV join to view. · 8d7ff13e
      Kevin Grittner authored
      This would have caught a bug in the initial patch, and seems like
      a good thing to test going forward.
      
      Per bug report by Erik Rijkers and fix by Tom Lane
      8d7ff13e
    • Heikki Linnakangas's avatar
      Also update psqlscan.l with the UESCAPE error rule changes. · f7559c01
      Heikki Linnakangas authored
      Even though this patch had no user-visible difference, better keep the code
      in psqlscan.l sync with the backend lexer. And of course it's nice to shrink
      the psql binary, too. Ecpg's version of the lexer doesn't have the error
      rule, it doesn't try to avoid backing up, so it doesn't need to be modified.
      
      As reminded by Tom Lane
      f7559c01
    • Tom Lane's avatar
      Minor fixes for hstore_to_json_loose(). · c2754991
      Tom Lane authored
      Fix unportable use of isdigit(), get rid of useless calculations.
      c2754991
    • Tom Lane's avatar
      Avoid inserting Result nodes that only compute identity projections. · 4387cf95
      Tom Lane authored
      The planner sometimes inserts Result nodes to perform column projections
      (ie, arbitrary scalar calculations) above plan nodes that lack projection
      logic of their own.  However, we did that even if the lower plan node was
      in fact producing the required column set already; which is a pretty common
      case given the popularity of "SELECT * FROM ...".  Measurements show that
      the useless plan node adds non-negligible overhead, especially when there
      are many columns in the result.  So add a check to avoid inserting a Result
      node unless there's something useful for it to do.
      
      There are a couple of remaining places where unnecessary Result nodes
      could get inserted, but they are (a) much less performance-critical,
      and (b) coded in such a way that it's hard to avoid inserting a Result,
      because the desired tlist is changed on-the-fly in subsequent logic.
      We'll leave those alone for now.
      
      Kyotaro Horiguchi; reviewed and further hacked on by Amit Kapila and
      Tom Lane.
      4387cf95
    • Heikki Linnakangas's avatar
      Change the way UESCAPE is lexed, to reduce the size of the flex tables. · a5ff502f
      Heikki Linnakangas authored
      The error rule used to avoid backtracking with the U&'...' UESCAPE 'x'
      syntax bloated the flex tables, so refactor that. This patch makes the error
      rule shorter, by introducing a new exclusive flex state that's entered after
      parsing U&'...'. This shrinks the postgres binary by about 220kB.
      a5ff502f
    • Heikki Linnakangas's avatar
      Add cost estimation of range @> and <@ operators. · 59d0bf9d
      Heikki Linnakangas authored
      The estimates are based on the existing lower bound histogram, and a new
      histogram of range lengths.
      
      Bump catversion, because the range length histogram now needs to be present
      in statistic slot kind 6, or you get an error on @> and <@ queries. (A
      re-ANALYZE would be enough to fix that, though)
      
      Alexander Korotkov, with some refactoring by me.
      59d0bf9d
    • Peter Eisentraut's avatar
      Add regression tests for XML mapping of domains · 788bce13
      Peter Eisentraut authored
      Pavel Stěhule
      788bce13
    • Kevin Grittner's avatar
      Fix bug in dumping prior releases due to MV REFRESH dependency checking. · a18b72ad
      Kevin Grittner authored
      Reports and suggested patches from Fujii Masao and Andrew Dunstan.
      
      Andrew Dunstan
      a18b72ad
  5. 13 Mar, 2013 1 commit
    • Tom Lane's avatar
      Introduce less-bogus handling of collations in contrib/postgres_fdw. · ed3ddf91
      Tom Lane authored
      Treat expressions as being remotely executable only if all collations used
      in them are determined by Vars of the foreign table.  This means that, if
      the foreign server gets different answers than we do, it's the user's fault
      for not having marked the foreign table columns with collations equivalent
      to the remote table's.  This rule allows most simple expressions such as
      "var < 'constant'" to be sent to the remote side, because the constant
      isn't determining the collation (the Var's collation would win).  There's
      still room for improvement, but it's hard to see how to do it without a
      lot more knowledge and/or assumptions about what the remote side will do.
      ed3ddf91
  6. 12 Mar, 2013 6 commits
    • Tom Lane's avatar
      Fix documentation oversight. · 209f675f
      Tom Lane authored
      Mention that PlanForeignModify's result must be copiable by copyObject.
      209f675f
    • Tom Lane's avatar
      Fix contrib/postgres_fdw's handling of column defaults. · 50c19fc7
      Tom Lane authored
      Adopt the position that only locally-defined defaults matter.  Any defaults
      defined in the remote database do not affect insertions performed through
      a foreign table (unless they are for columns not known to the foreign
      table).  While it'd arguably be more useful to permit remote defaults to be
      used, making that work in a consistent fashion requires far more work than
      seems possible for 9.3.
      50c19fc7
    • Tom Lane's avatar
      Allow default expressions to be attached to columns of foreign tables. · a0c6dfee
      Tom Lane authored
      There's still some discussion about exactly how postgres_fdw ought to
      handle this case, but there seems no debate that we want to allow defaults
      to be used for inserts into foreign tables.  So remove the core-code
      restrictions that prevented it.
      
      While at it, get rid of the special grammar productions for CREATE FOREIGN
      TABLE, and instead add explicit FEATURE_NOT_SUPPORTED error checks for the
      disallowed cases.  This makes the grammar a shade smaller, and more
      importantly results in much more intelligible error messages for
      unsupported cases.  It's also one less thing to fix if we ever start
      supporting constraints on foreign tables.
      a0c6dfee
    • Alvaro Herrera's avatar
      Fix orthotypographical mistake · 1ba01193
      Alvaro Herrera authored
      Apparently I lost some of the edits I had done on this page for commit
      0ac5ad51.
      
      Per note from Etsuro Fujita, although I didn't use his patch.
      
      Make some of the wording in the affected section a bit more complete,
      too.
      1ba01193
    • Tom Lane's avatar
      Avoid row-processing-order dependency in postgres_fdw regression test. · 0247d43d
      Tom Lane authored
      A test intended to provoke an error on the remote side was coded in such
      a way that multiple rows should be updated, so the output would vary
      depending on which one was processed first.  Per buildfarm.
      0247d43d
    • Tom Lane's avatar
      Fix postgres_fdw's issues with inconsistent interpretation of data values. · cc3f281f
      Tom Lane authored
      For datatypes whose output formatting depends on one or more GUC settings,
      we have to worry about whether the other server will interpret the value
      the same way it was meant.  pg_dump has been aware of this hazard for a
      long time, but postgres_fdw needs to deal with it too.  To fix data
      retrieval from the remote server, set the necessary remote GUC settings at
      connection startup.  (We were already assuming that settings made then
      would persist throughout the remote session.)  To fix data transmission to
      the remote server, temporarily force the relevant GUCs to the right values
      when we're about to convert any data values to text for transmission.
      
      This is all pretty grotty, and not very cheap either.  It's tempting to
      think of defining one uber-GUC that would override any settings that might
      render printed data values unportable.  But of course, older remote servers
      wouldn't know any such thing and would still need this logic.
      
      While at it, revert commit f7951eef, since
      this provides a real fix.  (The timestamptz given in the error message
      returned from the "remote" server will now reliably be shown in UTC.)
      cc3f281f
  7. 11 Mar, 2013 2 commits
  8. 10 Mar, 2013 7 commits
    • Andrew Dunstan's avatar
      JSON generation improvements. · 38fb4d97
      Andrew Dunstan authored
      This adds the following:
      
          json_agg(anyrecord) -> json
          to_json(any) -> json
          hstore_to_json(hstore) -> json (also used as a cast)
          hstore_to_json_loose(hstore) -> json
      
      The last provides heuristic treatment of numbers and booleans.
      
      Also, in json generation, if any non-builtin type has a cast to json,
      that function is used instead of the type's output function.
      
      Andrew Dunstan, reviewed by Steve Singer.
      
      Catalog version bumped.
      38fb4d97
    • Peter Eisentraut's avatar
      doc: Add note about checkpoint_warning vs checkpoint_timeout · dd28c410
      Peter Eisentraut authored
      suggested by Tianyin Xu
      dd28c410
    • Peter Eisentraut's avatar
      31531325
    • Peter Eisentraut's avatar
    • Tom Lane's avatar
      Band-aid for regression test expected-results problem with timestamptz. · f7951eef
      Tom Lane authored
      We probably need to tell the remote server to use specific timezone and
      datestyle settings, and maybe other things.  But for now let's just hack
      the postgres_fdw regression test to not provoke failures when run in
      non-EST5EDT environments.  Per buildfarm.
      f7951eef
    • Tom Lane's avatar
      Support writable foreign tables. · 21734d2f
      Tom Lane authored
      This patch adds the core-system infrastructure needed to support updates
      on foreign tables, and extends contrib/postgres_fdw to allow updates
      against remote Postgres servers.  There's still a great deal of room for
      improvement in optimization of remote updates, but at least there's basic
      functionality there now.
      
      KaiGai Kohei, reviewed by Alexander Korotkov and Laurenz Albe, and rather
      heavily revised by Tom Lane.
      21734d2f
    • Magnus Hagander's avatar
      Report pg_hba line number and contents when users fail to log in · 7f49a67f
      Magnus Hagander authored
      Instead of just reporting which user failed to log in, log both the
      line number in the active pg_hba.conf file (which may not match reality
      in case the file has been edited and not reloaded) and the contents of
      the matching line (which will always be correct), to make it easier
      to debug incorrect pg_hba.conf files.
      
      The message to the client remains unchanged and does not include this
      information, to prevent leaking security sensitive information.
      
      Reviewed by Tom Lane and Dean Rasheed
      7f49a67f