1. 21 Mar, 2020 5 commits
  2. 20 Mar, 2020 5 commits
  3. 19 Mar, 2020 11 commits
    • Peter Geoghegan's avatar
      nbtree: Remove obsolete _bt_pgaddtup() comments. · b27e1b34
      Peter Geoghegan authored
      Remove comments that are a throw back to a time when nbtree cared about
      write-ordering dependencies.  The comments are similar to those removed
      by commit 9ee7414e, among others.
      b27e1b34
    • Jeff Davis's avatar
      Revert "Specialize MemoryContextMemAllocated()." · 2fd6a44a
      Jeff Davis authored
      This reverts commit e00912e1.
      2fd6a44a
    • Bruce Momjian's avatar
      pg_upgrade: make get_major_server_version() err msg consistent · 2247a1ea
      Bruce Momjian authored
      This patch fixes the error message in get_major_server_version() to be
      "could not parse version file", and uses the full file path name, rather
      than just the data directory path.
      
      Also, commit 4109bb5d added the cause of the failure to the  "could
      not open" error message, and improved quoting.  This patch backpatches
      the "could not open" cause to PG 12, where it was first widely used, and
      backpatches the quoting fix in that patch to all supported releases.
      
      Reported-by: Tom Lane
      
      Discussion: https://postgr.es/m/87pne2w98h.fsf@wibble.ilmari.org
      
      Author: Dagfinn Ilmari Mannsåker
      
      Backpatch-through: 9.5
      2247a1ea
    • Alexander Korotkov's avatar
    • Tom Lane's avatar
      Introduce "anycompatible" family of polymorphic types. · 24e2885e
      Tom Lane authored
      This patch adds the pseudo-types anycompatible, anycompatiblearray,
      anycompatiblenonarray, and anycompatiblerange.  They work much like
      anyelement, anyarray, anynonarray, and anyrange respectively, except
      that the actual input values need not match precisely in type.
      Instead, if we can find a common supertype (using the same rules
      as for UNION/CASE type resolution), then the parser automatically
      promotes the input values to that type.  For example,
      "myfunc(anycompatible, anycompatible)" can match a call with one
      integer and one bigint argument, with the integer automatically
      promoted to bigint.  With anyelement in the definition, the user
      would have had to cast the integer explicitly.
      
      The new types also provide a second, independent set of type variables
      for function matching; thus with "myfunc(anyelement, anyelement,
      anycompatible) returns anycompatible" the first two arguments are
      constrained to be the same type, but the third can be some other
      type, and the result has the type of the third argument.  The need
      for more than one set of type variables was foreseen back when we
      first invented the polymorphic types, but we never did anything
      about it.
      
      Pavel Stehule, revised a bit by me
      
      Discussion: https://postgr.es/m/CAFj8pRDna7VqNi8gR+Tt2Ktmz0cq5G93guc3Sbn_NVPLdXAkqA@mail.gmail.com
      24e2885e
    • Fujii Masao's avatar
      Make pg_basebackup ask the server to estimate the total backup size, by default. · fab13dc5
      Fujii Masao authored
      This commit changes pg_basebackup so that it specifies PROGRESS option in
      BASE_BACKUP replication command whether --progress is specified or not.
      This causes the server to estimate the total backup size and report it in
      pg_stat_progress_basebackup.backup_total, by default. This is reasonable
      default because the time required for the estimation would not be so large
      in most cases.
      
      Also this commit adds new option --no-estimate-size to pg_basebackup.
      This option prevents the server from the estimation, and so is useful to
      avoid such estimation time if it's too long.
      
      Author: Fujii Masao
      Reviewed-by: Magnus Hagander, Amit Langote
      Discussion: https://postgr.es/m/CABUevEyDPPSjP7KRvfTXPdqOdY5aWNkqsB5aAXs3bco5ZwtGHg@mail.gmail.com
      fab13dc5
    • Peter Eisentraut's avatar
      Prepare to support non-tables in publications · c314c147
      Peter Eisentraut authored
      This by itself doesn't change any functionality but prepares the way
      for having relations other than base tables in publications.
      
      Make arrangements for COPY handling the initial table sync.  For
      non-tables we have to use COPY (SELECT ...) instead of directly
      copying from the table, but then we have to take care to omit
      generated columns from the column list.
      
      Also, remove a hardcoded reference to relkind = 'r' and rely on the
      publisher to send only what it can actually publish, which will be
      correct even in future cross-version scenarios.
      Reviewed-by: default avatarAmit Langote <amitlangote09@gmail.com>
      Discussion: https://www.postgresql.org/message-id/flat/CA+HiwqH=Y85vRK3mOdjEkqFK+E=ST=eQiHdpj43L=_eJMOOznQ@mail.gmail.com
      c314c147
    • Fujii Masao's avatar
      Rename the recovery-related wait events. · 1d253bae
      Fujii Masao authored
      This commit renames RecoveryWalAll and RecoveryWalStream wait events to
      RecoveryWalStream and RecoveryRetrieveRetryInterval, respectively,
      in order to make the names and what they are more consistent. For example,
      previously RecoveryWalAll was reported as a wait event while the recovery
      was waiting for WAL from a stream, and which was confusing because the name
      was very different from the situation where the wait actually could happen.
      
      The names of macro variables for those wait events also are renamed
      accordingly.
      
      This commit also changes the category of RecoveryRetrieveRetryInterval to
      Timeout from Activity because the wait event is reported while waiting based
      on wal_retrieve_retry_interval.
      
      Author: Fujii Masao
      Reviewed-by: Kyotaro Horiguchi, Atsushi Torikoshi
      Discussion: https://postgr.es/m/124997ee-096a-5d09-d8da-2c7a57d0816e@oss.nttdata.com
      1d253bae
    • Amit Kapila's avatar
      Add assert to ensure that page locks don't participate in deadlock cycle. · 72e78d83
      Amit Kapila authored
      Assert that we don't acquire any other heavyweight lock while holding the
      page lock except for relation extension.  However, these locks are never
      taken in reverse order which implies that page locks will never
      participate in the deadlock cycle.
      
      Similar to relation extension, page locks are also held for a short
      duration, so imposing such a restriction won't hurt.
      
      Author: Dilip Kumar, with few changes by Amit Kapila
      Reviewed-by: Amit Kapila, Kuntal Ghosh and Sawada Masahiko
      Discussion: https://postgr.es/m/CAD21AoCmT3cFQUN4aVvzy5chw7DuzXrJCbrjTU05B+Ss=Gn1LA@mail.gmail.com
      72e78d83
    • Peter Geoghegan's avatar
      nbtree: Use raw PageAddItem() for retail inserts. · 6312c08a
      Peter Geoghegan authored
      Only internal page splits need to call _bt_pgaddtup() instead of
      PageAddItem(), and only for data items, one of which will end up at the
      first offset (or first offset after the high key offset) on the new
      right page.  This data item alone will need to be truncated in
      _bt_pgaddtup().
      
      Since there is no reason why retail inserts ever need to truncate the
      incoming item, use a raw PageAddItem() call there instead.  Even
      _bt_split() uses raw PageAddItem() calls for left page and right page
      high keys.  Clearly the _bt_pgaddtup() shim function wasn't really
      encapsulating anything.  _bt_pgaddtup() should now be thought of as a
      _bt_split() helper function.
      
      Note that the assertions from commit d1e241c2 verify that retail inserts
      never insert an item at an internal page's negative infinity offset.
      This invariant could only ever be violated as a result of a basic logic
      error in nbtinsert.c.
      6312c08a
    • Michael Paquier's avatar
      Fix comment related to concurrent index swapping in index.c · d41202f3
      Michael Paquier authored
      A comment about switching indisvalid of the new and old indexes swapped
      in REINDEX CONCURRENTLY got this backwards.
      
      Issue introduced by 5dc92b84, the original commit of REINDEX
      CONCURRENTLY.
      
      Author: Julien Rouhaud
      Discussion: https://postgr.es/m/20200318143340.GA46897@nol
      Backpatch-through: 12
      d41202f3
  4. 18 Mar, 2020 17 commits
  5. 17 Mar, 2020 2 commits
    • Tom Lane's avatar
      Refactor our checks for valid function and aggregate signatures. · e6c178b5
      Tom Lane authored
      pg_proc.c and pg_aggregate.c had near-duplicate copies of the logic
      to decide whether a function or aggregate's signature is legal.
      This seems like a bad thing even without the problem that the
      upcoming "anycompatible" patch would roughly double the complexity
      of that logic.  Hence, refactor so that the rules are localized
      in new subroutines supplied by parse_coerce.c.  (One could quibble
      about just where to add that code, but putting it beside
      enforce_generic_type_consistency seems not totally unreasonable.)
      
      The fact that the rules are about to change would mandate some
      changes in the wording of the associated error messages in any case.
      I ended up spelling things out in a fairly literal fashion in the
      errdetail messages, eg "A result of type anyelement requires at
      least one input of type anyelement, anyarray, anynonarray, anyenum,
      or anyrange."  Perhaps this is overkill, but once there's more than
      one subgroup of polymorphic types, people might get confused by
      more-abstract messages.
      
      Discussion: https://postgr.es/m/24137.1584139352@sss.pgh.pa.us
      e6c178b5
    • Peter Geoghegan's avatar
      Doc: Correct deduplicate_items varlistentry id. · dbbb5538
      Peter Geoghegan authored
      Use a varlistentry id for the deduplicate_items storage parameter that
      is derived from the name of the parameter itself.
      
      This oversight happened because the storage parameter was renamed
      relatively late during the development of the patch that became commit
      0d861bbb.
      dbbb5538