1. 22 Feb, 2019 4 commits
  2. 21 Feb, 2019 9 commits
  3. 20 Feb, 2019 7 commits
    • Andrew Gierth's avatar
      Use an unsigned char for bool if we don't use the native bool. · d26a810e
      Andrew Gierth authored
      On (rare) platforms where sizeof(bool) > 1, we need to use our own
      bool, but imported c99 code (such as Ryu) may want to use bool values
      as array subscripts, which elicits warnings if bool is defined as
      char. Using unsigned char instead should work just as well for our
      purposes, and avoid such warnings.
      
      Per buildfarm members prariedog and locust.
      d26a810e
    • Tom Lane's avatar
      Improve planner's understanding of strictness of type coercions. · e04a3905
      Tom Lane authored
      PG type coercions are generally strict, ie a NULL input must produce
      a NULL output (or, in domain cases, possibly an error).  The planner's
      understanding of that was a bit incomplete though, so improve it:
      
      * Teach contain_nonstrict_functions() that CoerceViaIO can always be
      considered strict.  Previously it believed that only if the underlying
      I/O functions were marked strict, which is often but not always true.
      
      * Teach clause_is_strict_for() that CoerceViaIO, ArrayCoerceExpr,
      ConvertRowtypeExpr, CoerceToDomain can all be considered strict.
      Previously it knew nothing about any of them.
      
      The main user-visible impact of this is that IS NOT NULL predicates
      can be proven to hold from expressions involving casts in more cases
      than before, allowing partial indexes with such predicates to be used
      without extra pushups.  This reduces the surprise factor for users,
      who may well be used to ordinary (function-call-based) casts being
      known to be strict.
      
      Per a gripe from Samuel Williams.  This doesn't rise to the level of
      a bug, IMO, so no back-patch.
      
      Discussion: https://postgr.es/m/27571.1550617881@sss.pgh.pa.us
      e04a3905
    • Tom Lane's avatar
      Fix incorrect strictness test for ArrayCoerceExpr expressions. · 1571bc0f
      Tom Lane authored
      The recursion in contain_nonstrict_functions_walker() was done wrong,
      causing the strictness check to be bypassed for a parse node that
      is the immediate input of an ArrayCoerceExpr node.  This could allow,
      for example, incorrect decisions about whether a strict SQL function
      can be inlined.
      
      I didn't add a regression test, because (a) the bug is so narrow
      and (b) I couldn't think of a test case that wasn't dependent on a
      large number of other behaviors, to the point where it would likely
      soon rot to the point of not testing what it was intended to.
      
      I broke this in commit c12d570f, so back-patch to v11.
      
      Discussion: https://postgr.es/m/27571.1550617881@sss.pgh.pa.us
      1571bc0f
    • Alvaro Herrera's avatar
      Make object address handling more robust · 5721b9b3
      Alvaro Herrera authored
      pg_identify_object_as_address crashes when passed certain tuples from
      inconsistent system catalogs.  Make it more defensive.
      
      Author: Álvaro Herrera
      Reviewed-by: Michaël Paquier
      Discussion: https://postgr.es/m/20190218202743.GA12392@alvherre.pgsql
      5721b9b3
    • Amit Kapila's avatar
      Doc: Update the documentation for FSM behavior for small tables. · 29d108cd
      Amit Kapila authored
      In commit b0eaa4c5, we have avoided the creation of FSM for small tables.
      So the functions that use FSM to compute the free space can return zero for
      such tables.  This was previously also possible for the cases where the
      vacuum has not been triggered to update FSM.
      
      This commit updates the comments in code and documentation to reflect this
      behavior.
      
      Author: John Naylor
      Reviewed-by: Amit Kapila
      Discussion: https://postgr.es/m/CACPNZCtba-3m1q3A8gxA_vxg=T7gQf7gMbpR4Ciy5LntY-j+0Q@mail.gmail.com
      29d108cd
    • Dean Rasheed's avatar
      Fix DEFAULT-handling in multi-row VALUES lists for updatable views. · 41531e42
      Dean Rasheed authored
      INSERT ... VALUES for a single VALUES row is implemented differently
      from a multi-row VALUES list, which causes inconsistent behaviour in
      the way that DEFAULT items are handled. In particular, when inserting
      into an auto-updatable view on top of a table with a column default, a
      DEFAULT item in a single VALUES row gets correctly replaced with the
      table column's default, but for a multi-row VALUES list it is replaced
      with NULL.
      
      Fix this by allowing rewriteValuesRTE() to leave DEFAULT items in the
      VALUES list untouched if the target relation is an auto-updatable view
      and has no column default, deferring DEFAULT-expansion until the query
      against the base relation is rewritten. For all other types of target
      relation, including tables and trigger- and rule-updatable views, we
      must continue to replace DEFAULT items with NULL in the absence of a
      column default.
      
      This is somewhat complicated by the fact that if an auto-updatable
      view has DO ALSO rules attached, the VALUES lists for the product
      queries need to be handled differently from the original query, since
      the product queries need to act like rule-updatable views whereas the
      original query has auto-updatable view semantics.
      
      Back-patch to all supported versions.
      
      Reported by Roger Curley (bug #15623). Patch by Amit Langote and me.
      
      Discussion: https://postgr.es/m/15623-5d67a46788ec8b7f@postgresql.org
      41531e42
    • Michael Paquier's avatar
      Mark correctly initial slot snapshots with MVCC type when built · 56fadbed
      Michael Paquier authored
      When building an initial slot snapshot, snapshots are marked with
      historic MVCC snapshots as type with the marker field being set in
      SnapBuildBuildSnapshot() but not overriden in SnapBuildInitialSnapshot().
      Existing callers of SnapBuildBuildSnapshot() do not care about the type
      of snapshot used, but extensions calling it actually may, as reported.
      
      While on it, mark correctly the snapshot type when importing one.  This
      is cosmetic as the field is enforced to 0.
      
      Author: Antonin Houska
      Reviewed-by: Álvaro Herrera, Michael Paquier
      Discussion: https://postgr.es/m/23215.1527665193@localhost
      Backpatch-through: 9.4
      56fadbed
  4. 19 Feb, 2019 2 commits
  5. 18 Feb, 2019 10 commits
  6. 17 Feb, 2019 6 commits
    • Thomas Munro's avatar
      Fix race in dsm_unpin_segment() when handles are reused. · 0b55aaac
      Thomas Munro authored
      Teach dsm_unpin_segment() to skip segments that are in the process
      of being destroyed by another backend, when searching for a handle.
      Such a segment cannot possibly be the one we are looking for, even
      if its handle matches.  Another slot might hold a recently created
      segment that has the same handle value by coincidence, and we need
      to keep searching for that one.
      
      The bug caused rare "cannot unpin a segment that is not pinned"
      errors on 10 and 11.  Similar to commit 6c0fb941 for dsm_attach().
      
      Back-patch to 10, where dsm_unpin_segment() landed.
      
      Author: Thomas Munro
      Reported-by: Justin Pryzby
      Tested-by: Justin Pryzby (along with other recent DSA/DSM fixes)
      Discussion: https://postgr.es/m/20190216023854.GF30291@telsasoft.com
      0b55aaac
    • Joe Conway's avatar
      Fix documentation for dblink_error_message() return value · bc6d7eb6
      Joe Conway authored
      The dblink documentation claims that an empty string is returned if there
      has been no error, however OK is actually returned in that case. Also,
      clarify that an async error may not be seen unless dblink_is_busy() or
      dblink_get_result() have been called first.
      
      Backpatch to all supported branches.
      
      Reported-by: realyota
      Backpatch-through: 9.4
      Discussion: https://postgr.es/m/153371978486.1298.2091761143788088262@wrigleys.postgresql.org
      bc6d7eb6
    • Tom Lane's avatar
      Fix CREATE VIEW to allow zero-column views. · a32ca788
      Tom Lane authored
      We should logically have allowed this case when we allowed zero-column
      tables, but it was overlooked.
      
      Although this might be thought a feature addition, it's really a bug
      fix, because it was possible to create a zero-column view via
      the convert-table-to-view code path, and then you'd have a situation
      where dump/reload would fail.  Hence, back-patch to all supported
      branches.
      
      Arrange the added test cases to provide coverage of the related
      pg_dump code paths (since these views will be dumped and reloaded
      during the pg_upgrade regression test).  I also made them test
      the case where pg_dump has to postpone the view rule into post-data,
      which disturbingly had no regression coverage before.
      
      Report and patch by Ashutosh Sharma (test case by me)
      
      Discussion: https://postgr.es/m/CAE9k0PkmHdeSaeZt2ujnb_cKucmK3sDDceDzw7+d5UZoNJPYOg@mail.gmail.com
      a32ca788
    • Joe Conway's avatar
      Mark pg_config() stable rather than immutable · 290e3b77
      Joe Conway authored
      pg_config() has been marked immutable since its inception. As part of a
      larger discussion around the definition of immutable versus stable and
      related implications for marking functions parallel safe raised by
      Andres, the consensus was clearly that pg_config() is stable, since
      it could possibly change output even for the same minor version with
      a recompile or installation of a new binary. So mark it stable.
      
      Theoretically this could/should be backpatched, but it was deemed to be not
      worth the effort since in practice this is very unlikely to cause problems
      in the real world.
      
      Discussion: https://postgr.es/m/20181126234521.rh3grz7aavx2ubjv@alap3.anarazel.de
      290e3b77
    • Tatsuo Ishii's avatar
      Doc: remove ancient comment. · 69e52478
      Tatsuo Ishii authored
      There's a very old comment in rules.sgml added back to 2003.  It
      expected to a feature coming back but it never happened. So now we can
      safely remove the comment. Back-patched to all supported branches.
      
      Discussion: https://postgr.es/m/20190211.191004.219630835457494660.t-ishii%40sraoss.co.jp
      69e52478
    • Noah Misch's avatar
      Fix CLogTruncationLock documentation. · 301de4f7
      Noah Misch authored
      Back-patch to v10, which introduced the lock.
      301de4f7
  7. 16 Feb, 2019 2 commits