1. 19 Aug, 1996 8 commits
    • Marc G. Fournier's avatar
      Finish adding in svr4 port to v2.0 · c801ca09
      Marc G. Fournier authored
      c801ca09
    • Marc G. Fournier's avatar
      Added a SVR4 port · 926a066d
      Marc G. Fournier authored
      ```yaml
      below my signature, there are a coupls of diffs and files in a shell
      archive, which were needed to build postgres95 1.02 on Siemens Nixdorfs
      MIPS based SINIX systems. Except for the compiler switches "-W0" and
      "-LD-Blargedynsym" these diffs should also apply for other SVR4 based
      systems. The changes in "Makefile.global" and "genbki.sh" can probably
      be ignored (I needed gawk, to make the script run).
      
      There is one bugfix thou. In "src/backend/parser/sysfunc.c" the
      function in this file didn't honor the EUROPEAN_DATES ifdef.
      ```
      
      Submitted by:  Frank Ridderbusch <ridderbusch.pad@sni.de>
      926a066d
    • Marc G. Fournier's avatar
      Here's a minor fix that fixes a casting problem: · 0e9f4cea
      Marc G. Fournier authored
      -Kurt
      0e9f4cea
    • Marc G. Fournier's avatar
      More run-time checking errors: · c3673c03
      Marc G. Fournier authored
      -Kurt
      c3673c03
    • Marc G. Fournier's avatar
      Fixes: · 60b1123f
      Marc G. Fournier authored
      Here's a couple more small fixes that I've made to make my runtime
      checker happy with the code.  More along the lines of those that
      I sent in the past, ie, a pointer to an array != the name of
      an array.  The last patch is that I mailed about yesterday -- I got
      two replies of "do it", so it's done.  As far as I can tell, however,
      the function in question is never called by pg95, so either way
      it can't hurt...
      
      From:  "Kurt J. Lidl" <lidl@va.pubnix.com>
      60b1123f
    • Marc G. Fournier's avatar
      Fixes: · 77e01653
      Marc G. Fournier authored
      When you connect to a database with PQsetdb, as with psql, depending on
      how your uninitialized variables are set, you can get a failure with a
      "There is no connection to the backend" message.
      
      The fix is to move a call to PQexec() from inside connectDB() to
      PQsetdb() after connectDB() returns to PQsetdb().  That way a connection
      doesn't have to be already established in order to establish it!
      
      
      From:  bryanh@giraffe.netgate.net (Bryan Henderson)
      77e01653
    • Marc G. Fournier's avatar
      From: Dan McGuirk <mcguirk@indirect.com> · 3c47cdeb
      Marc G. Fournier authored
      fixed the spelling of 'nonexistent' in a few places...
      3c47cdeb
    • Marc G. Fournier's avatar
      |From: Dan McGuirk <mcguirk@indirect.com> · f796387b
      Marc G. Fournier authored
      |
      |This patch fixes a backend crash that happens sometimes when you try to
      |join on a field that contains NULL in some rows.  Postgres tries to
      |compute a hash value of the field you're joining on, but when the field
      |is NULL, the pointer it thinks is pointing to the data is really just
      |pointing to random memory.  This forces the hash value of NULL to be 0.
      |
      |It seems that nothing matches NULL on joins, even other NULL's (with or
      |without this patch).  Is that what's supposed to happen?
      |
      f796387b
  2. 18 Aug, 1996 1 commit
  3. 17 Aug, 1996 1 commit
  4. 15 Aug, 1996 3 commits
    • Marc G. Fournier's avatar
      Fixes a bug in 'create index' · a4402ecc
      Marc G. Fournier authored
      Submitted by: Dan McGuirk <mcguirk@indirect.com>
      a4402ecc
    • Marc G. Fournier's avatar
      Fixes: · d6fa4d95
      Marc G. Fournier authored
      CLUSTER command couldn't rename correctly the new created heap relation.
      The table base name resulted in some "temp_XXXX" instead of the correct
      base name.
      
      Submitted by: Dirk Koeser <koeser@informatik.uni-rostock.de>
      d6fa4d95
    • Marc G. Fournier's avatar
      Fixes; · 4844adc8
      Marc G. Fournier authored
       Postgres is not able to cluster a relation on which an rtree index is
       defined. Postmaster gives the following error message:
      
       Too Large Allocation Request("!(0 < (size) && (size) <= (0xfffffff)):size=0
       [0x0]", File:"/export/home/postgres/src/backend/utils/mmgr/mcxt.c", Line: 220)
        !(0 <(size) && (size) <= (0xfffffff)) (0) [No such file or directory]
      
      Submitted by: Dirk Koeser <koeser@informatik.uni-rostock.de>
      4844adc8
  5. 14 Aug, 1996 8 commits
    • Marc G. Fournier's avatar
      | · bde34552
      Marc G. Fournier authored
      |Here is a fix for the psql alignment problem.  It turns out that libpq
      |was trying to determine if the column contained only numeric values so
      |it could right justify it.  The 'e' values were taked as exponient
      |values and all columns were considered numeric.
      |
      |The patch excludes 'e' and 'E' as being valid first-column numeric
      |values.
      |
      
      Submitted by: Bruce...
      bde34552
    • Marc G. Fournier's avatar
      This patch can be installed as part of 1.02.1 so people can properly · 476ef109
      Marc G. Fournier authored
      pg_dump and load to 2.0.  I haven't gotten any feedback on whether
      people want it, so I am submitting it for others to decide.  I would
      recommend an install in 1.02.1.
      
      I had said that the 2.0 pg_dump could dump a 1.02.1 database, but I was
      wrong.  The copy is actually performed by the backend, and the 2.0
      database will not be able to read 1.02.1 databases because of the new
      system columns.
      
      This patch does several things.  It copies nulls out as \N, so they can
      be distinguished from '' strings.  It fixes a problem where backslashes
      in the input stream were not output as double-backslashes.  Without this
      patch, backslashes copied out were deleted upon input, or interpreted as
      special characters.  Third, input is now terminated by backslash-period.
      This can not be part of a normal input stream.
      
      I tested this by creating a database with all sorts of nulls, backslash,
      and period fields and dumped the database and reloaded into a new
      database and compared them.
      
      Submitted by: Bruce
      476ef109
    • Marc G. Fournier's avatar
      This patch can be installed as part of 1.02.1 so people can properly · e7a110b4
      Marc G. Fournier authored
      pg_dump and load to 2.0.  I haven't gotten any feedback on whether
      people want it, so I am submitting it for others to decide.  I would
      recommend an install in 1.02.1.
      
      I had said that the 2.0 pg_dump could dump a 1.02.1 database, but I was
      wrong.  The copy is actually performed by the backend, and the 2.0
      database will not be able to read 1.02.1 databases because of the new
      system columns.
      
      This patch does several things.  It copies nulls out as \N, so they can
      be distinguished from '' strings.  It fixes a problem where backslashes
      in the input stream were not output as double-backslashes.  Without this
      patch, backslashes copied out were deleted upon input, or interpreted as
      special characters.  Third, input is now terminated by backslash-period.
      This can not be part of a normal input stream.
      
      I tested this by creating a database with all sorts of nulls, backslash,
      and period fields and dumped the database and reloaded into a new
      database and compared them.
      
      Submitted by: Bruce
      e7a110b4
    • Marc G. Fournier's avatar
      I grabbed the latest version of the source code via sup this morning, · 15a64501
      Marc G. Fournier authored
      and found out that one of the patches is a show stopper for
      compiling under a strict ansi package.
      
      Please make sure the following fix makes it into the 1.02.1
      release...
      
      Thanks.
      
      -Kurt
      15a64501
    • Marc G. Fournier's avatar
      This is a fix to be included in 1.02.1. It adds a tip for people · 988a9adf
      Marc G. Fournier authored
      getting semaphore or shared memory errors.
      
      Submitted by: bryanh@giraffe.netgate.net (Bryan Henderson)
      988a9adf
    • Marc G. Fournier's avatar
      | · 011ee131
      Marc G. Fournier authored
      |We're all too familiar with psql's "no response from backend" message.
      |Users can't tell what this means, and psql continues prompting for
      |commands after it even though the backend is dead and no commands can
      |succeed.  It eventually dies on a signal when the dead socket fills
      |up.  I extended the message to offer a better explanation and made
      |psql exit when it finds the backend is dead.
      |
      |I also added a short message and newline when the user does a ctl-D so
      |it doesn't mess up the terminal display.
      |
      |
      
      Submitted by: Bryan Henderson <bryanh@giraffe.netgate.net>
      011ee131
    • Marc G. Fournier's avatar
      Here's a small makefile patch that corrects the following bug: The makefiles · 6b9ecd83
      Marc G. Fournier authored
      don't indicate that the libpq.a library is a dependency of all the /bin
      programs.  So if the library changes, the /bin programs don't get remade.
      
      Submitted by: Bryan Henderson <bryanh@giraffe.netgate.net>
      6b9ecd83
    • Marc G. Fournier's avatar
      The following patch makes postmaster -D work. -D specifies a different PGDATA · 80d0c4ff
      Marc G. Fournier authored
      directory.  The code that looks for the pg_hba file doesn't use it, though,
      so the postmaster uses the wrong pg_hba file.  Also, when the postmaster
      looks in one directory and the user thinks it is looking in another
      directory, the error messages don't give enough information to solve the
      problem.  I extended the error message for this.
      
      
      Submitted by: Bryan Henderson <bryanh@giraffe.netgate.net>
      80d0c4ff
  6. 13 Aug, 1996 8 commits
    • Marc G. Fournier's avatar
      I have attached a minor update for the Postgres make files. This update · ca5db6ca
      Marc G. Fournier authored
      does 2 things:
      
      1) Make it hard to not notice the make failed.  (As you recall, someone on
         the mailing list had this problem.  I've had it to some extent myself).
      
          The 1.02 make files continue with the next subdirectory when a make
          in a subdirectory fails.  The patch makes the make stop in the
          conventional way when a submake fails.  It also adds a reassuring message
          when the make succeeds and adds a note to the INSTALL file to expect it.
      
      2) Include loader flags on all invocations of the linker.
      
         The 1.02 make files omit the $(LDFLAGS) on some of the linker invocations.
         On my system, I need one of those flags just to make it invoke the proper
         version of the compiler/linker, so LDFLAGS has to be everywhere.
      
      Submitted by: Bryan Henderson <bryanh@giraffe.netgate.net>
      ca5db6ca
    • Marc G. Fournier's avatar
      More code cleanups · a721c91a
      Marc G. Fournier authored
      Submitted by: darcy@druid.druid.com (D'Arcy J.M. Cain)
      a721c91a
    • Marc G. Fournier's avatar
      Fixes: · 9305fc74
      Marc G. Fournier authored
      Attached is a patch to allow libpq to determine if a field is null.
      
      This is needed because text fields will return a PQgetlength() of 0
      whether it is '' or NULL.  There is even a comment in the source noting
      the fact.
      
      I have changed the value of the 'len' field for NULL result fields.  If
      the field is null, the len is set to -1 (NULL_LEN).  I have changed
      PQgetlength() to return a 0 length for both '' and NULL.  A new function
      PQgetisnull() returns true or false for NULL.
      
      The only risk is to applications that do not use the suggested
      PQgetlength() call, but read the result 'len' field directly.
      
      As this is not recommended, I think we are safe here.
      
      A separate documentation patch will be sent.
      
      
      Submitted by: Bruce Momjian <maillist@candle.pha.pa.us>
      9305fc74
    • Marc G. Fournier's avatar
      Small cleanup of the irix5 port · 78d56d0b
      Marc G. Fournier authored
      Submitted by: Andrew Martin <martin@biochemistry.ucl.ac.uk>
      78d56d0b
    • Marc G. Fournier's avatar
      Fixes: · 9da9c091
      Marc G. Fournier authored
      Here's a small patch that my run-time checker whines about
      incessantly.  The justification for the patch is along the
      lines of passing a NULL is allowed if you have an
      arguement that is a *POINTER* to something, but if
      the arguement is an array reference, it's not really
      a "pointer", so it can't be NULL.
      
      If you question this, I refer you to
      <URL:http://www.va.pubnix.com/staff/djm/lore/arrays-are-not-pointers>
      
      Anyways, here's the patch:
      
      -Kurt
      
      Submitted by: "Kurt J. Lidl" <lidl@va.pubnix.com>
      9da9c091
    • Marc G. Fournier's avatar
      Fixes: · 59f29714
      Marc G. Fournier authored
      This patch forces postgres95 to assume any floating-point value is a
      float8.  It removes the requirement that you cast all floating-point
      constants to float8.
      
      We can remove alot of casts in the regression test after we are sure
      this works.
      
      If I have missed anything, would someone let me know.  I have tested
      inserts of floating-point values into float8 fields, and it worked well.
      Casting the number to float4 showed the same precision loss as previous
      uncast values showed.
      
      Submitted by: Bruce Momjian <maillist@candle.pha.pa.us>
      59f29714
    • Marc G. Fournier's avatar
      Fixes: · 9b7eb28e
      Marc G. Fournier authored
      There is a support routine in the standard 4.4BSD C library
      called "err()".  There is also a utility routine in
      .../src/backend/bootstrap/bootstrap.c
      with the same name.
      
      Here's a patch that renames the pg95 routine to something a little
      more sane.  As a bonus, one more bit of system-specific code leaves
      the system...
      
      Submitted by: "Kurt J. Lidl" <lidl@va.pubnix.com>
      9b7eb28e
    • Marc G. Fournier's avatar
      More code cleanups · 5bd4485c
      Marc G. Fournier authored
      Submitted by:  darcy@druid.druid.com (D'Arcy J.M. Cain)
      5bd4485c
  7. 10 Aug, 1996 2 commits
  8. 09 Aug, 1996 1 commit
  9. 06 Aug, 1996 8 commits
    • Julian Assange's avatar
      dfca0926
    • Marc G. Fournier's avatar
      Fixes: · ab57e09e
      Marc G. Fournier authored
      Also, I think that an extra source of noise in the diff of regress.out and
      expected.out is caused by not substituting the shared library file
      extension in the regression.input file (much like the paths and the
      usernames are sub'ed). This seems to be fixed with the following patches
      to regression.input and the Makefile... If I'm off base here, please tell!
      
      Submitted by:  Wayde Nie <niew@phoenix.cis.mcmaster.ca>
      ab57e09e
    • Marc G. Fournier's avatar
      Fixes: · bb0bdfd1
      Marc G. Fournier authored
      I've enclosed two patches.  The first affects Solaris compilability.  The
      bug stems from netdb.h (where MAXHOSTNAMELEN is defined on a stock
      system).  If the user has installed the header files from BIND 4.9.x,
      there will be no definition of MAXHOSTNAMELEN.  The patch will, if all
      else fails, try to include <arpa/nameser.h> and set MAXHOSTNAMELEN to
      MAXDNAME, which is 256 (just like MAXHOSTNAMELEN on a stock system).
      
      The second patch adds aliases for "ISNULL" to "IS NULL" and likewise for
      "NOTNULL" to "IS NOT NULL".  I have not removed the postgres specific
      ISNULL and NOTNULL.  I noticed this on the TODO list, and figured it would
      be easy to remove.
      
      The full semantics are:
              [ expression IS NULL ]
              [ expression IS NOT NULL ]
      
      --Jason
      
      
      Submitted by: Jason Wright <jason@oozoo.vnet.net>
      bb0bdfd1
    • Marc G. Fournier's avatar
      Fixes: · 6c684b18
      Marc G. Fournier authored
      Previously Postgres95 wouldn't accept 'order by' clauses with fields
      referred to as '<table>.<field>', e.g.:
      
              select t1.field1, t2.field2 from table1 t1, table2 t2
                      order by t2.field2;
      
      This syntax is required by the ODBC SQL spec.
      
      Submitted by: Dan McGuirk <mcguirk@indirect.com>
      6c684b18
    • Marc G. Fournier's avatar
      Fixes: · ab22b348
      Marc G. Fournier authored
      While a normal SELECT statement can contain a GROUP BY clause, a cursor
      declaration cannot. This was not the case in PG-1.0. Was there a good
      reason why this was changed? Are cursors being phased out? Is there any way
      to get data with just a SELECT (and without a DECLARE CURSOR ...)?
      
      The patch below seems to fix things. If anyone can see a problem with it,
      please let me know. Thanks.
      
      Submitted by:  David Smith <dasmith@perseus.tufts.edu>
      ab22b348
    • Marc G. Fournier's avatar
      Fixes for: · c4e53a14
      Marc G. Fournier authored
      Here are a few minor fixes to Postgres95.  Mostly I have added const
      to some of the char pointers.  There was also a missing header file
      and a place where it looks like "==" was used when "=" was meant.
      I also changed some variables from Pfin and Pfout tp pfin and pfout
      because the latter shadow global variables and that just seems like
      an unsafe practice which I like to avoid.
      
      Submitted by:  "D'Arcy J.M. Cain" <darcy@druid.druid.com>
      c4e53a14
    • Marc G. Fournier's avatar
      Had a space in CFLAGS+= -I .. · fd3b8299
      Marc G. Fournier authored
      Submitted by:  Andrew Martin <martin@biochemistry.ucl.ac.uk>
      fd3b8299
    • Julian Assange's avatar
      added patch from kurt that fixes memory leak (didn't free line buffer · 7ef04b25
      Julian Assange authored
      for slash commands)
      7ef04b25