1. 24 Nov, 2017 2 commits
    • Noah Misch's avatar
      Support linking with MinGW-built Perl. · 84c4313c
      Noah Misch authored
      This is necessary for ActivePerl 5.18 onwards and for Strawberry Perl.
      It is not sufficient for 32-bit builds with newer Visual Studio; these
      fail with error LINK2026.  Back-patch to 9.3 (all supported versions).
      
      Reported by Victor Wagner.
      
      Discussion: https://postgr.es/m/20160326154321.7754ab8f@wagner.wagner.home
      84c4313c
    • Andres Freund's avatar
      Fix handling of NULLs returned by aggregate combine functions. · 59b71c6f
      Andres Freund authored
      When strict aggregate combine functions, used in multi-stage/parallel
      aggregation, returned NULL, we didn't check for that, invoking the
      combine function with NULL the next round, despite it being strict.
      
      The equivalent code invoking normal transition functions has a check
      for that situation, which did not get copied in a7de3dc5. Fix the
      bug by adding the equivalent check.
      
      Based on a quick look I could not find any strict combine functions in
      core actually returning NULL, and it doesn't seem very likely external
      users have done so. So this isn't likely to have caused issues in
      practice.
      
      Add tests verifying transition / combine functions returning NULL is
      tested.
      
      Reported-By: Andres Freund
      Author: Andres Freund
      Discussion: https://postgr.es/m/20171121033642.7xvmjqrl4jdaaat3@alap3.anarazel.de
      Backpatch: 9.6, where parallel aggregation was introduced
      59b71c6f
  2. 23 Nov, 2017 4 commits
  3. 22 Nov, 2017 6 commits
  4. 21 Nov, 2017 5 commits
    • Tom Lane's avatar
      pgbench: fix stats reporting when some transactions are skipped. · 16827d44
      Tom Lane authored
      pgbench can skip some transactions when both -R and -L options are used.
      Previously, this resulted in slightly silly statistics both in progress
      reports and final output, because the skipped transactions were counted
      as executed for TPS and related stats.  Discount skipped xacts in TPS
      numbers, and also when figuring the percentage of xacts exceeding the
      latency limit.
      
      Also, don't print per-script skipped-transaction counts when there is
      only one script.  That's redundant with the overall count, and it's
      inconsistent with the fact that we don't print other per-script stats
      when there's only one script.  Clean up some unnecessary interactions
      between what should be independent options that were due to that
      decision.
      
      While at it, avoid division-by-zero in cases where no transactions were
      executed.  While on modern platforms this would generally result in
      printing "NaN" rather than a crash, that isn't spelled consistently
      across platforms and it would confuse many people.  Skip the relevant
      output entirely when practical, else print zeroes.
      
      Fabien Coelho, reviewed by Steve Singer, additional hacking by me
      
      Discussion: https://postgr.es/m/26654.1505232433@sss.pgh.pa.us
      16827d44
    • Tom Lane's avatar
      Doc: fix broken markup. · 41761265
      Tom Lane authored
      41761265
    • Robert Haas's avatar
      Provide for forward compatibility with future minor protocol versions. · ae65f606
      Robert Haas authored
      Previously, any attempt to request a 3.x protocol version other than
      3.0 would lead to a hard connection failure, which made the minor
      protocol version really no different from the major protocol version
      and precluded gentle protocol version breaks.  Instead, when the
      client requests a 3.x protocol version where x is greater than 0, send
      the new NegotiateProtocolVersion message to convey that we support
      only 3.0.  This makes it possible to introduce new minor protocol
      versions without requiring a connection retry when the server is
      older.
      
      In addition, if the startup packet includes name/value pairs where
      the name starts with "_pq_.", assume that those are protocol options,
      not GUCs.  Include those we don't support (i.e. all of them, at
      present) in the NegotiateProtocolVersion message so that the client
      knows they were not understood.  This makes it possible for the
      client to request previously-unsupported features without bumping
      the protocol version at all; the client can tell from the server's
      response whether the option was understood.
      
      It will take some time before servers that support these new
      facilities become common in the wild; to speed things up and make
      things easier for a future 3.1 protocol version, back-patch to all
      supported releases.
      
      Robert Haas and Badrul Chowdhury
      
      Discussion: http://postgr.es/m/BN6PR21MB0772FFA0CBD298B76017744CD1730@BN6PR21MB0772.namprd21.prod.outlook.com
      Discussion: http://postgr.es/m/30788.1498672033@sss.pgh.pa.us
      ae65f606
    • Robert Haas's avatar
      Fix multiple problems with satisfies_hash_partition. · f3b0897a
      Robert Haas authored
      Fix the function header comment to describe the actual behavior.
      Check that table OID, modulus, and remainder arguments are not NULL
      before accessing them.  Check that the modulus and remainder are
      sensible.  If the table OID doesn't exist, return NULL instead of
      emitting an internal error, similar to what we do elsewhere.  Check
      that the actual argument types match, or at least are binary coercible
      to, the expected argument types.  Correctly handle invocation of this
      function using the VARIADIC syntax.  Add regression tests.
      
      Robert Haas and Amul Sul, per a report by Andreas Seltenreich and
      subsequent followup investigation.
      
      Discussion: http://postgr.es/m/871sl4sdrv.fsf@ansel.ydns.eu
      f3b0897a
    • Tom Lane's avatar
      Support index-only scans in contrib/cube and contrib/seg GiST indexes. · de1d042f
      Tom Lane authored
      To do this, we only have to remove the compress and decompress support
      functions, which have never done anything more than detoasting.
      In the wake of commit d3a4f89d, this results in automatically enabling
      index-only scans, since the core code will now know that the stored
      representation is the same as the original data (up to detoasting).
      
      The only exciting part of this is that ALTER OPERATOR FAMILY lacks
      a way to drop a support function that was declared as being part of
      an opclass rather than being loose in the family.  For the moment,
      we'll hack our way to a solution with a manual update of the pg_depend
      entry type, which is what distinguishes the two cases.  Perhaps
      someday it'll be worth providing a cleaner way to do that, but for
      now it seems like a very niche problem.
      
      Note that the underlying C functions remain, to support use of the shared
      libraries with older versions of the modules' SQL declarations.  Someday
      we may be able to remove them, but not soon.
      
      Andrey Borodin, reviewed by me
      
      Discussion: https://postgr.es/m/D0F53A05-4F4A-4DEC-8339-3C069FA0EE11@yandex-team.ru
      de1d042f
  5. 20 Nov, 2017 6 commits
  6. 19 Nov, 2017 1 commit
  7. 18 Nov, 2017 6 commits
    • Tom Lane's avatar
      Fix compiler warning in rangetypes_spgist.c. · 52f63bd9
      Tom Lane authored
      On gcc 7.2.0, comparing pointer to (Datum) 0 produces a warning.
      Treat it as a simple pointer to avoid that; this is more consistent
      with comparable code elsewhere, anyway.
      
      Tomas Vondra
      
      Discussion: https://postgr.es/m/99410021-61ef-9a9a-9bc8-f733ece637ee@2ndquadrant.com
      52f63bd9
    • Tom Lane's avatar
      Merge near-duplicate code in RI triggers. · 4797f9b5
      Tom Lane authored
      Merge ri_restrict_del and ri_restrict_upd into one function ri_restrict.
      Create a function ri_setnull that is the common implementation of
      RI_FKey_setnull_del and RI_FKey_setnull_upd.  Likewise create a function
      ri_setdefault that is the common implementation of RI_FKey_setdefault_del
      and RI_FKey_setdefault_upd.  All of these pairs of functions were identical
      except for needing to check for no-actual-key-change in the UPDATE cases;
      the one extra if-test is a small price to pay for saving so much code.
      
      Aside from removing about 400 lines of essentially duplicate code, this
      allows us to recognize that we were uselessly caching two identical plans
      whenever there were pairs of triggers using these duplicated functions
      (which is likely very common).
      
      Ildar Musin, reviewed by Ildus Kurbangaliev
      
      Discussion: https://postgr.es/m/ca7064a7-6adc-6f22-ca47-8615ba9425a5@postgrespro.ru
      4797f9b5
    • Peter Eisentraut's avatar
      Consistently catch errors from Python _New() functions · d0aa965c
      Peter Eisentraut authored
      Python Py*_New() functions can fail and return NULL in out-of-memory
      conditions.  The previous code handled that inconsistently or not at
      all.  This change organizes that better.  If we are in a function that
      is called from Python, we just check for failure and return NULL
      ourselves, which will cause any exception information to be passed up.
      If we are called from PostgreSQL, we consistently create an "out of
      memory" error.
      Reviewed-by: default avatarTom Lane <tgl@sss.pgh.pa.us>
      d0aa965c
    • Tom Lane's avatar
      Improve to_date/to_number/to_timestamp behavior with multibyte characters. · 976a1a48
      Tom Lane authored
      The documentation says that these functions skip one input character
      per literal (non-pattern) format character.  Actually, though, they
      skipped one input *byte* per literal *byte*, which could be hugely
      confusing if either data or format contained multibyte characters.
      
      To fix, adjust the FormatNode representation and parse_format() so
      that multibyte format characters are stored as one FormatNode not
      several, and adjust the data-skipping bits to advance by pg_mblen()
      not necessarily one byte.  There's no user-visible behavior change
      on the to_char() side, although the internal representation changes.
      
      Commit e87d4965 had already fixed most places where we skip characters
      on the basis of non-literal format patterns to advance by characters
      not bytes, but this gets one more place, the SKIP_THth macro.  I think
      everything in formatting.c gets that right now.
      
      It'd be nice to have some regression test cases covering this behavior;
      but of course there's no way to do so in an encoding-agnostic way, and
      many of the interesting aspects would also require unportable locale
      selections.  So I've not bothered here.
      
      Discussion: https://postgr.es/m/28186.1510957703@sss.pgh.pa.us
      976a1a48
    • Tom Lane's avatar
      Fix quoted-substring handling in format parsing for to_char/to_number/etc. · 63ca8631
      Tom Lane authored
      This code evidently intended to treat backslash as an escape character
      within double-quoted substrings, but it was sufficiently confused that
      cases like ..."foo\\"... did not work right: the second backslash
      managed to quote the double-quote after it, despite being quoted itself.
      Rewrite to get that right, while preserving the existing behavior
      outside double-quoted substrings, which is that backslash isn't special
      except in the combination \".
      
      Comparing to Oracle, it seems that their version of to_char() for
      timestamps allows literal alphanumerics only within double quotes, while
      non-alphanumerics are allowed outside quotes; backslashes aren't special
      anywhere; there is no way at all to emit a literal double quote.
      (Bizarrely, their to_char() for numbers is different; it doesn't allow
      literal text at all AFAICT.)  The fact that they don't treat backslash
      as special justifies our existing behavior for backslash outside double
      quotes.  I considered making backslash inside double quotes act the same
      way (ie, special only if before "), which in a green field would be a
      more consistent behavior.  But that would likely break more existing SQL
      code than what this patch does.
      
      Add some test cases illustrating this behavior.  (Only the last new
      case actually changes behavior in this commit.)
      
      Little of this behavior was documented, either, so fix that.
      
      Discussion: https://postgr.es/m/3626.1510949486@sss.pgh.pa.us
      63ca8631
    • Peter Eisentraut's avatar
      Support channel binding 'tls-unique' in SCRAM · 9288d62b
      Peter Eisentraut authored
      This is the basic feature set using OpenSSL to support the feature.  In
      order to allow the frontend and the backend to fetch the sent and
      expected TLS Finished messages, a PG-like API is added to be able to
      make the interface pluggable for other SSL implementations.
      
      This commit also adds a infrastructure to facilitate the addition of
      future channel binding types as well as libpq parameters to control the
      SASL mechanism names and channel binding names.  Those will be added by
      upcoming commits.
      
      Some tests are added to the SSL test suite to test SCRAM authentication
      with channel binding.
      
      Author: Michael Paquier <michael@paquier.xyz>
      Reviewed-by: default avatarPeter Eisentraut <peter.eisentraut@2ndquadrant.com>
      9288d62b
  8. 17 Nov, 2017 7 commits
  9. 16 Nov, 2017 3 commits
    • Tom Lane's avatar
      Clean up warnings in MinGW builds. · 09a77744
      Tom Lane authored
      Experimentation with modern MinGW (specifically the 5.0.2 version packaged
      for Fedora 26) shows that its version of sys/stat.h *does* provide S_IRGRP
      and friends, contrary to the expectation of win32_port.h.  This results in
      an astonishing number of compiler warnings, and perhaps in incorrect code
      --- I'm not sure if the nonzero values supplied by MinGW's header actually
      do anything.  Hence, adjust win32_port.h to only define these macros if
      <sys/stat.h> doesn't.
      
      This might be worth back-patching, but given the lack of complaints so
      far, I'm not too excited about it.
      09a77744
    • Tom Lane's avatar
      Make PL/Python handle domain-type conversions correctly. · 687f096e
      Tom Lane authored
      Fix PL/Python so that it can handle domains over composite, and so that
      it enforces domain constraints correctly in other cases that were not
      always done properly before.  Notably, it didn't do arrays of domains
      right (oversight in commit c12d570f), and it failed to enforce domain
      constraints when returning a composite type containing a domain field,
      and if a transform function is being used for a domain's base type then
      it failed to enforce domain constraints on the result.  Also, in many
      places it missed checking domain constraints on null values, because
      the plpy_typeio code simply wasn't called for Py_None.
      
      Rather than try to band-aid these problems, I made a significant
      refactoring of the plpy_typeio logic.  The existing design of recursing
      for array and composite members is extended to also treat domains as
      containers requiring recursion, and the APIs for the module are cleaned
      up and simplified.
      
      The patch also modifies plpy_typeio to rely on the typcache more than
      it did before (which was pretty much not at all).  This reduces the
      need for repetitive lookups, and lets us get rid of an ad-hoc scheme
      for detecting changes in composite types.  I added a couple of small
      features to typcache to help with that.
      
      Although some of this is fixing bugs that long predate v11, I don't
      think we should risk a back-patch: it's a significant amount of code
      churn, and there've been no complaints from the field about the bugs.
      
      Tom Lane, reviewed by Anthony Bykov
      
      Discussion: https://postgr.es/m/24449.1509393613@sss.pgh.pa.us
      687f096e
    • Robert Haas's avatar
      Remove redundant line from Makefile. · 575cead9
      Robert Haas authored
      Masahiko Sawada, reviewed by Michael Paquier
      
      Discussion: http://postgr.es/m/CAD21AoDFes_Mgye-1K89rmTgeU3RxYF3zgTjzCJVq2KzzcpC4A@mail.gmail.com
      575cead9