1. 11 10月, 2012 5 次提交
    • T
      Update obsolete comment. · 864db116
      Tom Lane 提交于
      We no longer use GetNewOidWithIndex on pg_largeobject; rather,
      pg_largeobject_metadata's regular OID column is considered the repository
      of OIDs for large objects.  The special functionality is still needed for
      TOAST tables however.
      864db116
    • T
      Create an improved FDW option validator function for contrib/dblink. · 8255566f
      Tom Lane 提交于
      dblink now has its own validator function dblink_fdw_validator(), which is
      better than the core function postgresql_fdw_validator() because it gets
      the list of legal options from libpq instead of having a hard-wired list.
      
      Make the dblink extension module provide a standard foreign data wrapper
      dblink_fdw that encapsulates use of this validator, and recommend use of
      that wrapper instead of making up wrappers on the fly.
      
      Unfortunately, because ad-hoc wrappers *were* recommended practice
      previously, it's not clear when we can get rid of postgresql_fdw_validator
      without causing upgrade problems.  But this is a step in the right
      direction.
      
      Shigeru Hanada, reviewed by KaiGai Kohei
      8255566f
    • T
      Update obsolete text in fdwhandler.sgml. · 392b2e50
      Tom Lane 提交于
      Etsuro Fujita, with some wording adjustment by me.
      392b2e50
    • B
      In pg_upgrade, issue proper error message when we can't open PG_VERSION. · a9701a1d
      Bruce Momjian 提交于
      Backpatch to 9.2.
      a9701a1d
    • T
      Set procost to 10 for each of the pg_foo_is_visible() functions. · a80889a7
      Tom Lane 提交于
      The idea here is to make sure the planner will evaluate these functions
      last not first among the filter conditions in psql pattern search and
      tab-completion queries.  We've discussed this several times, and there
      was consensus to do it back in August, but we didn't want to do it just
      before a release.  Now seems like a safer time.
      
      No catversion bump, since this catalog change doesn't create a backend
      incompatibility nor any regression test result changes.
      a80889a7
  2. 10 10月, 2012 4 次提交
    • T
      Fix PGXS support for building loadable modules on AIX. · 3f88fa97
      Tom Lane 提交于
      Building a shlib on AIX requires use of the mkldexport.sh script, but we
      failed to install that, preventing its use from non-source-tree contexts.
      Also, Makefile.aix had the wrong idea about where to find the installed
      copy of the postgres.imp symbol file used by AIX.
      
      Per report from John Pierce.  Patch all the way back, since this has been
      broken since the beginning of PGXS.
      3f88fa97
    • T
      Remove unnecessary overhead in backend's large-object operations. · 7e0cce02
      Tom Lane 提交于
      Do read/write permissions checks at most once per large object descriptor,
      not once per lo_read or lo_write call as before.  The repeated tests were
      quite useless in the read case since the snapshot-based tests were
      guaranteed to produce the same answer every time.  In the write case,
      the extra tests could in principle detect revocation of write privileges
      after a series of writes has started --- but there's a race condition there
      anyway, since we'd check privileges before performing and certainly before
      committing the write.  So there's no real advantage to checking every
      single time, and we might as well redefine it as "only check the first
      time".
      
      On the same reasoning, remove the LargeObjectExists checks in inv_write
      and inv_truncate.  We already checked existence when the descriptor was
      opened, and checking again doesn't provide any real increment of safety
      that would justify the cost.
      7e0cce02
    • H
      Fix silly bug in previous refactoring. · 2d8c81ac
      Heikki Linnakangas 提交于
      I extracted the refactoring patch from a larger patch that contained other
      changes too, but missed one unintentional change and didn't test enough...
      2d8c81ac
    • H
      Put the logic to wait for WAL in standby mode to a separate function. · ff8f160b
      Heikki Linnakangas 提交于
      This is just refactoring with no user-visible effect, to make the code more
      readable.
      ff8f160b
  3. 09 10月, 2012 12 次提交
  4. 08 10月, 2012 7 次提交
  5. 07 10月, 2012 3 次提交
  6. 06 10月, 2012 1 次提交
    • P
      Improve LDAP authentication documentation · ae835c7d
      Peter Eisentraut 提交于
      Use the terms "simple bind" and "search+bind" consistently do
      distinguish the two modes (better than first mode and second mode in
      any case).  They were already used in some places, now it's just more
      prominent.
      
      Split up the list of options into one for common options and one for
      each mode, for clarity.
      
      Add configuration examples for either mode.
      ae835c7d
  7. 05 10月, 2012 8 次提交
    • M
      Removed sentence about not being able to retrieve more than one row at a time, · 1045af95
      Michael Meskes 提交于
      because it is not correct.
      1045af95
    • M
      Fixed test for array boundary. · 6e41fa2e
      Michael Meskes 提交于
      Instead of continuing if the next character is not an array boundary get_data()
      used to continue only on finding a boundary so it was not able to read any
      element after the first.
      6e41fa2e
    • H
      Use the regular main processing loop also in walsenders. · fd5942c1
      Heikki Linnakangas 提交于
      The regular backend's main loop handles signal handling and error recovery
      better than the current WAL sender command loop does. For example, if the
      client hangs and a SIGTERM is received before starting streaming, the
      walsender will now terminate immediately, rather than hang until the
      connection times out.
      fd5942c1
    • T
      getnameinfo_unix has to be taught not to insist on NI_NUMERIC flags, too. · 1997f34d
      Tom Lane 提交于
      Per testing of previous patch.
      1997f34d
    • P
      PL/pgSQL: rename gram.y to pl_gram.y · 05346c13
      Peter Eisentraut 提交于
      This makes the naming inside plpgsql consistent and distinguishes the
      file from the backend's gram.y file.  It will also allow easier
      refactoring of the bison make rules later on.
      05346c13
    • P
      Remove redundant code for getnameinfo() replacement · c424d0d1
      Peter Eisentraut 提交于
      Our getnameinfo() replacement implementation in getaddrinfo.c failed
      unless NI_NUMERICHOST and NI_NUMERICSERV were given as flags, because
      it doesn't resolve host names, only numeric IPs.  But per standard,
      when those flags are not given, an implementation can still degrade to
      not returning host names, so this restriction is unnecessary.  When we
      remove it, we can eliminate some code in postmaster.c that apparently
      tried to work around that.
      c424d0d1
    • T
      Make CREATE AGGREGATE complain if the initcond is invalid for the datatype. · e1e60694
      Tom Lane 提交于
      The initial transition value is stored as a text string and not fed to the
      transition type's input function until runtime (so that values such as
      "now" don't get frozen at creation time).  Previously, CREATE AGGREGATE
      didn't do anything with it but that, which meant that even erroneous values
      would be accepted and not complained of until the aggregate is used.  This
      seems unhelpful, and it's confused at least one user, as in Rhys Stewart's
      recent report.  It seems worth taking a few more cycles to invoke the input
      function and verify that the value is acceptable.  We can't do this if the
      transition type is polymorphic, but in normal aggregates we know the actual
      transition type so we can call the right input function.
      e1e60694
    • T
      Fix parse location tracking for lists that can be empty. · 70726354
      Tom Lane 提交于
      The previous coding of the YYLLOC_DEFAULT macro behaved strangely for empty
      productions, assigning the previous nonterminal's location as the parse
      location of the result.  The usefulness of that was (at best) debatable
      already, but the real problem is that in list-generating nonterminals like
      	OptFooList: /* EMPTY */ { ... } | OptFooList Foo { ... } ;
      the initially-identified location would get copied up, so that even a
      nonempty list would be given a bogus parse location.  Document how to work
      around that, and do so for OptSchemaEltList, so that the error condition
      just added for CREATE SCHEMA IF NOT EXISTS produces a sane error cursor.
      So far as I can tell, there are currently no other cases where the
      situation arises, so we don't need other instances of this coding yet.
      70726354