1. 14 May, 2014 7 commits
    • Bruce Momjian's avatar
      pg_upgrade: error out on 'line' data type usage · bb797b64
      Bruce Momjian authored
      The data type internal format changed in 9.4.  Also mention this in the
      9.4 release notes.
      bb797b64
    • Tom Lane's avatar
      Code review for recent changes in relcache.c. · b23b0f55
      Tom Lane authored
      rd_replidindex should be managed the same as rd_oidindex, and rd_keyattr
      and rd_idattr should be managed like rd_indexattr.  Omissions in this area
      meant that the bitmapsets computed for rd_keyattr and rd_idattr would be
      leaked during any relcache flush, resulting in a slow but permanent leak in
      CacheMemoryContext.  There was also a tiny probability of relcache entry
      corruption if we ran out of memory at just the wrong point in
      RelationGetIndexAttrBitmap.  Otherwise, the fields were not zeroed where
      expected, which would not bother the code any AFAICS but could greatly
      confuse anyone examining the relcache entry while debugging.
      
      Also, create an API function RelationGetReplicaIndex rather than letting
      non-relcache code be intimate with the mechanisms underlying caching of
      that value (we won't even mention the memory leak there).
      
      Also, fix a relcache flush hazard identified by Andres Freund:
      RelationGetIndexAttrBitmap must not assume that rd_replidindex stays valid
      across index_open.
      
      The aspects of this involving rd_keyattr date back to 9.3, so back-patch
      those changes.
      b23b0f55
    • Bruce Momjian's avatar
      doc: fix 9.4 release notes typo · ac53295d
      Bruce Momjian authored
      Report by Dean Rasheed
      ac53295d
    • Bruce Momjian's avatar
      doc: fix typo in 9.4 release note comments · eefd90c4
      Bruce Momjian authored
      Patch by Sergey Muraviov
      eefd90c4
    • Tom Lane's avatar
      Make initdb throw error for bad locale values. · 31a26323
      Tom Lane authored
      Historically we've printed a complaint for a bad locale setting, but then
      fallen back to the environment default.  Per discussion, this is not such
      a great idea, because rectifying an erroneous locale choice post-initdb
      (perhaps long after data has been loaded) could be enormously expensive.
      Better to complain and give the user a chance to double-check things.
      
      The behavior was particularly bad if the bad setting came from environment
      variables rather than a bogus command-line switch: in that case not only
      was there a fallback to C/SQL_ASCII, but the printed complaint was quite
      unhelpful.  It's hard to be entirely sure what variables setlocale looked
      at, but we can at least give a hint where the problem might be.
      
      Per a complaint from Tomas Vondra.
      31a26323
    • Bruce Momjian's avatar
      docs: mention windows quoting change in 9.4 release notes · eb6144bb
      Bruce Momjian authored
      Report by Heikki Linnakangas
      eb6144bb
    • Bruce Momjian's avatar
      doc: auto-updatable view adjustments for 9.4 release notes · e513087f
      Bruce Momjian authored
      Report by Dean Rasheed
      e513087f
  2. 13 May, 2014 7 commits
    • Bruce Momjian's avatar
      docs: 9.4 release notes adjustments · 062f5351
      Bruce Momjian authored
      Patch by Andres Freund, slight adjustments by me
      062f5351
    • Heikki Linnakangas's avatar
      Fix harmless access to uninitialized memory. · f35aef41
      Heikki Linnakangas authored
      When cache invalidations arrive while ri_LoadConstraintInfo() is busy
      filling a new cache entry, InvalidateConstraintCacheCallBack() compares
      the - not yet initialized - oidHashValue field with the to-be-invalidated
      hash value. To fix, check whether the entry is already marked as invalid.
      
      Andres Freund
      f35aef41
    • Heikki Linnakangas's avatar
      Initialize padding bytes in btree_gist varbit support. · 540ac7ce
      Heikki Linnakangas authored
      The code expands a varbit gist leaf key to a node key by copying the bit
      data twice in a varlen datum, as both the lower and upper key. The lower key
      was expanded to INTALIGN size, but the padding bytes were not initialized.
      That's a problem because when the lower/upper keys are compared, the padding
      bytes are used compared too, when the values are otherwise equal. That could
      lead to incorrect query results.
      
      REINDEX is advised for any btree_gist indexes on bit or bit varying data
      type, to fix any garbage padding bytes on disk.
      
      Per Valgrind, reported by Andres Freund. Backpatch to all supported
      versions.
      540ac7ce
    • Noah Misch's avatar
      Add Valgrind suppression for reorderbuffer padding bytes. · 5a90ac29
      Noah Misch authored
      Andres Freund
      5a90ac29
    • Bruce Momjian's avatar
      docs: use structfield instead of structname in 9.4 release notes · 9af8bd51
      Bruce Momjian authored
      Where appropriate
      9af8bd51
    • Bruce Momjian's avatar
      doc: 9.4 release note adjustments · 6de9a6c0
      Bruce Momjian authored
      Report by Nicolas Barbier, Tatsuo Ishii, MauMau
      6de9a6c0
    • Tom Lane's avatar
      Be more wary in choice of timezone names to test make_timestamptz with. · 66b737cd
      Tom Lane authored
      America/Metlakatla hasn't been in the IANA database all that long, so
      some installations might not have it.  It does seem worthwhile to test
      with a fractional-minute GMT offset, but we can get that from almost
      any pre-1900 date; I chose Europe/Paris, whose LMT offset from Greenwich
      should be pretty darn well established.
      
      Also, assuming that Mars/Mons_Olympus will never be in the IANA database
      seems less than future-proof, so let's use a more fanciful location for
      the bad-zone-name check.
      
      Per complaint from Christoph Berg.
      66b737cd
  3. 12 May, 2014 3 commits
  4. 11 May, 2014 5 commits
    • Tom Lane's avatar
      Stamp 9.4beta1. · e6df2e1b
      Tom Lane authored
      e6df2e1b
    • Tom Lane's avatar
      Find postgresql.auto.conf in PGDATA even when postgresql.conf is elsewhere. · 195e81af
      Tom Lane authored
      The original coding for ALTER SYSTEM made a fundamentally bogus assumption
      that postgresql.auto.conf could be sought relative to the main config file
      if we hadn't yet determined the value of data_directory.  This fails for
      common arrangements with the config file elsewhere, as reported by
      Christoph Berg.
      
      The simplest fix is to not try to read postgresql.auto.conf until after
      SelectConfigFiles has chosen (and locked down) the data_directory setting.
      
      Because of the logic in ProcessConfigFile for handling resetting of GUCs
      that've been removed from the config file, we cannot easily read the main
      and auto config files separately; so this patch adopts a brute force
      approach of reading the main config file twice during postmaster startup.
      That's a tad ugly, but the actual time cost is likely to be negligible,
      and there's no time for a more invasive redesign before beta.
      
      With this patch, any attempt to set data_directory via ALTER SYSTEM
      will be silently ignored.  It would probably be better to throw an
      error, but that can be dealt with later.  This bug, however, would
      prevent any testing of ALTER SYSTEM by a significant fraction of the
      userbase, so it seems important to get it fixed before beta.
      195e81af
    • Tom Lane's avatar
      Rename jsonb_hash_ops to jsonb_path_ops. · 12e611d4
      Tom Lane authored
      There's no longer much pressure to switch the default GIN opclass for
      jsonb, but there was still some unhappiness with the name "jsonb_hash_ops",
      since hashing is no longer a distinguishing property of that opclass,
      and anyway it seems like a relatively minor detail.  At the suggestion of
      Heikki Linnakangas, we'll use "jsonb_path_ops" instead; that captures the
      important characteristic that each index entry depends on the entire path
      from the document root to the indexed value.
      
      Also add a user-facing explanation of the implementation properties of
      these two opclasses.
      12e611d4
    • Peter Eisentraut's avatar
      Translation updates · e136271a
      Peter Eisentraut authored
      e136271a
    • Bruce Momjian's avatar
      ea78ce1d
  5. 10 May, 2014 6 commits
  6. 09 May, 2014 12 commits
    • Tom Lane's avatar
      Fix broken allocation logic in recently-rewritten jsonb_util.c. · 3d8c2b49
      Tom Lane authored
      reserveFromBuffer() failed to consider the possibility that it needs to
      more-than-double the current buffer size.  Beyond that, it seems likely
      that we'd someday need to worry about integer overflow of the buffer
      length variable.  Rather than reinvent the logic that's already been
      debugged in stringinfo.c, let's go back to using that logic.  We can
      still have the same targeted API, but we'll rely on stringinfo.c to
      manage reallocation.
      
      Per report from Alexander Korotkov.
      3d8c2b49
    • Tom Lane's avatar
      Improve user-facing JSON documentation. · 0b92a77c
      Tom Lane authored
      I started out with the intention of just fixing the info about the jsonb
      operator classes, but soon found myself copy-editing most of the JSON
      material.  Hopefully it's more readable now.
      0b92a77c
    • Tom Lane's avatar
      Get rid of bogus dependency on typcategory in to_json() and friends. · 0ca6bda8
      Tom Lane authored
      These functions were relying on typcategory to identify arrays and
      composites, which is not reliable and not the normal way to do it.
      Using typcategory to identify boolean, numeric types, and json itself is
      also pretty questionable, though the code in those cases didn't seem to be
      at risk of anything worse than wrong output.  Instead, use the standard
      lsyscache functions to identify arrays and composites, and rely on a direct
      check of the type OID for the other cases.
      
      In HEAD, also be sure to look through domains so that a domain is treated
      the same as its base type for conversions to JSON.  However, this is a
      small behavioral change; given the lack of field complaints, we won't
      back-patch it.
      
      In passing, refactor so that there's only one copy of the code that decides
      which conversion strategy to apply, not multiple copies that could (and
      have) gotten out of sync.
      0ca6bda8
    • Robert Haas's avatar
      Code review for logical decoding patch. · f1d8dd36
      Robert Haas authored
      Post-commit review identified a number of places where addition was
      used instead of multiplication or memory wasn't zeroed where it should
      have been.  This commit also fixes one case where a structure member
      was mis-initialized, and moves another memory allocation closer to
      the place where the allocated storage is used for clarity.
      
      Andres Freund
      f1d8dd36
    • Robert Haas's avatar
      Remove overeager assertion in logical_heap_begin_rewrite. · b2dada8f
      Robert Haas authored
      It's legal to configure wal_level=logical and max_replication_slots=0
      simultaneously.
      
      Andres Freund
      b2dada8f
    • Tom Lane's avatar
      Teach add_json() that jsonb is of TYPCATEGORY_JSON. · 62e57ff0
      Tom Lane authored
      This code really needs to be refactored so that there aren't so many copies
      that can diverge.  Not to mention that this whole approach is probably
      wrong.  But for the moment I'll just stick my finger in the dike.
      Per report from Michael Paquier.
      62e57ff0
    • Tom Lane's avatar
      Fix typcategory labeling of jsonb. · bdf9dd4d
      Tom Lane authored
      Dunno who had the cute idea of labeling jsonb as typcategory 'C',
      but it is not a composite type.  Label it 'U', since that's what
      json is using.
      bdf9dd4d
    • Heikki Linnakangas's avatar
      More jsonb cleanup. · d9daff0e
      Heikki Linnakangas authored
      Fix JSONB_MAX_ELEMS and JSONB_MAX_PAIRS macros to use CB_MASK in the
      calculation. JENTRY_POSMASK happens to have the same value at the moment,
      but that's just coincidental.
      
      Refactor jsonb iterator functions, for readability.
      
      Get rid of the JENTRY_ISFIRST flag. Whenever we handle JEntrys, we have
      access to the whole array and have enough context information to know
      which entry is the first. This frees up one bit in the JEntry header for
      future use. While we're at it, shuffle the JEntry bits so that boolean
      true and false go together, for aesthetic reasons.
      
      Bump catalog version as this changes the on-disk format slightly.
      d9daff0e
    • Tom Lane's avatar
      Improve key representation for GIN jsonb_ops, and fix existence-search bug. · 46dddf76
      Tom Lane authored
      Change the key representation so that values that would exceed 127 bytes
      are hashed into short strings, and so that the original JSON datatype of
      each value is recorded in the index.  The hashing rule eliminates the major
      objection to having this opclass be the default for jsonb, namely that it
      could fail for plausible input data (due to GIN's restrictions on maximum
      key length).  Preserving datatype information doesn't really buy us much
      right now, but it requires no extra space compared to the previous way,
      and it might be useful later.
      
      Also, change the consistency-checking functions to request recheck for
      exists (jsonb ? text) and related operators.  The original analysis that
      this is an exactly checkable query was incorrect, since the index does
      not preserve information about whether a key appears at top level in
      the indexed JSON object.  Add a test case demonstrating the problem.
      
      Make some other, mostly cosmetic improvements to the code in jsonb_gin.c
      as well.
      
      catversion bump due to on-disk data format change in jsonb_ops indexes.
      46dddf76
    • Heikki Linnakangas's avatar
      Minor cleanup of jsonb_util.c · ff7bbb01
      Heikki Linnakangas authored
      Move the functions around to group related functions together. Remove
      binequal argument from lengthCompareJsonbStringValue, moving that
      responsibility to lengthCompareJsonbPair. Fix typo in comment.
      ff7bbb01
    • Heikki Linnakangas's avatar
      Avoid some pnstrdup()s when constructing jsonb · d3c72e23
      Heikki Linnakangas authored
      This speeds up text to jsonb parsing and hstore to jsonb conversions
      somewhat.
      d3c72e23
    • Tom Lane's avatar
      Fix missing dependencies in ecpg's test Makefiles. · 14d309cc
      Tom Lane authored
      Ensure that ecpg preprocessor output files are rebuilt when re-testing
      after a change in the ecpg preprocessor itself, or a change in any of
      several include files that get copied verbatim into the output files.
      The lack of these dependencies was what created problems for Kevin Grittner
      after the recent pgindent run.  There's no way for --enable-depend to
      discover these dependencies automatically, so we've gotta put them into
      the Makefiles by hand.
      
      While at it, reduce the amount of duplication in the ecpg invocations.
      14d309cc