1. 15 Mar, 2019 5 commits
  2. 14 Mar, 2019 13 commits
  3. 13 Mar, 2019 9 commits
  4. 12 Mar, 2019 7 commits
    • Peter Geoghegan's avatar
      Correct obsolete nbtree page split comment. · 3f342839
      Peter Geoghegan authored
      Commit 40dae7ec, which made the nbtree page split algorithm more
      robust, made _bt_insert_parent() only unlock the right child of the
      parent page before inserting a new downlink into the parent.  Update a
      comment from the Berkeley days claiming that both left and right child
      pages are unlocked before the new downlink actually gets inserted.
      
      The claim that it is okay to release both locks early based on Lehman
      and Yao's say-so never made much sense.  Lehman and Yao must sometimes
      "couple" buffer locks across a pair of internal pages when relocating a
      downlink, unlike the corresponding code within _bt_getstack().
      3f342839
    • Tom Lane's avatar
      Add support for hyperbolic functions, as well as log10(). · f1d85aa9
      Tom Lane authored
      The SQL:2016 standard adds support for the hyperbolic functions
      sinh(), cosh(), and tanh().  POSIX has long required libm to
      provide those functions as well as their inverses asinh(),
      acosh(), atanh().  Hence, let's just expose the libm functions
      to the SQL level.  As with the trig functions, we only implement
      versions for float8, not numeric.
      
      For the moment, we'll assume that all platforms actually do have
      these functions; if experience teaches otherwise, some autoconf
      effort may be needed.
      
      SQL:2016 also adds support for base-10 logarithm, but with the
      function name log10(), whereas the name we've long used is log().
      Add aliases named log10() for the float8 and numeric versions.
      
      Lætitia Avrot
      
      Discussion: https://postgr.es/m/CAB_COdguG22LO=rnxDQ2DW1uzv8aQoUzyDQNJjrR4k00XSgm5w@mail.gmail.com
      f1d85aa9
    • Tom Lane's avatar
      Remove remaining hard-wired OID references in the initial catalog data. · 3aa0395d
      Tom Lane authored
      In the v11-era commits that taught genbki.pl to resolve symbolic
      OID references in the initial catalog data, we didn't bother to
      make every last reference symbolic; some of the catalogs have so
      few initial rows that it didn't seem worthwhile.
      
      However, the new project policy that OIDs assigned by new patches
      should be automatically renumberable changes this calculus.
      A patch that wants to add a row in one of these catalogs would have
      a problem when the OID it assigns gets renumbered.  Hence, do the
      mop-up work needed to make all OID references in initial data be
      symbolic, and establish an associated project policy that we'll
      never again write a hard-wired OID reference there.
      
      No catversion bump since the contents of postgres.bki aren't
      actually changed by this commit.
      
      Discussion: https://postgr.es/m/CAH2-WzmMTGMcPuph4OvsO7Ykut0AOCF_i-=eaochT0dd2BN9CQ@mail.gmail.com
      3aa0395d
    • Tom Lane's avatar
      Create a script that can renumber manually-assigned OIDs. · a6417078
      Tom Lane authored
      This commit adds a Perl script renumber_oids.pl, which can reassign a
      range of manually-assigned OIDs to someplace else by modifying OID
      fields of the catalog *.dat files and OID-assigning macros in the
      catalog *.h files.
      
      Up to now, we've encouraged new patches that need manually-assigned
      OIDs to use OIDs just above the range of existing OIDs.  Predictably,
      this leads to patches stepping on each others' toes, as whichever
      one gets committed first creates an OID conflict that other patch
      author(s) have to resolve manually.  With the availability of
      renumber_oids.pl, we can eliminate a lot of this hassle.
      The new project policy, therefore, is:
      
      * Encourage new patches to use high OIDs (the documentation suggests
      choosing a block of OIDs at random in 8000..9999).
      
      * After feature freeze in each development cycle, run renumber_oids.pl
      to move all such OIDs down to lower numbers, thus freeing the high OID
      range for the next development cycle.
      
      This plan should greatly reduce the risk of OID collisions between
      concurrently-developed patches.  Also, if such a collision happens
      anyway, we have the option to resolve it without much effort by doing
      an off-schedule OID renumbering to get the first-committed patch out
      of the way.  Or a patch author could use renumber_oids.pl to change
      their patch's assignments without much pain.
      
      This approach does put a premium on not hard-wiring any OID values
      in places where renumber_oids.pl and genbki.pl can't fix them.
      Project practice in that respect seems to be pretty good already,
      but a follow-on patch will sand down some rough edges.
      
      John Naylor and Tom Lane, per an idea of Peter Geoghegan's
      
      Discussion: https://postgr.es/m/CAH2-WzmMTGMcPuph4OvsO7Ykut0AOCF_i-=eaochT0dd2BN9CQ@mail.gmail.com
      a6417078
    • Etsuro Fujita's avatar
      Fix testing of parallel-safety of scan/join target. · b5afdde6
      Etsuro Fujita authored
      In commit 960df2a9 ("Correctly assess parallel-safety of tlists when
      SRFs are used."), the testing of scan/join target was done incorrectly,
      which caused a plan-quality problem.  Backpatch through to v11 where
      the aforementioned commit went in, since this is a regression from v10.
      
      Author: Etsuro Fujita
      Reviewed-by: Robert Haas and Tom Lane
      Discussion: https://postgr.es/m/5C75303E.8020303@lab.ntt.co.jp
      b5afdde6
    • Amit Kapila's avatar
      Add more tests for FSM. · 6f918159
      Amit Kapila authored
      In commit b0eaa4c5, we left out a test that used a vacuum to remove dead
      rows as the behavior of test was not predictable.  This test has been
      rewritten to use fillfactor instead to control free space.  Since we no
      longer need to remove dead rows as part of the test, put the fsm regression
      test in a parallel group.
      
      Author: John Naylor
      Reviewed-by: Amit Kapila
      Discussion: https://postgr.es/m/CAA4eK1L=qWp_bJ5aTc9+fy4Ewx2LPaLWY-RbR4a60g_rupCKnQ@mail.gmail.com
      6f918159
    • Michael Paquier's avatar
      Add routine able to update the control file to src/common/ · ce6afc68
      Michael Paquier authored
      This adds a new routine to src/common/ which is compatible with both the
      frontend and backend code, able to update the control file's contents.
      This is now getting used only by pg_rewind, but some upcoming patches
      which add more control on checksums for offline instances will make use
      of it.  This could also get used more by the backend as xlog.c has its
      own flavor of the same logic with some wait events and an additional
      flush phase before closing the opened file descriptor, but this is let
      as separate work.
      
      Author: Michael Banck, Michael Paquier
      Reviewed-by: Fabien Coelho, Sergei Kornilov
      Discussion: https://postgr.es/m/20181221201616.GD4974@nighthawk.caipicrew.dd-dns.de
      ce6afc68
  5. 11 Mar, 2019 6 commits