1. 23 Dec, 2019 6 commits
    • Joe Conway's avatar
      Disallow null category in crosstab_hash · d5b9c2ba
      Joe Conway authored
      While building a hash map of categories in load_categories_hash,
      resulting category names have not thus far been checked to ensure
      they are not null. Prior to pg12 null category names worked to the
      extent that they did not crash on some platforms. This is because
      those system libraries have an snprintf which can deal with being
      passed a null pointer argument for a string. But even in those cases
      null categories did nothing useful. And on some platforms it crashed.
      As of pg12, our own version of snprintf gets called, and it does
      not deal with null pointer arguments at all, and crashes consistently.
      
      Fix that by disallowing null categories. They never worked usefully,
      and no one has ever asked for them to work previously. Back-patch to
      all supported branches.
      
      Reported-By: Ireneusz Pluta
      Discussion: https://postgr.es/m/16176-7489719b05e4303c@postgresql.org
      d5b9c2ba
    • Tom Lane's avatar
      Disallow partition key expressions that return pseudo-types. · 39ebb943
      Tom Lane authored
      This wasn't checked originally, but it should have been, because
      in general pseudo-types can't be stored to and retrieved from disk.
      Notably, partition bound values of type "record" would not be
      interpretable by another session.
      
      In v12 and HEAD, add another flag to CheckAttributeType's repertoire
      so that it can produce a specific error message for this case.  That's
      infeasible in older branches without an ABI break, so fall back to
      a slightly-less-nicely-worded error message in v10 and v11.
      
      Problem noted by Amit Langote, though this patch is not his initial
      solution.  Back-patch to v10 where partitioning was introduced.
      
      Discussion: https://postgr.es/m/CA+HiwqFUzjfj9HEsJtYWcr1SgQ_=iCAvQ=O2Sx6aQxoDu4OiHw@mail.gmail.com
      39ebb943
    • Tom Lane's avatar
      Prevent a rowtype from being included in itself via a range. · fc769589
      Tom Lane authored
      We probably should have thought of this case when ranges were added,
      but we didn't.  (It's not the fault of commit eb51af71, because
      ranges didn't exist then.)
      
      It's an old bug, so back-patch to all supported branches.
      
      Discussion: https://postgr.es/m/7782.1577051475@sss.pgh.pa.us
      fc769589
    • Alvaro Herrera's avatar
      GetPublicationByName: Don't repeat ourselves · 0fd8cfb2
      Alvaro Herrera authored
      Use get_publication_oid() instead of reimplementing it.
      
      Discussion: https://postgr.es/m/20191220201017.GA17292@alvherre.pgsql
      0fd8cfb2
    • Peter Geoghegan's avatar
      Normalize _bt_finish_split() argument names. · 696cc3a0
      Peter Geoghegan authored
      Make a function prototype argument's name match the function
      definition's argument name.
      696cc3a0
    • Peter Geoghegan's avatar
      Update nbtree LP_DEAD item deletion comments. · fe97c61c
      Peter Geoghegan authored
      Comments about the consequences of clearing the BTP_HAS_GARBAGE page
      flag bit that apply only to VACUUM were added to code that deals with
      opportunistic deletion of LP_DEAD items by commit a760893d.  The same
      comment block was added to both _bt_delitems_vacuum() and
      _bt_delitems_delete().  Correct _bt_delitems_delete()'s copy of the
      comment block.
      
      _bt_delitems_delete() reliably deletes items that were found by caller
      to have their LP_DEAD bit set.  There is no question about whether or
      not unsetting the BTP_HAS_GARBAGE bit can miss some LP_DEAD items that
      were set recently.
      
      Also tweak a related section of the nbtree README.
      fe97c61c
  2. 22 Dec, 2019 2 commits
  3. 21 Dec, 2019 3 commits
    • Tom Lane's avatar
      In pgwin32_open, loop after ERROR_ACCESS_DENIED only if we can't stat. · 5406513e
      Tom Lane authored
      This fixes a performance problem introduced by commit 6d7547c2.
      ERROR_ACCESS_DENIED is returned in some other cases besides the
      delete-pending case considered by that commit; notably, if the
      given path names a directory instead of a plain file.  In that
      case we'll uselessly loop for 1 second before returning the
      failure condition.  That slows down some usage scenarios enough
      to cause test timeout failures on our Windows buildfarm critters.
      
      To fix, try to stat() the file, and sleep/loop only if that fails.
      It will fail in the delete-pending case, and also in the case where
      the deletion completed before we could stat(), so we have the cases
      where we want to loop covered.  In the directory case, the stat()
      should succeed, letting us exit without a wait.
      
      One case where we'll still wait uselessly is if the access-denied
      problem pertains to a directory in the given pathname.  But we don't
      expect that to happen in any performance-critical code path.
      
      There might be room to refine this further, but I'll push it now
      in hopes of making the buildfarm green again.
      
      Back-patch, like the preceding commit.
      
      Alexander Lakhin and Tom Lane
      
      Discussion: https://postgr.es/m/23073.1576626626@sss.pgh.pa.us
      5406513e
    • Bruce Momjian's avatar
      C comment: clarify why psql's help/exit/quit must alone · 4376fdba
      Bruce Momjian authored
      Document why no indentation and why no non-whitespace postfix is
      supported.
      
      Backpatch-through: master
      4376fdba
    • Bruce Momjian's avatar
      docs: clarify handling of column lists in COPY TO/FROM · 4cab43ec
      Bruce Momjian authored
      Previously it was unclear how COPY FROM handled cases where not all
      columns were specified, or if the order didn't match.
      
      Reported-by: pavlo.golub@gmail.com
      
      Discussion: https://postgr.es/m/157487729344.7213.14245726713444755296@wrigleys.postgresql.org
      
      Backpatch-through: 9.4
      4cab43ec
  4. 20 Dec, 2019 7 commits
  5. 19 Dec, 2019 9 commits
  6. 18 Dec, 2019 11 commits
  7. 17 Dec, 2019 2 commits
    • Tom Lane's avatar
      Fix error reporting for index expressions of prohibited types. · 2acab054
      Tom Lane authored
      If CheckAttributeType() threw an error about the datatype of an
      index expression column, it would report an empty column name,
      which is pretty unhelpful and certainly not the intended behavior.
      I (tgl) evidently broke this in commit cfc5008a, by not noticing
      that the column's attname was used above where I'd placed the
      assignment of it.
      
      In HEAD and v12, this is trivially fixable by moving up the
      assignment of attname.  Before v12 the code is a bit more messy;
      to avoid doing substantial refactoring, I took the lazy way out
      and just put in two copies of the assignment code.
      
      Report and patch by Amit Langote.  Back-patch to all supported
      branches.
      
      Discussion: https://postgr.es/m/CA+HiwqFA+BGyBFimjiYXXMa2Hc3fcL0+OJOyzUNjhU4NCa_XXw@mail.gmail.com
      2acab054
    • Robert Haas's avatar
      Fix bad formula in previous commit. · 5184f110
      Robert Haas authored
      Commit d5406dea used a slightly
      novel, and wrong, approach to compute the length of the last
      toast chunk. It worked fine unless the last chunk happened to
      have the largest possible size.
      5184f110