1. 08 Dec, 2015 5 commits
    • Kevin Grittner's avatar
      Improve performance in freeing memory contexts · 25c53923
      Kevin Grittner authored
      The single linked list of memory contexts could result in O(N^2)
      performance to free a set of contexts if they were not freed in
      reverse order of creation.  In many cases the reverse order was
      used, but there were some significant exceptions that caused real-
      world performance problems.  Rather than requiring all callers to
      care about the order in which contexts were freed, and hunting down
      and changing all existing cases where the wrong order was used, we
      add one pointer per memory context so that the implementation
      details are not so visible.
      
      Jan Wieck
      25c53923
    • Tom Lane's avatar
      Make failure to open psql's --log-file fatal. · 521f0458
      Tom Lane authored
      Commit 344cdff2 made failure to open the target of --output fatal.
      For consistency, the --log-file switch should behave similarly.
      Like the previous commit, back-patch to 9.5 but no further.
      
      Daniel Verite
      521f0458
    • Tom Lane's avatar
      Avoid odd portability problem in TestLib.pm's slurp_file function. · 938d797b
      Tom Lane authored
      For unclear reasons, this function doesn't always read the expected data
      in some old Perl versions.  Rewriting it to avoid use of ARGV seems to
      dodge the problem, and this version is clearer anyway if you ask me.
      
      In passing, also improve error message in adjacent append_to_file function.
      938d797b
    • Robert Haas's avatar
      psql: Support multiple -c and -f options, and allow mixing them. · d5563d7d
      Robert Haas authored
      To support this, we must reconcile some historical anomalies in the
      behavior of -c.  In particular, as a backward-incompatibility, -c no
      longer implies --no-psqlrc.
      
      Pavel Stehule (code) and Catalin Iacob (documentation).  Review by
      Michael Paquier and myself.  Proposed behavior per Tom Lane.
      d5563d7d
    • Robert Haas's avatar
      Allow foreign and custom joins to handle EvalPlanQual rechecks. · 385f337c
      Robert Haas authored
      Commit e7cb7ee1 provided basic
      infrastructure for allowing a foreign data wrapper or custom scan
      provider to replace a join of one or more tables with a scan.
      However, this infrastructure failed to take into account the need
      for possible EvalPlanQual rechecks, and ExecScanFetch would fail
      an assertion (or just overwrite memory) if such a check was attempted
      for a plan containing a pushed-down join.  To fix, adjust the EPQ
      machinery to skip some processing steps when scanrelid == 0, making
      those the responsibility of scan's recheck method, which also has
      the responsibility in this case of correctly populating the relevant
      slot.
      
      To allow foreign scans to gain control in the right place to make
      use of this new facility, add a new, optional RecheckForeignScan
      method.  Also, allow a foreign scan to have a child plan, which can
      be used to correctly populate the slot (or perhaps for something
      else, but this is the only use currently envisioned).
      
      KaiGai Kohei, reviewed by Robert Haas, Etsuro Fujita, and Kyotaro
      Horiguchi.
      385f337c
  2. 07 Dec, 2015 4 commits
    • Tom Lane's avatar
      Simplify LATERAL-related calculations within add_paths_to_joinrel(). · edca44b1
      Tom Lane authored
      While convincing myself that commit 7e19db0c would solve both of
      the problems recently reported by Andreas Seltenreich, I realized that
      add_paths_to_joinrel's handling of LATERAL restrictions could be made
      noticeably simpler and faster if we were to retain the minimum possible
      parameterization for each joinrel (that is, the set of relids supplying
      unsatisfied lateral references in it).  We already retain that for
      baserels, in RelOptInfo.lateral_relids, so we can use that field for
      joinrels too.
      
      I re-pgindent'd the files touched here, which affects some unrelated
      comments.
      
      This is, I believe, just a minor optimization not a bug fix, so no
      back-patch.
      edca44b1
    • Alvaro Herrera's avatar
      PostgresNode: wrap correctly around port number range end · 7ac5d9b3
      Alvaro Herrera authored
      Per note from Tom Lane
      7ac5d9b3
    • Tom Lane's avatar
      Fix another oversight in checking if a join with LATERAL refs is legal. · 7e19db0c
      Tom Lane authored
      It was possible for the planner to decide to join a LATERAL subquery to
      the outer side of an outer join before the outer join itself is completed.
      Normally that's fine because of the associativity rules, but it doesn't
      work if the subquery contains a lateral reference to the inner side of the
      outer join.  In such a situation the outer join *must* be done first.
      join_is_legal() missed this consideration and would allow the join to be
      attempted, but the actual path-building code correctly decided that no
      valid join path could be made, sometimes leading to planner errors such as
      "failed to build any N-way joins".
      
      Per report from Andreas Seltenreich.  Back-patch to 9.3 where LATERAL
      support was added.
      7e19db0c
    • Alvaro Herrera's avatar
      Cleanup some problems in new Perl test code · 9821492e
      Alvaro Herrera authored
      Noted by Tom Lane:
      - PostgresNode had a BEGIN block which created files, contrary to
        perlmod suggestions to do that only on INIT blocks.
      - Assign ports randomly rather than starting from 90600.
      
      Noted by Noah Misch:
      - Change use of no-longer-set PGPORT environment variable to $node->port
      - Don't start a server in pg_controldata test
      - PostgresNode was reading the PID file incorrectly; test the right
        thing, and chomp the line we read from the PID file.
      - Remove an unused $devnull variable
      - Use 'pg_ctl kill' instead of "kill" directly, for Windos portability.
      - Make server log names more informative.
      
      Author: Michael Paquier
      9821492e
  3. 06 Dec, 2015 1 commit
  4. 05 Dec, 2015 2 commits
    • Tom Lane's avatar
      Create TestLib.pm's tempdir underneath tmp_check/, not out in the open. · db072363
      Tom Lane authored
      This way, existing .gitignore entries and makefile clean actions will
      automatically apply to the tempdir, should it survive a TAP test run
      (which can happen if the user control-C's out of the run, for example).
      
      Michael Paquier, per a complaint from me
      db072363
    • Noah Misch's avatar
      Instruct Coverity using an assertion. · d4b686af
      Noah Misch authored
      This should make Coverity deduce that plperl_call_perl_func() does not
      dereference NULL argtypes.  Back-patch to 9.5, where the affected code
      was introduced.
      
      Michael Paquier
      d4b686af
  5. 04 Dec, 2015 1 commit
    • Tom Lane's avatar
      Further improve documentation of the role-dropping process. · 63acfb79
      Tom Lane authored
      In commit 1ea0c73c I added a section to user-manag.sgml about how to drop
      roles that own objects; but as pointed out by Stephen Frost, I neglected
      that shared objects (databases or tablespaces) may need special treatment.
      Fix that.  Back-patch to supported versions, like the previous patch.
      63acfb79
  6. 03 Dec, 2015 6 commits
    • Alvaro Herrera's avatar
      Further tweak commit_timestamp behavior · 820ddb2c
      Alvaro Herrera authored
      As pointed out by Fujii Masao, we weren't quite there on a standby
      behaving sanely: first because we were failing to acquire the correct
      state in the case where no XLOG_PARAMETER_CHANGE message was sent
      (because a checkpoint had already happened after the setting was changed
      in the master, and then the standby was restarted); and second because
      promoting the standby with the feature enabled failed to activate it if
      the master had the feature disabled.
      
      This patch fixes both those misbehaviors hopefully without
      re-introducing any old problems.
      
      Also change the hint emitted in a standby together with the error
      message about the feature being disabled, to make it point out that the
      place to chance the setting is the master.  Otherwise, if the setting is
      already enabled in the standby, it is very confusing to have it say that
      the setting must be enabled ...
      
      Authors: Álvaro Herrera, Petr Jelínek.
      Backpatch to 9.5.
      820ddb2c
    • Tom Lane's avatar
      Clean up some psql issues around handling of the query output file. · 344cdff2
      Tom Lane authored
      Formerly, if "psql -o foo" failed to open the output file "foo", it would
      print an error message but then carry on as though -o had not been
      specified at all.  This seems contrary to expectation: a program that
      cannot open its output file normally fails altogether.  Make psql do
      exit(1) after reporting the error.
      
      If "\o foo" failed to open "foo", it would print an error message but then
      reset the output file to stdout, as if the argument had been omitted.
      This is likewise pretty surprising behavior.  Make it keep the previous
      output state, instead.
      
      psql keeps SIGPIPE interrupts disabled when it is writing to a pipe, either
      a pipe specified by -o/\o or a transient pipe opened for purposes such as
      using a pager on query output.  The logic for this was too simple and could
      sometimes re-enable SIGPIPE when a -o pipe was still active, thus possibly
      leading to an unexpected psql crash later.
      
      Fixing the last point required getting rid of the kluge in PrintQueryTuples
      and ExecQueryUsingCursor whereby they'd transiently change the global
      queryFout state, but that seems like good cleanup anyway.
      
      Back-patch to 9.5 but not further; these are minor-enough issues that
      changing the behavior in stable branches doesn't seem appropriate.
      344cdff2
    • Peter Eisentraut's avatar
      doc: Add serial comma · f15b820a
      Peter Eisentraut authored
      f15b820a
    • Peter Eisentraut's avatar
      psql: Improve spelling · 77a7bb3d
      Peter Eisentraut authored
      77a7bb3d
    • Peter Eisentraut's avatar
      9ff1a11a
    • Alvaro Herrera's avatar
      Fix broken subroutine call in TestLib · a2983cfd
      Alvaro Herrera authored
      Michael Paquier
      a2983cfd
  7. 02 Dec, 2015 3 commits
    • Tom Lane's avatar
      Fix behavior of printTable() and friends with externally-invoked pager. · d8ff060e
      Tom Lane authored
      The formatting modes that depend on knowledge of the terminal window width
      did not work right when printing a query result that's been fetched in
      sections (as a result of FETCH_SIZE).  ExecQueryUsingCursor() would force
      use of the pager as soon as there's more than one result section, and then
      print.c would see an output file pointer that's not stdout and incorrectly
      conclude that the terminal window width isn't relevant.
      
      This has been broken all along for non-expanded "wrapped" output format,
      and as of 9.5 the issue affects expanded mode as well.  The problem also
      caused "\pset expanded auto" mode to invariably *not* switch to expanded
      output in a segmented result, which seems to me to be exactly backwards.
      
      To fix, we need to pass down an "is_pager" flag to inform the print.c
      subroutines that some calling level has already replaced stdout with a
      pager pipe, so they should (a) not do that again and (b) nonetheless honor
      the window size.  (Notably, this makes the first is_pager test in
      print_aligned_text() not be dead code anymore.)
      
      This patch is a bit invasive because there are so many existing calls of
      printQuery()/printTable(), but fortunately all but a couple can just pass
      "false" for the added parameter.
      
      Back-patch to 9.5 but no further.  Given the lack of field complaints,
      it's not clear that we should change the behavior in stable branches.
      Also, the API change for printQuery()/printTable() might possibly break
      third-party code, again something we don't like to do in stable branches.
      However, it's not quite too late to do this in 9.5, and with the larger
      scope of the problem there, it seems worth doing.
      d8ff060e
    • Alvaro Herrera's avatar
      Refactor Perl test code · 1caef31d
      Alvaro Herrera authored
      The original code was a bit clunky; make it more amenable for further
      reuse by creating a new Perl package PostgresNode, which is an
      object-oriented representation of a single server, with some support
      routines such as init, start, stop, psql.  This serves as a better basis
      on which to build further test code, and enables writing tests that use
      more than one server without too much complication.
      
      This commit modifies a lot of the existing test files, mostly to remove
      explicit calls to system commands (pg_ctl) replacing them with method
      calls of a PostgresNode object.  The result is quite a bit more
      straightforward.
      
      Also move some initialization code to BEGIN and INIT blocks instead of
      having it straight in as top-level code.
      
      This commit also introduces package RecursiveCopy so that we can copy
      whole directories without having to depend on packages that may not be
      present on vanilla Perl 5.8 installations.
      
      I also ran perltidy on the modified files, which changes some code sites
      that are not otherwise touched by this patch.  I tried to avoid this,
      but it ended up being more trouble than it's worth.
      
      Authors: Michael Paquier, Álvaro Herrera
      Review: Noah Misch
      1caef31d
    • Robert Haas's avatar
      Add handling for GatherPath to print_path. · c7485a82
      Robert Haas authored
      Peter Geoghegan
      c7485a82
  8. 01 Dec, 2015 5 commits
    • Tom Lane's avatar
      Make gincostestimate() cope with hypothetical GIN indexes. · 7fb008c5
      Tom Lane authored
      We tried to fetch statistics data from the index metapage, which does not
      work if the index isn't actually present.  If the index is hypothetical,
      instead extrapolate some plausible internal statistics based on the index
      page count provided by the index-advisor plugin.
      
      There was already some code in gincostestimate() to invent internal stats
      in this way, but since it was only meant as a stopgap for pre-9.1 GIN
      indexes that hadn't been vacuumed since upgrading, it was pretty crude.
      If we want it to support index advisors, we should try a little harder.
      A small amount of testing says that it's better to estimate the entry pages
      as 90% of the index, not 100%.  Also, estimating the number of entries
      (keys) as equal to the heap tuple count could be wildly wrong in either
      direction.  Instead, let's estimate 100 entries per entry page.
      
      Perhaps someday somebody will want the index advisor to be able to provide
      these numbers more directly, but for the moment this should serve.
      
      Problem report and initial patch by Julien Rouhaud; modified by me to
      invent less-bogus internal statistics.  Back-patch to all supported
      branches, since we've supported index advisors since 9.0.
      7fb008c5
    • Tom Lane's avatar
      Further tweaking of print_aligned_vertical(). · 95708e1d
      Tom Lane authored
      Don't force the data width to extend all the way to the right margin if it
      doesn't need to.  This reverts the behavior in non-wrapping cases to be
      what it was in 9.4.  Also, make the logic that ensures the data line width
      is at least equal to the record-header line width a little less obscure.
      
      In passing, avoid possible calculation of log10(0).  Probably that's
      harmless, given the lack of field complaints, but it seems risky:
      conversion of NaN to an integer isn't well defined.
      95708e1d
    • Tom Lane's avatar
      Use "g" not "f" format in ecpg's PGTYPESnumeric_from_double(). · db4a5cfc
      Tom Lane authored
      The previous coding could overrun the provided buffer size for a very large
      input, or lose precision for a very small input.  Adopt the methodology
      that's been in use in the equivalent backend code for a long time.
      
      Per private report from Bas van Schaik.  Back-patch to all supported
      branches.
      db4a5cfc
    • Tom Lane's avatar
      Further adjustment to psql's print_aligned_vertical() function. · 2287b874
      Tom Lane authored
      We should ignore output_columns unless it's greater than zero.
      A zero means we couldn't get any information from ioctl(TIOCGWINSZ);
      in that case the expected behavior is to print the data at native width,
      not to wrap it at the smallest possible value.  print_aligned_text()
      gets this consideration right, but print_aligned_vertical() lost track
      of this detail somewhere along the line.
      2287b874
    • Teodor Sigaev's avatar
      Use pg_rewind when target timeline was switched · e50cda78
      Teodor Sigaev authored
      Allow pg_rewind to work when target timeline was switched. Now
      user can return promoted standby to old master.
      
      Target timeline history becomes a global variable. Index
      in target timeline history is used in function interfaces instead of
      specifying TLI directly. Thus, SimpleXLogPageRead() can easily start
      reading XLOGs from next timeline when current timeline ends.
      
      Author: Alexander Korotkov
      Review: Michael Paquier
      e50cda78
  9. 30 Nov, 2015 2 commits
    • Tom Lane's avatar
      Rework wrap-width calculation in psql's print_aligned_vertical() function. · 0e0776bc
      Tom Lane authored
      This area was rather heavily whacked around in 6513633b and follow-on
      commits, and it was showing it, because the logic to calculate the
      allowable data width in wrapped expanded mode had only the vaguest
      relationship to the logic that was actually printing the data.  It was
      not very close to being right about the conditions requiring overhead
      columns to be added.  Aside from being wrong, it was pretty unreadable
      and under-commented.  Rewrite it so it corresponds to what the printing
      code actually does.
      
      In passing, remove a couple of dead tests in the printing logic, too.
      
      Per a complaint from Jeff Janes, though this doesn't look much like his
      patch because it fixes a number of other corner-case bogosities too.
      One such fix that's visible in the regression test results is that
      although the code was attempting to enforce a minimum data width of
      3 columns, it sometimes left less space than that available.
      0e0776bc
    • Robert Haas's avatar
      Fix obsolete comment. · 3690dc6b
      Robert Haas authored
      It's amazing how fast things become obsolete these days.
      
      Amit Langote
      3690dc6b
  10. 29 Nov, 2015 1 commit
    • Tom Lane's avatar
      Avoid caching expression state trees for domain constraints across queries. · ec7eef6b
      Tom Lane authored
      In commit 8abb3cda I attempted to cache
      the expression state trees constructed for domain CHECK constraints for
      the life of the backend (assuming the domain's constraints don't get
      redefined).  However, this turns out not to work very well, because
      execQual.c will run those state trees with ecxt_per_query_memory pointing
      to a query-lifespan context, and in some situations we'll end up with
      pointers into that context getting stored into the state trees.  This
      happens in particular with SQL-language functions, as reported by
      Emre Hasegeli, but there are many other cases.
      
      To fix, keep only the expression plan trees for domain CHECK constraints
      in the typcache's data structure, and revert to performing ExecInitExpr
      (at least) once per query to set up expression state trees in the query's
      context.
      
      Eventually it'd be nice to undo this, but that will require some careful
      thought about memory management for expression state trees, and it seems
      far too late for any such redesign in 9.5.  This way is still much more
      efficient than what happened before 8abb3cda.
      ec7eef6b
  11. 28 Nov, 2015 1 commit
    • Tom Lane's avatar
      Avoid doing encoding conversions by double-conversion via MULE_INTERNAL. · 8d32717b
      Tom Lane authored
      Previously, we did many conversions for Cyrillic and Central European
      single-byte encodings by converting to a related MULE_INTERNAL coding
      scheme before converting to the destination.  This seems unnecessarily
      inefficient.  Moreover, if the conversion encounters an untranslatable
      character, the error message will confusingly complain about failure
      to convert to or from MULE_INTERNAL, rather than the user-visible
      encodings.  Worse still, this approach results in some completely
      unnecessary conversion failures; there are cases where the chosen
      MULE subset lacks characters that exist in both of the user-visible
      encodings, causing a conversion failure that need not occur.
      
      This patch fixes the first two of those deficiencies by introducing
      a new local2local() conversion support subroutine for direct conversion
      between any two single-byte character sets, and adding new conversion
      tables where needed.  However, I generated the new conversion tables by
      testing PG 9.5's behavior, so that the actual conversion behavior is
      bug-compatible with previous releases; the only user-visible behavior
      change is that the error messages for conversion failures are saner.
      Changes in the conversion behavior will probably ensue after discussion.
      
      Interestingly, although this approach requires more tables, the .so files
      actually end up smaller (at least on my x86_64 machine); the tables are
      smaller than the management code needed for double conversion.
      
      Per a complaint from Albe Laurenz.
      8d32717b
  12. 27 Nov, 2015 4 commits
    • Tom Lane's avatar
    • Tom Lane's avatar
      Auto-generate file header comments in Unicode mapping files. · e17dab53
      Tom Lane authored
      Some of the Unicode/*.map files had identification comments added to them,
      evidently by hand.  Others did not.  Modify the generating scripts to
      produce these comments automatically, and update the generated files that
      lacked them.
      
      This is just minor cleanup as a by-product of trying to verify that the
      *.map files can indeed be reproduced from authoritative data.  There are a
      depressingly large number that fail to reproduce from the claimed sources.
      I have not touched those in this commit, except for the JIS 2004-related
      files which required only a single comment update to match.
      
      Since this only affects comments, no need to consider a back-patch.
      e17dab53
    • Tom Lane's avatar
      Improve PQhost() to return useful data for default Unix-socket connections. · 40cb21f7
      Tom Lane authored
      Previously, if no host information had been specified at connection time,
      PQhost() would return NULL (unless you are on Windows, in which case you
      got "localhost").  This is an unhelpful definition for a couple of reasons:
      it can cause corner-case crashes in applications (cf commit c5ef8ce5),
      and there's no well-defined way for applications to find out the socket
      directory path that's actually in use.  As an example of the latter
      problem, psql substituted DEFAULT_PGSOCKET_DIR for NULL in a couple of
      places, but this is subtly wrong because it's conceivable that psql is
      using a libpq shared library that was built with a different setting.
      
      Hence, change PQhost() to return DEFAULT_PGSOCKET_DIR when appropriate,
      and strip out the now-dead substitutions in psql.  (There is still one
      remaining reference to DEFAULT_PGSOCKET_DIR in psql, in prompt.c, which
      I don't see a nice way to get rid of.  But it only controls a prompt
      abbreviation decision, so it seems noncritical.)
      
      Also update the docs for PQhost, which had never previously mentioned
      the possibility of a socket directory path being returned.  In passing
      fix the outright-incorrect code comment about PGconn.pgunixsocket.
      40cb21f7
    • Teodor Sigaev's avatar
      COPY (INSERT/UPDATE/DELETE .. RETURNING ..) · 92e38182
      Teodor Sigaev authored
      Attached is a patch for being able to do COPY (query) without a CTE.
      
      Author: Marko Tiikkaja
      Review: Michael Paquier
      92e38182
  13. 26 Nov, 2015 1 commit
    • Tom Lane's avatar
      Fix failure to consider failure cases in GetComboCommandId(). · 0da3a9be
      Tom Lane authored
      Failure to initially palloc the comboCids array, or to realloc it bigger
      when needed, left combocid's data structures in an inconsistent state that
      would cause trouble if the top transaction continues to execute.  Noted
      while examining a user complaint about the amount of memory used for this.
      (There's not much we can do about that, but it does point up that repalloc
      failure has a non-negligible chance of occurring here.)
      
      In HEAD/9.5, also avoid possible invocation of memcpy() with a null pointer
      in SerializeComboCIDState; cf commit 13bba022.
      0da3a9be
  14. 25 Nov, 2015 4 commits
    • Tom Lane's avatar
      Be more paranoid about null return values from libpq status functions. · c5ef8ce5
      Tom Lane authored
      PQhost() can return NULL in non-error situations, namely when a Unix-socket
      connection has been selected by default.  That behavior is a tad debatable
      perhaps, but for the moment we should make sure that psql copes with it.
      Unfortunately, do_connect() failed to: it could pass a NULL pointer to
      strcmp(), resulting in crashes on most platforms.  This was reported as a
      security issue by ChenQin of Topsec Security Team, but the consensus of
      the security list is that it's just a garden-variety bug with no security
      implications.
      
      For paranoia's sake, I made the keep_password test not trust PQuser or
      PQport either, even though I believe those will never return NULL given
      a valid PGconn.
      
      Back-patch to all supported branches.
      c5ef8ce5
    • Tom Lane's avatar
      Improve div_var_fast(), mostly by making comments better. · 46166197
      Tom Lane authored
      The integer overflow situation in div_var_fast() is a great deal more
      complicated than the pre-existing comments would suggest.  Moreover, the
      comments were also flat out incorrect as to the precise statement of the
      maxdiv loop invariant.  Upon clarifying that, it becomes apparent that the
      way in which we updated maxdiv after a carry propagation pass was overly
      slow, complex, and conservative: we can just reset it to one, which is much
      easier and also reduces the number of times carry propagation occurs.
      Fix that and improve the relevant comments.
      
      Since this is mostly a comment fix, with only a rather marginal performance
      boost, no need for back-patch.
      
      Tom Lane and Dean Rasheed
      46166197
    • Teodor Sigaev's avatar
      Add forgotten file in commit d6061f83 · 0271e27c
      Teodor Sigaev authored
      0271e27c
    • Teodor Sigaev's avatar
      Improve pageinspect module · d6061f83
      Teodor Sigaev authored
      Now pageinspect can show data stored in the heap tuple.
      
      Nikolay Shaplov
      d6061f83