1. 07 May, 2019 1 commit
  2. 06 May, 2019 5 commits
    • Bruce Momjian's avatar
      docs: fist draft version of the PG 12 release notes · bdf595ad
      Bruce Momjian authored
      Still needs text markup, links, word wrap, and indenting.
      bdf595ad
    • Alvaro Herrera's avatar
      Revert "Make pg_dump emit ATTACH PARTITION instead of PARTITION OF" · a1ec7402
      Alvaro Herrera authored
      ... and fallout (from branches 10, 11 and master).  The change was
      ill-considered, and it broke a few normal use cases; since we don't have
      time to fix it, we'll try again after this week's minor releases.
      
      Reported-by: Rushabh Lathia
      Discussion: https://postgr.es/m/CAGPqQf0iQV=PPOv2Btog9J9AwOQp6HmuVd6SbGTR_v3Zp2XT1w@mail.gmail.com
      a1ec7402
    • Michael Paquier's avatar
      Add tests for error message generation in partition tuple routing · 91248608
      Michael Paquier authored
      This adds extra tests for the error message generated for partition
      tuple routing in the executor, using more than three levels of
      partitioning including partitioned tables with no partitions.  These
      tests have been added to fix CVE-2019-10129 on REL_11_STABLE.  HEAD has
      no active bugs in this area, but it lacked coverage.
      
      Author: Michael Paquier
      Reviewed-by: Noah Misch
      Security: CVE-2019-10129
      91248608
    • Dean Rasheed's avatar
      Use checkAsUser for selectivity estimator checks, if it's set. · a0905056
      Dean Rasheed authored
      In examine_variable() and examine_simple_variable(), when checking the
      user's table and column privileges to determine whether to grant
      access to the pg_statistic data, use checkAsUser for the privilege
      checks, if it's set. This will be the case if we're accessing the
      table via a view, to indicate that we should perform privilege checks
      as the view owner rather than the current user.
      
      This change makes this planner check consistent with the check in the
      executor, so the planner will be able to make use of statistics if the
      table is accessible via the view. This fixes a performance regression
      introduced by commit e2d4ef8d, which affects queries against
      non-security barrier views in the case where the user doesn't have
      privileges on the underlying table, but the view owner does.
      
      Note that it continues to provide the same safeguards controlling
      access to pg_statistic for direct table access (in which case
      checkAsUser won't be set) and for security barrier views, because of
      the nearby checks on rte->security_barrier and rte->securityQuals.
      
      Back-patch to all supported branches because e2d4ef8d was.
      
      Dean Rasheed, reviewed by Jonathan Katz and Stephen Frost.
      a0905056
    • Dean Rasheed's avatar
      Fix security checks for selectivity estimation functions with RLS. · 1aebfbea
      Dean Rasheed authored
      In commit e2d4ef8d, security checks were added to prevent
      user-supplied operators from running over data from pg_statistic
      unless the user has table or column privileges on the table, or the
      operator is leakproof. For a table with RLS, however, checking for
      table or column privileges is insufficient, since that does not
      guarantee that the user has permission to view all of the column's
      data.
      
      Fix this by also checking for securityQuals on the RTE, and insisting
      that the operator be leakproof if there are any. Thus the
      leakproofness check will only be skipped if there are no securityQuals
      and the user has table or column privileges on the table -- i.e., only
      if we know that the user has access to all the data in the column.
      
      Back-patch to 9.5 where RLS was added.
      
      Dean Rasheed, reviewed by Jonathan Katz and Stephen Frost.
      
      Security: CVE-2019-10130
      1aebfbea
  3. 05 May, 2019 3 commits
    • Tom Lane's avatar
      Bring pg_nextoid()'s error messages into line with message style guide. · bd5e8b62
      Tom Lane authored
      Noticed while reviewing nearby code.  Given all the disclaimers about
      this not being meant as user-facing code, I wonder whether we should
      make these non-translatable?  But in any case there's little excuse
      for them not to be good English.
      bd5e8b62
    • Tom Lane's avatar
      Fix style violations in syscache lookups. · 9691aa72
      Tom Lane authored
      Project style is to check the success of SearchSysCacheN and friends
      by applying HeapTupleIsValid to the result.  A tiny minority of calls
      creatively did it differently.  Bring them into line with the rest.
      
      This is just cosmetic, since HeapTupleIsValid is indeed just a null
      check at the moment ... but that may not be true forever, and in any
      case it puts a mental burden on readers who may wonder why these
      call sites are not like the rest.
      
      Back-patch to v11 just to keep the branches in sync.  (The bulk of these
      errors seem to have originated in v11 or v12, though a few are old.)
      
      Per searching to see if anyplace else had made the same error
      repaired in 62148c35.
      9691aa72
    • Tom Lane's avatar
      Add check for syscache lookup failure in update_relispartition(). · 62148c35
      Tom Lane authored
      Omitted in commit 05b38c7e (though it looks like the original blame
      belongs to 9e9befac).  A failure is admittedly unlikely, but if it
      did happen, SIGSEGV is not the approved method of reporting it.
      
      Per Coverity.  Back-patch to v11 where the broken code originated.
      62148c35
  4. 04 May, 2019 3 commits
  5. 03 May, 2019 3 commits
  6. 02 May, 2019 4 commits
    • Tom Lane's avatar
      Fix reindexing of pg_class indexes some more. · f912d7de
      Tom Lane authored
      Commits 3dbb317d et al failed under CLOBBER_CACHE_ALWAYS testing.
      Investigation showed that to reindex pg_class_oid_index, we must
      suppress accesses to the index (via SetReindexProcessing) before we call
      RelationSetNewRelfilenode, or at least before we do CommandCounterIncrement
      therein; otherwise, relcache reloads happening within the CCI may try to
      fetch pg_class rows using the index's new relfilenode value, which is as
      yet an empty file.
      
      Of course, the point of 3dbb317d was that that ordering didn't work
      either, because then RelationSetNewRelfilenode's own update of the index's
      pg_class row cannot access the index, should it need to.
      
      There are various ways we might have got around that, but Andres Freund
      came up with a brilliant solution: for a mapped index, we can really just
      skip the pg_class update altogether.  The only fields it was actually
      changing were relpages etc, but it was just setting them to zeroes which
      is useless make-work.  (Correct new values will be installed at the end
      of index build.)  All pg_class indexes are mapped and probably always will
      be, so this eliminates the problem by removing work rather than adding it,
      always a pleasant outcome.  Having taught RelationSetNewRelfilenode to do
      it that way, we can revert the code reordering in reindex_index.  (But
      I left the moved setup code where it was; there seems no reason why it
      has to run without use of the old index.  If you're trying to fix a
      busted pg_class index, you'll have had to disable system index use
      altogether to get this far.)
      
      Moreover, this means we don't need RelationSetIndexList at all, because
      reindex_relation's hacking to make "REINDEX TABLE pg_class" work is
      likewise now unnecessary.  We'll leave that code in place in the back
      branches, but a follow-on patch will remove it in HEAD.
      
      In passing, do some minor cleanup for commit 5c156060 (in HEAD only),
      notably removing a duplicate newrnode assignment.
      
      Patch by me, using a core idea due to Andres Freund.  Back-patch to all
      supported branches, as 3dbb317d was.
      
      Discussion: https://postgr.es/m/28926.1556664156@sss.pgh.pa.us
      f912d7de
    • Alvaro Herrera's avatar
      heap_prepare_freeze_tuple: Simplify coding · 2bf372a4
      Alvaro Herrera authored
      Commit d2599ecf introduced some contorted, confused code around:
      readers would think that it's possible for HeapTupleHeaderGetXmin return
      a non-frozen value for some frozen tuples, which would be disastrous.
      There's no actual bug, but it seems better to make it clearer.
      
      Per gripe from Tom Lane and Andres Freund.
      Discussion: https://postgr.es/m/30116.1555430496@sss.pgh.pa.us
      2bf372a4
    • Peter Geoghegan's avatar
      Fix nbtsort.c's page space accounting. · 6dd86c26
      Peter Geoghegan authored
      Commit dd299df8, which made heap TID a tiebreaker nbtree index
      column, introduced new rules on page space management to make suffix
      truncation safe.  In general, suffix truncation needs to have a small
      amount of extra space available on the new left page when splitting a
      leaf page.  This is needed in case it turns out that truncation cannot
      even "truncate away the heap TID column", resulting in a
      larger-than-firstright leaf high key with an explicit heap TID
      representation.
      
      Despite all this, CREATE INDEX/nbtsort.c did not account for the
      possible need for extra heap TID space on leaf pages when deciding
      whether or not a new item could fit on current page.  This could lead to
      "failed to add item to the index page" errors when CREATE
      INDEX/nbtsort.c tried to finish off a leaf page that lacked space for a
      larger-than-firstright leaf high key (it only had space for firstright
      tuple, which was just short of what was needed following "truncation").
      
      Several conditions needed to be met all at once for CREATE INDEX to
      fail.  The problem was in the hard limit on what will fit on a page,
      which tends to be masked by the soft fillfactor-wise limit.  The easiest
      way to recreate the problem seems to be a CREATE INDEX on a low
      cardinality text column, with tuples that are of non-uniform width,
      using a fillfactor of 100.
      
      To fix, bring nbtsort.c in line with nbtsplitloc.c, which already
      pessimistically assumes that all leaf page splits will have high keys
      that have a heap TID appended.
      
      Reported-By: Andreas Joseph Krogh
      Discussion: https://postgr.es/m/VisenaEmail.c5.3ee7fe277d514162.16a6d785bea@tc7-visena
      6dd86c26
    • Robert Haas's avatar
      Fix some problems with VACUUM (INDEX_CLEANUP FALSE). · dd695979
      Robert Haas authored
      The new nleft_dead_tuples and nleft_dead_itemids fields are confusing
      and do not seem like the correct way forward.  One of them is tested
      via an assertion that can fail, as it has already done on buildfarm
      member topminnow.  Remove the assertion and the fields.
      
      Change the logic for the case where a tuple is not initially pruned
      by heap_page_prune but later diagnosed HEAPTUPLE_DEAD by
      HeapTupleSatisfiesVacuum.  Previously, tupgone = true was set in
      that case, which leads to treating the tuple as one that will be
      removed.  In a normal vacuum, that's OK, because we'll remove
      index entries for it and then the second heap pass will remove the
      tuple itself, but when index cleanup is disabled, those things
      don't happen, so we must instead treat it as a recently-dead
      tuple that we have voluntarily chosen to keep.
      
      Report and analysis by Tom Lane.  This patch loosely based on one
      from Masahiko Sawada, but I changed most of it.
      dd695979
  7. 01 May, 2019 4 commits
    • Bruce Momjian's avatar
      doc: clarify behavior of pg_upgrade's clone mode · 26950273
      Bruce Momjian authored
      Be more precise about the benefits of using clone mode.
      26950273
    • Magnus Hagander's avatar
      Fix union for pgstat message types · 659e5349
      Magnus Hagander authored
      The message type for temp files and for checksum failures were missing
      from the union. Due to the coding style used there was no compiler error
      when this happend. So change the code to actively use the union thereby
      producing a compiler error if the same mistake happens again, suggested
      by Tom Lane.
      
      Author: Julien Rouhaud
      Reported-By: Tomas Vondra
      Discussion: https://postgr.es/m/20190430163328.zd4rrlnbvgaqlcdz@development
      659e5349
    • Andres Freund's avatar
      Run catalog reindexing test from 3dbb317d serially, to avoid deadlocks. · 809c9b48
      Andres Freund authored
      The tests turn out to cause deadlocks in some circumstances. Fairly
      reproducibly so with -DRELCACHE_FORCE_RELEASE
      -DCATCACHE_FORCE_RELEASE.  Some of the deadlocks may be hard to fix
      without disproportionate measures, but others probably should be fixed
      - but not in 12.
      
      We discussed removing the new tests until we can fix the issues
      underlying the deadlocks, but results from buildfarm animal
      markhor (which runs with CLOBBER_CACHE_ALWAYS) indicates that there
      might be a more severe, as of yet undiagnosed, issue (including on
      stable branches) with reindexing catalogs. The failure is:
      ERROR: could not read block 0 in file "base/16384/28025": read only 0 of 8192 bytes
      Therefore it seems advisable to keep the tests.
      
      It's not certain that running the tests in isolation removes the risk
      of deadlocks. It's possible that additional locks are needed to
      protect against a concurrent auto-analyze or such.
      
      Per discussion with Tom Lane.
      
      Discussion: https://postgr.es/m/28926.1556664156@sss.pgh.pa.us
      Backpatch: 9.4-, like 3dbb317d
      809c9b48
    • Andres Freund's avatar
      Fix unused variable compiler warning in !debug builds. · 4b40d40b
      Andres Freund authored
      Introduced in 3dbb317d.  Fix by using the new local variable in more
      places.
      
      Reported-By: Bruce Momjian (off-list)
      Backpatch: 9.4-, like 3dbb317d
      4b40d40b
  8. 30 Apr, 2019 10 commits
    • Andres Freund's avatar
      b06a354e
    • Andres Freund's avatar
    • Andres Freund's avatar
      Improve code inferring length of bitmap for JITed tuple deforming. · 3a48005b
      Andres Freund authored
      While discussing comment improvements (see next commit) by Justin
      Pryzby, Tom complained about a few details of the logic to infer the
      length of the NULL bitmap when building the JITed tuple deforming
      function. That bitmap allows to avoid checking the tuple header's
      natts, a check which often causes a pipeline stall
      
      Improvements:
      a) As long as missing columns aren't taken into account, we can
         continue to infer the length of the NULL bitmap from NOT NULL
         columns following it. Previously we stopped at the first missing
         column.  It's unlikely to matter much in practice, but the
         alternative would have been to document why we stop.
      b) For robustness reasons it seems better to also check against
         attisdropped - RemoveAttributeById() sets attnotnull to false, but
         an additional check is trivial.
      c) Improve related comments
      
      Discussion: https://postgr.es/m/20637.1555957068@sss.pgh.pa.us
      Backpatch: -
      3a48005b
    • Tom Lane's avatar
      Clean up handling of constraint_exclusion and enable_partition_pruning. · e03ff739
      Tom Lane authored
      The interaction of these parameters was a bit confused/confusing,
      and in fact v11 entirely misses the opportunity to apply partition
      constraints when a partition is accessed directly (rather than
      indirectly from its parent).
      
      In HEAD, establish the principle that enable_partition_pruning controls
      partition pruning and nothing else.  When accessing a partition via its
      parent, we do partition pruning (if enabled by enable_partition_pruning)
      and then there is no need to consider partition constraints in the
      constraint_exclusion logic.  When accessing a partition directly, its
      partition constraints are applied by the constraint_exclusion logic,
      only if constraint_exclusion = on.
      
      In v11, we can't have such a clean division of these GUCs' effects,
      partly because we don't want to break compatibility too much in a
      released branch, and partly because the clean coding requires
      inheritance_planner to have applied partition pruning to a partitioned
      target table, which it doesn't in v11.  However, we can tweak things
      enough to cover the missed case, which seems like a good idea since
      it's potentially a performance regression from v10.  This patch keeps
      v11's previous behavior in which enable_partition_pruning overrides
      constraint_exclusion for an inherited target table, though.
      
      In HEAD, also teach relation_excluded_by_constraints that it's okay to use
      inheritable constraints when trying to prune a traditional inheritance
      tree.  This might not be thought worthy of effort given that that feature
      is semi-deprecated now, but we have enough infrastructure that it only
      takes a couple more lines of code to do it correctly.
      
      Amit Langote and Tom Lane
      
      Discussion: https://postgr.es/m/9813f079-f16b-61c8-9ab7-4363cab28d80@lab.ntt.co.jp
      Discussion: https://postgr.es/m/29069.1555970894@sss.pgh.pa.us
      e03ff739
    • Bruce Momjian's avatar
      ad23adc5
    • Bruce Momjian's avatar
    • Alvaro Herrera's avatar
      Message style fixes · 9f8b717a
      Alvaro Herrera authored
      9f8b717a
    • Alvaro Herrera's avatar
      Widen tuple counter variables from long to int64 · 9a83afec
      Alvaro Herrera authored
      Mistake in ab0dfc96; progress reporting would have wrapped around
      for indexes created with more than 2^31 tuples.
      
      Reported-by: Peter Geoghegan
      Discussion: https://postgr.es/m/CAH2-Wz=WbNxc5ob5NJ9yqo2RMJ0q4HXDS30GVCobeCvC9A1L9A@mail.gmail.com
      9a83afec
    • Andres Freund's avatar
      Fix potential assertion failure when reindexing a pg_class index. · 3dbb317d
      Andres Freund authored
      When reindexing individual indexes on pg_class it was possible to
      either trigger an assertion failure:
      TRAP: FailedAssertion("!(!ReindexIsProcessingIndex(((index)->rd_id)))
      
      That's because reindex_index() called SetReindexProcessing() - which
      enables an asserts ensuring no index insertions happen into the index
      - before calling RelationSetNewRelfilenode(). That not correct for
      indexes on pg_class, because RelationSetNewRelfilenode() updates the
      relevant pg_class row, which needs to update the indexes.
      
      The are two reasons this wasn't noticed earlier. Firstly the bug
      doesn't trigger when reindexing all of pg_class, as reindex_relation
      has code "hiding" all yet-to-be-reindexed indexes. Secondly, the bug
      only triggers when the the update to pg_class doesn't turn out to be a
      HOT update - otherwise there's no index insertion to trigger the
      bug. Most of the time there's enough space, making this bug hard to
      trigger.
      
      To fix, move RelationSetNewRelfilenode() to before the
      SetReindexProcessing() (and, together with some other code, to outside
      of the PG_TRY()).
      
      To make sure the error checking intended by SetReindexProcessing() is
      more robust, modify CatalogIndexInsert() to check
      ReindexIsProcessingIndex() even when the update is a HOT update.
      
      Also add a few regression tests for REINDEXing of system catalogs.
      
      The last two improvements would have prevented some of the issues
      fixed in 5c156060 from being introduced in the first place.
      
      Reported-By: Michael Paquier
      Diagnosed-By: Tom Lane and Andres Freund
      Author: Andres Freund
      Reviewed-By: Tom Lane
      Discussion: https://postgr.es/m/20190418011430.GA19133@paquier.xyz
      Backpatch: 9.4-, the bug is present in all branches
      3dbb317d
    • Andres Freund's avatar
      Fix several recently introduced issues around handling new relation forks. · 5c156060
      Andres Freund authored
      Most of these stem from d25f5191 "tableam: relation creation, VACUUM
      FULL/CLUSTER, SET TABLESPACE.".
      
      1) To pass data to the relation_set_new_filenode()
         RelationSetNewRelfilenode() was made to update RelationData.rd_rel
         directly. That's not OK however, as it makes the relcache entries
         temporarily inconsistent. Which among other scenarios is a problem
         if a REINDEX targets an index on pg_class - the
         CatalogTupleUpdate() in RelationSetNewRelfilenode().  Presumably
         that was introduced because other places in the code do so - while
         those aren't "good practice" they don't appear to be actively
         buggy (e.g. because system tables may not be targeted).
      
         I (Andres) should have caught this while reviewing and signficantly
         evolving the code in that commit, mea culpa.
      
         Fix that by instead passing in the new RelFileNode as separate
         argument to relation_set_new_filenode() and rely on the relcache to
         update the catalog entry. Also revert that the
         RelationMapUpdateMap() call was changed to immediate, and undo some
         other more unnecessary changes.
      
      2) Document that the relation_set_new_filenode cannot rely on the
         whole relcache entry to be valid. It might be worthwhile to
         refactor the code to never have to rely on that, but given the way
         heap_create() is currently coded, that'd be a large change.
      
      3) ATExecSetTableSpace() shouldn't do FlushRelationBuffers() itself. A
         table AM might not use shared buffers at all. Move to
         index_copy_data() and heapam_relation_copy_data().
      
      4) heapam_relation_set_new_filenode() previously sometimes accessed
         rel->rd_rel->relpersistence rather than the `persistence`
         argument. Code movement mistake.
      
      5) Previously heapam_relation_set_new_filenode() re-opened the smgr
         relation to create the init for, if necesary. Instead have
         RelationCreateStorage() return the SMgrRelation and use it to
         create the init fork.
      
      6) Add a note about the danger of modifying the relcache directly to
         ATExecSetTableSpace() - it's currently not a bug because there's a
         check ERRORing for catalog tables.
      
      Regression tests and assertion improvements that together trigger the
      bug described in 1) will be added in a later commit, as there is a
      related bug on all branches.
      
      Reported-By: Michael Paquier
      Diagnosed-By: Tom Lane and Andres Freund
      Author: Andres Freund
      Reviewed-By: Tom Lane
      Discussion: https://postgr.es/m/20190418011430.GA19133@paquier.xyz
      5c156060
  9. 29 Apr, 2019 5 commits
    • Peter Geoghegan's avatar
      Remove obsolete _bt_insert_parent() comment. · 9ee7414e
      Peter Geoghegan authored
      Remove a comment that refers to a coding practice that was fully removed
      by commit a8b8f4db, which introduced MarkBufferDirty().  It looks like
      the comment was even obsolete before then, since it concerns
      write-ordering dependencies with synchronous buffer writes.
      9ee7414e
    • Tom Lane's avatar
      In walreceiver, don't try to do ereport() in a signal handler. · a1a789eb
      Tom Lane authored
      This is quite unsafe, even for the case of ereport(FATAL) where we won't
      return control to the interrupted code, and despite this code's use of
      a flag to restrict the areas where we'd try to do it.  It's possible
      for example that we interrupt malloc or free while that's holding a lock
      that's meant to protect against cross-thread interference.  Then, any
      attempt to do malloc or free within ereport() will result in a deadlock,
      preventing the walreceiver process from exiting in response to SIGTERM.
      We hypothesize that this explains some hard-to-reproduce failures seen
      in the buildfarm.
      
      Hence, get rid of the immediate-exit code in WalRcvShutdownHandler,
      as well as the logic associated with WalRcvImmediateInterruptOK.
      Instead, we need to take care that potentially-blocking operations
      in the walreceiver's data transmission logic (libpqwalreceiver.c)
      will respond reasonably promptly to the process's latch becoming
      set and then call ProcessWalRcvInterrupts.  Much of the needed code
      for that was already present in libpqwalreceiver.c.  I refactored
      things a bit so that all the uses of PQgetResult use latch-aware
      waiting, but didn't need to do much more.
      
      These changes should be enough to ensure that libpqwalreceiver.c
      will respond promptly to SIGTERM whenever it's waiting to receive
      data.  In principle, it could block for a long time while waiting
      to send data too, and this patch does nothing to guard against that.
      I think that that hazard is mostly theoretical though: such blocking
      should occur only if we fill the kernel's data transmission buffers,
      and we don't generally send enough data to make that happen without
      waiting for input.  If we find out that the hazard isn't just
      theoretical, we could fix it by using PQsetnonblocking, but that
      would require more ticklish changes than I care to make now.
      
      This is a bug fix, but it seems like too big a change to push into
      the back branches without much more testing than there's time for
      right now.  Perhaps we'll back-patch once we have more confidence
      in the change.
      
      Patch by me; thanks to Thomas Munro for review.
      
      Discussion: https://postgr.es/m/20190416070119.GK2673@paquier.xyz
      a1a789eb
    • Michael Paquier's avatar
    • Alvaro Herrera's avatar
      Message fixes · ffbce803
      Alvaro Herrera authored
      ffbce803
    • Peter Eisentraut's avatar
      Fix potential catalog corruption with temporary identity columns · cd3e2746
      Peter Eisentraut authored
      If a temporary table with an identity column and ON COMMIT DROP is
      created in a single-statement transaction (not useful, but allowed),
      it would leave the catalog corrupted.  We need to add a
      CommandCounterIncrement() so that PreCommit_on_commit_actions() sees
      the created dependency between table and sequence and can clean it
      up.
      
      The analogous and more useful case of doing this in a transaction
      block already runs some CommandCounterIncrement() before it gets to
      the on-commit cleanup, so it wasn't a problem in practical use.
      
      Several locations for placing the new CommandCounterIncrement() call
      were discussed.  This patch places it at the end of
      standard_ProcessUtility().  That would also help if other commands
      were to create catalog entries that some on-commit action would like
      to see.
      
      Bug: #15631
      Reported-by: default avatarSerge Latyntsev <dnsl48@gmail.com>
      Author: Peter Eisentraut <peter.eisentraut@2ndquadrant.com>
      Reviewed-by: default avatarMichael Paquier <michael@paquier.xyz>
      cd3e2746
  10. 28 Apr, 2019 2 commits
    • Tom Lane's avatar
      Do pre-release housekeeping on catalog data, and fix jsonpath send/recv. · c3f67ed6
      Tom Lane authored
      Run renumber_oids.pl to move high-numbered OIDs down, as per pre-beta
      tasks specified by RELEASE_CHANGES.  (The only change is 8394 -> 3428.)
      
      Also run reformat_dat_file.pl while I'm here.
      
      While looking at the reformat diffs, I chanced to notice that type
      jsonpath had typsend and typreceive = '-', which surely is not the
      intention given that jsonpath_send and jsonpath_recv exist.
      Fix that.  It's safe to assume that these functions have never been
      tested :-(.  I didn't try, but somebody should.
      c3f67ed6
    • Noah Misch's avatar
      Use preprocessor conditions compatible with Emacs indent. · 90e7f317
      Noah Misch authored
      Emacs wrongly indented hundreds of subsequent lines.
      90e7f317