1. 28 Mar, 2017 3 commits
    • Simon Riggs's avatar
      Cleanup slots during drop database · ff539da3
      Simon Riggs authored
      Automatically drop all logical replication slots associated with a
      database when the database is dropped. Previously we threw an ERROR
      if a slot existed. Now we throw ERROR only if a slot is active in
      the database being dropped.
      
      Craig Ringer
      ff539da3
    • Peter Eisentraut's avatar
      Fix Perl code which had broken the Windows build · 4d33a7f2
      Peter Eisentraut authored
      The previous change wanted to avoid modifying $_ in grep, but the code
      just made the change in a local variable and then lost it.  Rewrite the
      code using a separate map and grep, which is clearer anyway.
      
      Author: Dagfinn Ilmari Mannsåker <ilmari@ilmari.org>
      4d33a7f2
    • Tom Lane's avatar
      Show ignored constants as "$N" rather than "?" in pg_stat_statements. · a6f22e83
      Tom Lane authored
      The trouble with the original choice here is that "?" is a valid (and
      indeed used) operator name, so that you could end up with ambiguous
      statement texts like "SELECT ? ? ?".  With this patch, you instead
      see "SELECT $1 ? $2", which seems significantly more readable.
      The numbers used for this purpose begin after the last actual $N parameter
      in the particular query.  The conflict with external parameters has its own
      potential for confusion of course, but it was agreed to be an improvement
      over the previous behavior.
      
      Lukas Fittl
      
      Discussion: https://postgr.es/m/CAP53PkxeaCuwYmF-A4J5z2-qk5fYFo5_NH3gpXGJJBxv1DMwEw@mail.gmail.com
      a6f22e83
  2. 27 Mar, 2017 22 commits
  3. 26 Mar, 2017 13 commits
    • Tom Lane's avatar
      Improve performance of ExecEvalWholeRowVar. · 2f0903ea
      Tom Lane authored
      In commit b8d7f053, we needed to fix ExecEvalWholeRowVar to not change
      the state of the slot it's copying.  The initial quick hack at that
      required two rounds of tuple construction, which is not very nice.
      To fix, add another primitive to tuptoaster.c that does precisely what
      we need.  (I initially tried to do this by refactoring one of the
      existing functions into two pieces; but it looked like that might hurt
      performance for the existing case, and the amount of code that could
      be shared is not very large, so I gave up on that.)
      
      Discussion: https://postgr.es/m/26088.1490315792@sss.pgh.pa.us
      2f0903ea
    • Peter Eisentraut's avatar
      Fix cpluspluscheck warning · 895f9370
      Peter Eisentraut authored
      Structure tag cannot be the same as a typedef that is a pointer to that
      struct.
      895f9370
    • Tom Lane's avatar
      Use ExecPrepareExpr in place of ExecPrepareCheck where appropriate. · 9b95f2fa
      Tom Lane authored
      Change one more place where ExecInitCheck/ExecPrepareCheck's insistence
      on getting implicit-AND-format quals wasn't really helpful, because the
      caller had to do make_ands_implicit() for no reason that it cared about.
      Using ExecPrepareExpr directly simplifies the code and saves cycles.
      
      The only remaining use of these functions is to process
      resultRelInfo->ri_PartitionCheck quals.  However, implicit-AND format
      does seem to be what we want for that, so leave it alone.
      9b95f2fa
    • Tom Lane's avatar
      Fix typos in logical replication support for initial data copy. · 5459cfd3
      Tom Lane authored
      Fix an incorrect assert condition (noted by Coverity), and spell the new
      name of the function correctly.  Typos introduced in commit 7c4f5240.
      
      Michael Paquier
      5459cfd3
    • Tom Lane's avatar
      Fix unportable disregard of alignment requirements in RADIUS code. · 4c051c41
      Tom Lane authored
      The compiler is entitled to store a char[] local variable with no
      particular alignment requirement.  Our RADIUS code cavalierly took such
      a local variable and cast its address to a struct type that does have
      alignment requirements.  On an alignment-picky machine this would lead
      to bus errors.  To fix, declare the local variable honestly, and then
      cast its address to char * for use in the I/O calls.
      
      Given the lack of field complaints, there must be very few if any
      people affected; but nonetheless this is a clear portability issue,
      so back-patch to all supported branches.
      
      Noted while looking at a Coverity complaint in the same code.
      4c051c41
    • Tom Lane's avatar
      Fix some minor resource leaks in PerformRadiusTransaction(). · 7cbd9446
      Tom Lane authored
      Failure to free serveraddrs pointed out by Coverity, failure to close
      socket noted by code-reading.  These bugs seem to be quite old, but
      given the low probability of taking these error-exit paths and the
      minimal consequences of the leaks (since the process would presumably
      exit shortly anyway), it doesn't seem worth back-patching.
      
      Michael Paquier and Tom Lane
      7cbd9446
    • Tom Lane's avatar
      Improve implementation of EEOP_BOOLTEST_* opcodes. · d77f014e
      Tom Lane authored
      Both Andres and I were happy with "*op->resvalue = *op->resvalue;",
      but Coverity isn't; and it has a point, because some compilers might
      not be smart enough to elide that.  So remove it.  In passing, also
      avoid doing unnecessary assignments to *op->resnull when it's already
      known to have the right value.
      d77f014e
    • Peter Eisentraut's avatar
      doc: Fix oldhtml/old PDF build · e259e1f7
      Peter Eisentraut authored
      "xref to REFSECT1 unsupported" with the DSSSL stylesheets.
      Reported-by: default avatarDevrim Gündüz <devrim@gunduz.org>
      e259e1f7
    • Peter Eisentraut's avatar
      doc: Clean up bibliography rendering for XSLT · d6376245
      Peter Eisentraut authored
      In the DSSSL stylesheets, we had an extensive customization of the
      bibliography rendering.  Since the bibliography isn't that used much, it
      doesn't seem worth doing an elaborate porting of that to XSLT.  So this
      just moves some things around, removes some unused things, and does some
      minimal XSLT stylesheet customizations to make things look clean.
      d6376245
    • Tom Lane's avatar
      Update some obsolete comments. · 244dd95c
      Tom Lane authored
      Fix a few stray references to expression eval functions that don't
      exist anymore or don't take the same input representation they used to.
      244dd95c
    • Alvaro Herrera's avatar
      Add missing break · 6a101b0a
      Alvaro Herrera authored
      Noticed by Coverity
      6a101b0a
    • Andres Freund's avatar
      Blindly attempt to fix sepgsql tests #2. · d253b0f6
      Andres Freund authored
      d253b0f6
    • Andres Freund's avatar
      Blindly attempt to fix sepgsql tests. · 83bbcb04
      Andres Freund authored
      Due to b8d7f053 some permission checks are now happening even on
      empty tables, and some of the checks move around.
      
      Discussion: https://postgr.es/m/95bdb608-093c-160f-c6be-983a36ccd7f9@joeconway.com
      83bbcb04
  4. 25 Mar, 2017 2 commits