1. 07 Jul, 2015 7 commits
    • Heikki Linnakangas's avatar
      Improve handling of out-of-memory in libpq. · 414bef30
      Heikki Linnakangas authored
      If an allocation fails in the main message handling loop, pqParseInput3
      or pqParseInput2, it should not be treated as "not enough data available
      yet". Otherwise libpq will wait indefinitely for more data to arrive from
      the server, and gets stuck forever.
      
      This isn't a complete fix - getParamDescriptions and getCopyStart still
      have the same issue, but it's a step in the right direction.
      
      Michael Paquier and me. Backpatch to all supported versions.
      414bef30
    • Fujii Masao's avatar
      Add tab-completion for psql meta-commands. · c81c9564
      Fujii Masao authored
      Based on the original code from David Christensen, modified by me.
      c81c9564
    • Andres Freund's avatar
      Refer to %p in the psql docs as 'process ID' not 'pid'. · 4af04f96
      Andres Freund authored
      Per Tom.
      4af04f96
    • Andres Freund's avatar
      Add psql PROMPT variable showing the pid of the connected to backend. · 275f05c9
      Andres Freund authored
      The substitution for the pid is %p.
      
      Author: Julien Rouhaud
      Discussion: 116262CF971C844FB6E793F8809B51C6E99D48@BPXM02GP.gisp.nec.co.jp
      275f05c9
    • Andres Freund's avatar
      Fix logical decoding bug leading to inefficient reopening of files. · b2f6f749
      Andres Freund authored
      When spilling transaction data to disk a simple typo caused the output
      file to be closed and reopened for every serialized change. That happens
      to not have a huge impact on linux, which is why it probably wasn't
      noticed so far, but on windows that appears to trigger actual disk
      writes after every change. Not fun.
      
      The bug fortunately does not have any impact besides speed. A change
      could end up being in the wrong segment (last instead of next), but
      since we read all files to the end, that's just ugly, not really
      problematic. It's not a problem to upgrade, since transaction spill
      files do not persist across restarts.
      
      Bug: #13484
      Reported-By: Olivier Gosseaume
      Discussion: 20150703090217.1190.63940@wrigleys.postgresql.org
      
      Backpatch to 9.4, where logical decoding was added.
      b2f6f749
    • Andres Freund's avatar
      Fix pg_recvlogical not to fsync output when it's a tty or pipe. · 5c0de384
      Andres Freund authored
      The previous coding tried to handle possible failures when fsyncing a
      tty or pipe fd by accepting EINVAL - but apparently some
      platforms (windows, OSX) don't reliably return that. So instead check
      whether the output fd refers to a pipe or a tty when opening it.
      
      Reported-By: Olivier Gosseaume, Marko Tiikkaja
      Discussion: 559AF98B.3050901@joh.to
      
      Backpatch to 9.4, where pg_recvlogical was added.
      5c0de384
    • Joe Conway's avatar
      Make RLS related error messages more consistent and compliant. · 02eac01f
      Joe Conway authored
      Also updated regression expected output to match. Noted and patch by Daniele Varrazzo.
      02eac01f
  2. 06 Jul, 2015 4 commits
    • Heikki Linnakangas's avatar
      Turn install.bat into a pure one line wrapper fort he perl script. · 6c534fd6
      Heikki Linnakangas authored
      Build.bat and vcregress.bat got similar treatment years ago. I'm not sure
      why install.bat wasn't treated at the same time, but it seems like a good
      idea anyway.
      
      The immediate problem with the old install.bat was that it had quoting
      issues, and wouldn't work if the target directory's name contained spaces.
      This fixes that problem.
      6c534fd6
    • Heikki Linnakangas's avatar
      Call getsockopt() on the correct socket. · 8e33fc17
      Heikki Linnakangas authored
      We're interested in the buffer size of the socket that's connected to the
      client, not the one that's listening for new connections. It happened to
      work, as default buffer size is the same on both, but it was clearly not
      wrong.
      
      Spotted by Tom Lane
      8e33fc17
    • Heikki Linnakangas's avatar
      Don't set SO_SNDBUF on recent Windows versions that have a bigger default. · 4f33621f
      Heikki Linnakangas authored
      It's unnecessary to set it if the default is higher in the first place.
      Furthermore, setting SO_SNDBUF disables the so-called "dynamic send
      buffering" feature, which hurts performance further. This can be seen
      especially when the network between the client and the server has high
      latency.
      
      Chen Huajun
      4f33621f
    • Fujii Masao's avatar
      Remove incorrect warning from pg_archivecleanup document. · 906e9249
      Fujii Masao authored
      The .backup file name can be passed to pg_archivecleanup even if
      it includes the extension which is specified in -x option.
      However, previously the document incorrectly warned a user
      not to do that.
      
      Back-patch to 9.2 where pg_archivecleanup's -x option and
      the warning were added.
      906e9249
  3. 05 Jul, 2015 4 commits
    • Tom Lane's avatar
      Make a editorial pass over pgbench's error messages. · 22ba5563
      Tom Lane authored
      The lack of consistency, and lack of attention to our message style
      guidelines, was a bit striking.  Try to make 'em better.
      22ba5563
    • Tom Lane's avatar
      Fix some typos in regression test comments. · 55165497
      Tom Lane authored
      Back-patch to avoid unnecessary cross-branch differences.
      
      CharSyam
      55165497
    • Tom Lane's avatar
      Further reduce overhead for passing plpgsql variables to the executor. · 6c82d8d1
      Tom Lane authored
      This builds on commit 21dcda27 by keeping
      a plpgsql function's shared ParamListInfo's entries for simple variables
      (PLPGSQL_DTYPE_VARs) valid at all times.  That adds a few cycles to each
      assignment to such variables, but saves significantly more cycles each time
      they are used; so except in the pathological case of many dead stores, this
      should always be a win.  Initial testing says it's good for about a 10%
      speedup of simple calculations; more in large functions with many datums.
      
      We can't use this method for row/record references unfortunately, so what
      we do for those is reset those ParamListInfo slots after use; which we
      can skip doing unless some of them were actually evaluated during the
      previous evaluation call.  So this should frequently be a win as well,
      while worst case is that it's similar cost to the previous approach.
      
      Also, closer study suggests that the previous method of instantiating a
      new ParamListInfo array per evaluation is actually probably optimal for
      cursor-opening executor calls.  The reason is that whatever is visible in
      the array is going to get copied into the cursor portal via copyParamList.
      So if we used the function's main ParamListInfo for those calls, we'd end
      up with all of its DTYPE_VAR vars getting copied, which might well include
      large pass-by-reference values that the cursor actually has no need for.
      To avoid a possible net degradation in cursor cases, go back to creating
      and filling a private ParamListInfo in those cases (which therefore will be
      exactly the same speed as before 21dcda27).  We still get some benefit
      out of this though, because this approach means that we only have to defend
      against copyParamList's try-to-fetch-every-slot behavior in the case of an
      unshared ParamListInfo; so plpgsql_param_fetch() can skip testing
      expr->paramnos in the common case.
      
      To ensure that the main ParamListInfo's image of a DTYPE_VAR datum is
      always valid, all assignments to such variables are now funneled through
      assign_simple_var().  But this makes for cleaner and shorter code anyway.
      6c82d8d1
    • Tom Lane's avatar
      Fix bad grammar in brin.sgml. · 25240462
      Tom Lane authored
      Christoph Berg
      25240462
  4. 03 Jul, 2015 6 commits
  5. 02 Jul, 2015 15 commits
  6. 01 Jul, 2015 3 commits
    • Tom Lane's avatar
      Don't leave pg_hba and pg_ident data lying around in running backends. · 1e24cf64
      Tom Lane authored
      Free the contexts holding this data after we're done using it, by the
      expedient of attaching them to the PostmasterContext which we were
      already taking care to delete (and where, indeed, this data used to live
      before commits e5e2fc84 and 7c45e3a3).  This saves a
      probably-usually-negligible amount of space per running backend.  It also
      avoids leaving potentially-security-sensitive data lying around in memory
      in processes that don't need it.  You'd have to be unusually paranoid to
      think that that amounts to a live security bug, so I've not gone so far as
      to forcibly zero the memory; but there surely isn't a good reason to keep
      this data around.
      
      Arguably this is a memory management bug in the aforementioned commits,
      but it doesn't seem important enough to back-patch.
      1e24cf64
    • Tom Lane's avatar
      Make sampler_random_fract() actually obey its API contract. · d7c19d68
      Tom Lane authored
      This function is documented to return a value in the range (0,1),
      which is what its predecessor anl_random_fract() did.  However, the
      new version depends on pg_erand48() which returns a value in [0,1).
      The possibility of returning zero creates hazards of division by zero
      or trying to compute log(0) at some call sites, and it might well
      break third-party modules using anl_random_fract() too.  So let's
      change it to never return zero.  Spotted by Coverity.
      
      Michael Paquier, cosmetically adjusted by me
      d7c19d68
    • Fujii Masao's avatar
      Make XLogFileCopy() look the same as in 9.4. · 82173708
      Fujii Masao authored
      XLogFileCopy() was changed heavily in commit de768844. However it was
      partially reverted in commit 7abc6859 and most of those changes to
      XLogFileCopy() were no longer needed. Then commit 7cbee7c0 removed
      those unnecessary code, but XLogFileCopy() looked different in master
      and 9.4 though the contents are almost the same.
      
      This patch makes XLogFileCopy() look the same in master and back-branches,
      which makes back-patching easier, per discussion on pgsql-hackers.
      Back-patch to 9.5.
      
      Discussion: 55760844.7090703@iki.fi
      
      Michael Paquier
      82173708
  7. 30 Jun, 2015 1 commit
    • Tom Lane's avatar
      Fix broken link in documentation. · 7f32dbcd
      Tom Lane authored
      HP's web server has apparently become case-sensitive sometime recently.
      Per bug #13479 from Daniel Abraham.  Corrected link identified by Alvaro.
      7f32dbcd