psqlodbc.git
10 years agoAdd a Makefile target to run the tests with different config options.
Heikki Linnakangas [Thu, 27 Nov 2014 13:38:51 +0000 (15:38 +0200)]
Add a Makefile target to run the tests with different config options.

10 years agoMake the regression test output independent of some settings.
Heikki Linnakangas [Thu, 27 Nov 2014 13:32:09 +0000 (15:32 +0200)]
Make the regression test output independent of some settings.

Namely, UseServerSidePrepare, UseDeclareFetch and Protocol.

10 years agoRun the odbc[inst].ini generation script in a more Makefile fashion.
Heikki Linnakangas [Thu, 27 Nov 2014 12:32:32 +0000 (14:32 +0200)]
Run the odbc[inst].ini generation script in a more Makefile fashion.

The expected output didn't match what I got on my laptop. Not sure why,
or if it worked for anyone, but in any case it's more straightforward to
let make run the script directly, rather than through pg_regress.

In the passing, allow passing extra command line options to odbcini-gen.sh,
which will be appended to the generated odbc.ini. This makes it handy to
run the regressions with extra non-default options.

10 years agoAdd more test cases.
Heikki Linnakangas [Wed, 26 Nov 2014 12:50:45 +0000 (14:50 +0200)]
Add more test cases.

This adds coverage for SQLConnect, SQLRowCount, and moving a cursor with
SQLFetchScroll, and for bookmarks.

10 years agoRemove some remnants of old protocol support
Heikki Linnakangas [Wed, 26 Nov 2014 11:04:12 +0000 (13:04 +0200)]
Remove some remnants of old protocol support

10 years agoAnother round of -Wformat fixes.
Heikki Linnakangas [Thu, 13 Nov 2014 21:47:37 +0000 (23:47 +0200)]
Another round of -Wformat fixes.

10 years agoFix test case for big-endian systems.
Heikki Linnakangas [Thu, 13 Nov 2014 20:29:12 +0000 (22:29 +0200)]
Fix test case for big-endian systems.

10 years agoSilence more compiler warnings in -Wformat mode, in regression test.
Heikki Linnakangas [Thu, 13 Nov 2014 19:44:27 +0000 (21:44 +0200)]
Silence more compiler warnings in -Wformat mode, in regression test.

10 years agoSilence compiler warnings in -Wformat mode.
Heikki Linnakangas [Thu, 13 Nov 2014 18:46:38 +0000 (20:46 +0200)]
Silence compiler warnings in -Wformat mode.

Passing SQLINTEGER/SQLUINTEGER sprintf "%d", "%ld" modifiers gave a warning
on some systems (at least on my 32-bit Debian system) .

10 years agoAllow building test suite in a different place other than the source code is.
Hiroshi Inoue [Tue, 21 Oct 2014 07:57:28 +0000 (16:57 +0900)]
Allow building test suite in a different place other than the source code is.
Change the test suite so that it works not only with unixODBC but also with iodbc.

10 years agoAvoid buffer overrun by makeKeepaliveConnectString().
Hiroshi Inoue [Thu, 13 Nov 2014 07:43:09 +0000 (16:43 +0900)]
Avoid buffer overrun by makeKeepaliveConnectString().

10 years agoFix Windows compilation with libpq enabled, but without SSPI
Heikki Linnakangas [Mon, 3 Nov 2014 16:25:48 +0000 (18:25 +0200)]
Fix Windows compilation with libpq enabled, but without SSPI

GetUserNameEx function requires secur32.dll. It is now referenced in the
code, regardless of SSPI, so we need to link with secur32.dll.

10 years agoAdd test case for large objects.
Heikki Linnakangas [Mon, 3 Nov 2014 13:06:25 +0000 (15:06 +0200)]
Add test case for large objects.

10 years agoAdd test case.
Heikki Linnakangas [Mon, 3 Nov 2014 09:05:01 +0000 (11:05 +0200)]
Add test case.

This tests a codepath in QR_next_tuple that had no coverage before.

10 years agoAvoid conflicts of external symbols other than ODBC APis.
Hiroshi Inoue [Thu, 30 Oct 2014 03:40:13 +0000 (12:40 +0900)]
Avoid conflicts of external symbols other than ODBC APis.

10 years agoChange *ANSI* in the title of 32-bit Unicode driver setup dialog to *Unicode*.
Hiroshi Inoue [Sun, 2 Nov 2014 05:00:27 +0000 (14:00 +0900)]
Change *ANSI* in the title of 32-bit Unicode driver setup dialog to *Unicode*.

10 years agoRemove dead code
Heikki Linnakangas [Fri, 31 Oct 2014 17:53:24 +0000 (19:53 +0200)]
Remove dead code

10 years agoRemove option to disable geqo.
Heikki Linnakangas [Wed, 29 Oct 2014 18:00:59 +0000 (20:00 +0200)]
Remove option to disable geqo.

You can use the generic ConnSettings option for that.

10 years agoMinor code simplification.
Heikki Linnakangas [Thu, 30 Oct 2014 07:27:54 +0000 (09:27 +0200)]
Minor code simplification.

Any compiler worth its salt will turn "strlen(constant)" into a constant,
so let's get rid of the fancy logic to precalculate those.

10 years agoFix max identifier length stuff.
Heikki Linnakangas [Thu, 30 Oct 2014 20:43:56 +0000 (22:43 +0200)]
Fix max identifier length stuff.

CC_get_max_idlen function didn't work correctly. It sent the "show
identifier_length" query to the backend, but assumed that the value comes
back in the command tag. It doesnt; the command tag is always "SHOW".

We fell back to the compiled in NAMEDATALEN_V73 default. But that's
off-by-one; the actual max identifier length is NAMEDATALEN - 1.

10 years agoRemove support for receiving 'P' or 'B' responses from server.
Heikki Linnakangas [Wed, 29 Oct 2014 20:39:34 +0000 (22:39 +0200)]
Remove support for receiving 'P' or 'B' responses from server.

Server versions >= 7.4 don't send these anymore.

10 years agoRemove some unused #defines
Heikki Linnakangas [Wed, 29 Oct 2014 20:47:17 +0000 (22:47 +0200)]
Remove some unused #defines

10 years agoAvoid unnecessary round-trip to server at connection startup.
Heikki Linnakangas [Wed, 29 Oct 2014 19:16:26 +0000 (21:16 +0200)]
Avoid unnecessary round-trip to server at connection startup.

When connecting with libpq, we issued an explicit query,
"SELECT pg_client_encoding()" at the connection startup to get the
effective client_encoding. That's not really required; the server reports
that automatically right after the authentication handshake. We just have
to ask libpq for the current setting.

10 years agoMerge info30.c and info.c
Heikki Linnakangas [Wed, 29 Oct 2014 17:36:26 +0000 (19:36 +0200)]
Merge info30.c and info.c

We no longer support ODBC 3.0, so these don't need to be separate anymore.
This removes some duplicated code at the bottom of each GetInfoAPI.

Michael Paquier

10 years agoRemove odbcapi25w.c
Heikki Linnakangas [Wed, 29 Oct 2014 17:21:26 +0000 (19:21 +0200)]
Remove odbcapi25w.c

All the functions in that file are obsolete, as we no longer support old
ODBC versions.

Michael Paquier

10 years agoRemove some remnants of ODBCVER < 3.51 support.
Heikki Linnakangas [Wed, 29 Oct 2014 17:35:38 +0000 (19:35 +0200)]
Remove some remnants of ODBCVER < 3.51 support.

10 years agoRemove hack for Windows 95 & 98.
Heikki Linnakangas [Wed, 29 Oct 2014 17:32:50 +0000 (19:32 +0200)]
Remove hack for Windows 95 & 98.

Let's not pretend that we still support those.

10 years agoRemove references to removed KSQO and protocol options from the docs.
Heikki Linnakangas [Wed, 29 Oct 2014 17:16:33 +0000 (19:16 +0200)]
Remove references to removed KSQO and protocol options from the docs.

And some other stuff that was only relevant to very old server versions.

Michael Paquier, with some tweaks by me.

10 years agoRemove support for ODBC versions < 3.51.
Heikki Linnakangas [Wed, 29 Oct 2014 17:00:33 +0000 (19:00 +0200)]
Remove support for ODBC versions < 3.51.

Older versions have been obsolete for a very long time by now. Removing the
support lets us get rid of a lot of code that no-one has in practice been
even compiling for a long time.

Michael Paquier

10 years agoRemove support for protocol versions older than 3.
Heikki Linnakangas [Wed, 29 Oct 2014 14:35:05 +0000 (16:35 +0200)]
Remove support for protocol versions older than 3.

PostgreSQL added support for protocol version 3 in server version 7.4.
There's no need to support servers older than that. This simplifies the
code a lot, removing a lot of corner cases that haven't been properly
regression tested for a long time anyway.

Original patch by me, with some tweaks by Michael Paquier.

11 years agoPrep next release version 09.03.0400. REL-09_03_0400
Hiroshi Saito [Sat, 25 Oct 2014 16:15:01 +0000 (01:15 +0900)]
Prep next release version 09.03.0400.

11 years agoOops, two files forget..
Hiroshi Saito [Sat, 25 Oct 2014 15:54:20 +0000 (00:54 +0900)]
Oops, two files forget..

11 years agoPrep next release Version 09.03.0400.
Hiroshi Saito [Sat, 25 Oct 2014 15:43:54 +0000 (00:43 +0900)]
Prep next release Version 09.03.0400.

11 years agoAdd some files.
Hiroshi Saito [Sat, 25 Oct 2014 15:38:35 +0000 (00:38 +0900)]
Add some files.

11 years agoPrep next release version 09.03.0400.
Hiroshi Saito [Sat, 25 Oct 2014 15:21:18 +0000 (00:21 +0900)]
Prep next release version 09.03.0400.

11 years agoFix some differnces in regression test.
Hiroshi Inoue [Sat, 25 Oct 2014 13:57:53 +0000 (22:57 +0900)]
Fix some differnces in regression test.
1. result-convrsion-test.c
   Explicitly specify an appropriate time zone.
   isprint() doesn't work as expected in my environment. It's safe
   to verify that the parameter is a single byte before calling
   isprint().

2. prepare-test.c
   Explicitly specify "postgres_verbose" intervalstyle.

3. diagnostics.c
   pg_terminate_backend() sometimes succeeds with no error message.

11 years agoEnable -Wall compile option if it's available.
Hiroshi Inoue [Mon, 13 Oct 2014 04:52:52 +0000 (13:52 +0900)]
Enable -Wall compile option if it's available.

11 years agoPG_BUILD_VERSION seems no longer needed.
Hiroshi Inoue [Sat, 11 Oct 2014 10:29:40 +0000 (19:29 +0900)]
PG_BUILD_VERSION seems no longer needed.

11 years agoInclude pdb files in the contents of installers.
Hiroshi Inoue [Sat, 11 Oct 2014 07:18:04 +0000 (16:18 +0900)]
Include pdb files in the contents of installers.

11 years agoRemoved RESET_CRYPTO_CALLBACKS preprocessor symbol definition.
Hiroshi Inoue [Sat, 11 Oct 2014 07:45:32 +0000 (16:45 +0900)]
Removed RESET_CRYPTO_CALLBACKS preprocessor symbol definition.
This is no longer needed and rather dangerous.
The removal also make it possible to remove the dependency to libeay32.

11 years agoRemoved a duplicated description.
Hiroshi Inoue [Thu, 9 Oct 2014 23:53:03 +0000 (08:53 +0900)]
Removed a duplicated description.

11 years agoSuppress option button from the bootstrapper dialog using BalExtention.
Hiroshi Inoue [Thu, 9 Oct 2014 06:45:47 +0000 (15:45 +0900)]
Suppress option button from the bootstrapper dialog using BalExtention.

11 years agoDon't continue to build installers in case the compilation failed.
Hiroshi Inoue [Wed, 8 Oct 2014 23:10:32 +0000 (08:10 +0900)]
Don't continue to build installers in case the compilation failed.

11 years agoUse 1ST, 2ND or 3RD PAGE instead of PREV or NEXT PAGE for the setup
Hiroshi Inoue [Wed, 8 Oct 2014 21:26:33 +0000 (06:26 +0900)]
Use 1ST, 2ND or 3RD PAGE instead of PREV or NEXT PAGE for the setup
program.

11 years agoAdd a powershell script buildBootStrapper.ps1 which builds bootStrapper program
Hiroshi Inoue [Tue, 24 Jun 2014 01:02:53 +0000 (10:02 +0900)]
Add a powershell script buildBootStrapper.ps1 which builds bootStrapper program
with some optional parameters. Quote the version number of bootstrapper from
the configuration xml file unless specified. Also change the name of 32bit MSI
in the bootstrapper according to changes of 32bit installer build system.
Change buildInstallers.ps1 build the bootstrapper together.
Change ALLUSERS from "2" to "1" of the 64bit installer.

11 years agoFix the wrong use of snprintf format in the previous commit.
Hiroshi Inoue [Wed, 8 Oct 2014 08:17:53 +0000 (17:17 +0900)]
Fix the wrong use of snprintf format in the previous commit.

11 years agoAvoid the registry operation to set XADLL entry from wow64 process.
Hiroshi Inoue [Wed, 8 Oct 2014 07:44:50 +0000 (16:44 +0900)]
Avoid the registry operation to set XADLL entry from wow64 process.

11 years agoCleanup the code for *test* button and add the functionality to test
Hiroshi Inoue [Thu, 3 Jul 2014 03:47:41 +0000 (12:47 +0900)]
Cleanup the code for *test* button and add the functionality to test
MSDTC support.

11 years agoAdd a new dialog page to the setup program and allow the setting
Hiroshi Inoue [Wed, 1 Oct 2014 04:01:54 +0000 (13:01 +0900)]
Add a new dialog page to the setup program and allow the setting
of PREFERLIBPQ and XAOPT option.

11 years agoSilence compilers warnings without _HANDLE_ENLIST_IN_DTC_ or USE_LIBPQ.
Heikki Linnakangas [Tue, 7 Oct 2014 07:45:30 +0000 (10:45 +0300)]
Silence compilers warnings without _HANDLE_ENLIST_IN_DTC_ or USE_LIBPQ.

Compiler complained about unused variable.

11 years agoFix SQLTables column names to be ODBC version 3 compliant
Heikki Linnakangas [Tue, 7 Oct 2014 07:36:14 +0000 (10:36 +0300)]
Fix SQLTables column names to be ODBC version 3 compliant

In ODBC3, TABLE_QUALIFIER was renamed to TABLE_CAT, and TABLE_OWNER to
TABLE_SCHEM.

David Hedberg

11 years agoImprove regression test for reading a bytea column to SQL_C_CHAR.
Heikki Linnakangas [Tue, 7 Oct 2014 07:14:38 +0000 (10:14 +0300)]
Improve regression test for reading a bytea column to SQL_C_CHAR.

When converting a bytea to SQL_C_CHAR, the driver uses upper-case letters in
the hex output, while the backend uses lower-case letters. That leads to
different output when using bytea_output=hex than with bytea_output=escape.
Set bytea_output explicitly in the regression test, so that it works
regardless of the current bytea_output setting. And test both settings - the
code path taken in the driver is quite different.

11 years agoAdd the libpq use parameter to the dtc connection string.
Hiroshi Inoue [Mon, 6 Oct 2014 14:16:39 +0000 (23:16 +0900)]
Add the libpq use parameter to the dtc connection string.

11 years agoAdditonal improvement on MSDTC enlistment.
Hiroshi Inoue [Wed, 24 Sep 2014 13:22:29 +0000 (22:22 +0900)]
Additonal improvement on MSDTC enlistment.

Unfortunately the current pgxalib.dll can't recover transactions which use
sslmode verify-[ca|full] or whose authentication is SSPI, certificate or
ident.
When MSDTC.exe tries to connect to PostgreSQL it does so under Windows user
NETWORKSERVICE, which won't match the username the original user connected
to PostgreSQL as. So PostgreSQL will reject the connection.

In addition XARMcreate() doesn't detect it on enlistment because invoked
xa_open() doesn't connect to the specified datasource. Though it has no
problem unless crash occurs between PREAPARE and COMMIT, the recovery of
the transaction is impossible when such a crash occurs.

Now 3 diffrent behaviors can be speicified using the xaopt connection
string option.

 1: The current default behavior.
 2: Same as above except it simply examines if the recovery for the specified
    datasource is unavailable before calling XARMcreate(). Currently it only
    examines whether the connection uses sslmode verify-[ca|full]. I can't find
    the way to detect SSPI, certicate or ident authentication.
 3: Invoked xa_open() tries to connect to the specified datasource immediately
    as user Network Service.

11 years agoRegister the XA DLL on installation.
Hiroshi Inoue [Fri, 26 Sep 2014 02:38:18 +0000 (11:38 +0900)]
Register the XA DLL on installation.
MSDTC runs in 64bit mode on 64bit machines and 32bit mode on 32bit machines.
We had better register the XA DLL on installation.

11 years agoFix the regkey search bug when XARMcreate() causes an error at enlistment
Hiroshi Inoue [Fri, 26 Sep 2014 01:06:29 +0000 (10:06 +0900)]
Fix the regkey search bug when XARMcreate() causes an error at enlistment
in DTC.

11 years agoAdd '#ifdef USE_LIBPQ' around the code which use PreferLibpq option
Hiroshi Inoue [Thu, 25 Sep 2014 00:11:55 +0000 (09:11 +0900)]
Add '#ifdef USE_LIBPQ' around the code which use PreferLibpq option
introduced in the previous commit.

11 years agoAdd an option to explicitly force/avoid the use of libpq library.
Hiroshi Inoue [Tue, 16 Sep 2014 07:51:38 +0000 (16:51 +0900)]
Add an option to explicitly force/avoid the use of libpq library.

11 years agoImprove pgxalib.dll(MSDTC support).
Hiroshi Inoue [Tue, 24 Jun 2014 00:58:46 +0000 (09:58 +0900)]
Improve pgxalib.dll(MSDTC support).
1. Add an option which lets xa_open() try to connect to the database
   immediately. This would cause an error at enlistment in dtc when
   the authentication method depends not only on the db user but also
   on the OS user, which means the automatic transaction recovery is
   unavailable.
2. Log the error message in case of SQLDriverConnect() error.
3. Improve the logging.

11 years agoFix the bug reported by Phillippe Champignon.
Hiroshi Inoue [Sun, 21 Sep 2014 04:59:09 +0000 (13:59 +0900)]
Fix the bug reported by Phillippe Champignon.
The function SC_setInsertedTable() prepares an info for subsequent
'select @@IDENTITY' command. Take table name like catalog.schema.table
into account in the function.

11 years agoAdd msvc runtime dlls which are needed by the drivers to the installers.
Hiroshi Inoue [Wed, 17 Sep 2014 03:34:10 +0000 (12:34 +0900)]
Add msvc runtime dlls which are needed by the drivers to the installers.

11 years agoAdd a switch type parameter to BuildAll Powershell script which makes
Hiroshi Inoue [Fri, 19 Sep 2014 04:25:55 +0000 (13:25 +0900)]
Add a switch type parameter to BuildAll Powershell script which makes
it possible to build the installers after building drivers.

11 years agoFix a crash bug.
Hiroshi Inoue [Sun, 14 Sep 2014 00:26:16 +0000 (09:26 +0900)]
Fix a crash bug.

11 years agoFix buffer overflow in SQLGetData.
Heikki Linnakangas [Fri, 5 Sep 2014 14:55:22 +0000 (17:55 +0300)]
Fix buffer overflow in SQLGetData.

If a PostgreSQL timestamp column is fetched using SQLGetData, into a
SQL_C_CHAR output variable, with size of 20-22 bytes, the driver might
overrun the buffer by a few bytes with unusual timestamp values, with
year < 0 or > 10000.

While at it, fix the truncation behavior for date/time/timestamp values
so that if the output buffer is too small, we still write what fits and
truncate, instead of writing nothing. This is something that one might
do on purpose, e.g. if you only want to fetch the year part of a date,
you might call SQLGetData() on a date column, with only 4 bytes long
output buffer. (although we haven't heard any complaints from the field).

Also, if the output buffer is of type SQL_C_WCHAR, but the buffer length
is odd, and we have to truncate, we didn't NULL-terminate the string.
Using an odd-sized buffer with SQL_C_WCHAR is a pretty unlikely thing to
do, but nevertheless I think this is more correct behavior.

Add test cases for the bugs fixed.

11 years agoAdd a test case for data type conversions for results coming from server
Heikki Linnakangas [Fri, 5 Sep 2014 14:39:09 +0000 (17:39 +0300)]
Add a test case for data type conversions for results coming from server

11 years agoMinor cleanup.
Heikki Linnakangas [Fri, 5 Sep 2014 14:23:16 +0000 (17:23 +0300)]
Minor cleanup.

11 years agoRemove unused or bogus PG_TYPE macros.
Heikki Linnakangas [Fri, 5 Sep 2014 12:47:31 +0000 (15:47 +0300)]
Remove unused or bogus PG_TYPE macros.

Some of these allegedly built-in types didn't exist in PostgreSQL source code
(maybe they did in some ancient version?), some were just unused in
psqlodbc code.

11 years agoRemove unused function.
Heikki Linnakangas [Thu, 4 Sep 2014 07:55:40 +0000 (10:55 +0300)]
Remove unused function.

Silences a compiler warning.

11 years agoFix bug in building an abbreviated connection string.
Heikki Linnakangas [Thu, 4 Sep 2014 07:50:28 +0000 (10:50 +0300)]
Fix bug in building an abbreviated connection string.

Introduced by the keepalive-patch, which accidentally removed a line from
sprintf format string. Caught by a compiler warning.

11 years agoSilence compiler warnings about unused variables.
Heikki Linnakangas [Thu, 4 Sep 2014 07:37:56 +0000 (10:37 +0300)]
Silence compiler warnings about unused variables.

11 years agoFix race condition in getting the current decimal separator.
Heikki Linnakangas [Thu, 4 Sep 2014 07:27:55 +0000 (10:27 +0300)]
Fix race condition in getting the current decimal separator.

The code to get the current decimal separator was not thread-safe. If two
threads concurrently saw that the locale had changed, they might both try
to free() the same string.

This isn't a perfect fix, there's still a race condition if a thread changes
the locale while another thread is running the psqlodbc code. But at least
this eliminates the race condition when the locale was changed earlier, not
concurrently, and even if it is changed concurrently, this is less likely
to crash, depending on the way localeconv() is implemented in libc.

11 years agoClear unused stuff from PgDtc_isolate() function. Also add CC_initialize_pg_version...
Hiroshi Inoue [Fri, 20 Jun 2014 12:23:31 +0000 (18:08 +0545)]
Clear unused stuff from PgDtc_isolate() function. Also add CC_initialize_pg_version() call after CC_copy_conninfo() so as to avoid the trouble caused by early PG_VERSION_xx() calls.

11 years agoGet rid of copy and paste code in installer/ and unify them.
Hiroshi Inoue [Tue, 12 Aug 2014 04:28:16 +0000 (13:28 +0900)]
Get rid of copy and paste code in installer/ and unify them.

The powershell scripts had lots of duplication. Make the unified
code instead.
Original patch was provided by Craig Ringer.

11 years agoAdd a check for NULL dereference pointed out by Pluto Cobain.
Hiroshi Inoue [Thu, 10 Jul 2014 03:51:50 +0000 (12:51 +0900)]
Add a check for NULL dereference pointed out by Pluto Cobain.
It's for safety though I don't think it would occur.

11 years agoRemove duplicated line in snprintf() which causes a crash introduced by
Hiroshi Inoue [Tue, 8 Jul 2014 05:22:17 +0000 (14:22 +0900)]
Remove duplicated line in snprintf() which causes a crash introduced by
the commit 1177281049e8bb3df5992da5dc1ca31ad892082e.

11 years agoRemove unsed dialog which was added by mistake.
Hiroshi Inoue [Mon, 7 Jul 2014 03:47:30 +0000 (12:47 +0900)]
Remove unsed dialog which was added by mistake.

11 years agoRevise descriptor stuff.
Hiroshi Inoue [Fri, 13 Jun 2014 12:47:24 +0000 (18:32 +0545)]
Revise descriptor stuff.
descriptor.c(h) was broken by the commit
2da1668f4c7d7871a7212db10af606a7e646abd6
and it now causes a crash bug.
Instead of reverting the change revising the stuff completely.

11 years agoFix a memory leak pointed out by pluto.cobain.
Hiroshi Inoue [Fri, 4 Jul 2014 03:52:49 +0000 (12:52 +0900)]
Fix a memory leak pointed out by pluto.cobain.

11 years agoRemove the duplicate winbuild readme
Craig Ringer [Thu, 3 Jul 2014 06:03:19 +0000 (14:03 +0800)]
Remove the duplicate winbuild readme

11 years agoRemove obsolete .bat installer creators
Craig Ringer [Thu, 3 Jul 2014 05:56:44 +0000 (13:56 +0800)]
Remove obsolete .bat installer creators

11 years agoDocument enabling MSDTC tracing
Craig Ringer [Thu, 3 Jul 2014 04:59:07 +0000 (12:59 +0800)]
Document enabling MSDTC tracing

11 years agoDocument build opts for SDK vs VS better
Craig Ringer [Thu, 3 Jul 2014 04:58:51 +0000 (12:58 +0800)]
Document build opts for SDK vs VS better

11 years agoAdd KeepaliveTime and KeepaliveInterval options to specify time or
Hiroshi Inoue [Sun, 1 Jun 2014 10:08:28 +0000 (19:08 +0900)]
Add KeepaliveTime and KeepaliveInterval options to specify time or
interval for keepalive.

11 years agoRemove PgDtc_set_property(.., prepareRequestded, 0) which causes a crash
Hiroshi Inoue [Mon, 30 Jun 2014 11:59:22 +0000 (20:59 +0900)]
Remove PgDtc_set_property(.., prepareRequestded, 0) which causes a crash
in case PREPARE TRANSACTION error. The property prepareRequested isn't set
anywhere.

11 years agoFix driver name mismatch between 32-bit ODBC app and 64-bit MSDTC host
Craig Ringer [Wed, 25 Jun 2014 07:17:00 +0000 (15:17 +0800)]
Fix driver name mismatch between 32-bit ODBC app and 64-bit MSDTC host

If the 32-bit driver runs on a 64-bit host within a 32-bit app
running under SysWow64 then XA transactions will fail to recover.

That's because recovery is done by pgxalib.dll which runs within
MSDTC.exe - a 64-bit application. It connects to a DSN supplied
by psqlODBC in EnlistInDtc_1pipe during DTC enlistment by the
XA resource manager. This DSN uses the driver name of the client's
ODBC driver - which is fine so long as the client and MSDTC
architectures match. If they don't then MSDTC will fail to connect
to Pg, so it'll never resolve transactions.

Traces of MSDTC will show RM_COMMIT_DELIVERY_FAILED_DUE_TO_CONNECTION_DOWN
events.

Traces of pgxalib.dll will show xa_recover(..) being entered, followed by
"SQLDriverConnect return=-1".

To fix this, we detect if we're running under SysWow64 by examining the
PROCESSOR_ARCHITEW6432 environment variable and supply the 64-bit driver name
if so.

See mailing list thread:

  http://www.postgresql.org/message-id/53A45B59.70303@2ndquadrant.com

for details.

Craig Ringer

11 years agoFix bug with UseDeclareFetch=1 when a transaction is committed before fetch.
Heikki Linnakangas [Tue, 24 Jun 2014 13:38:00 +0000 (16:38 +0300)]
Fix bug with UseDeclareFetch=1 when a transaction is committed before fetch.

If a server cursor is closed before the application has fetched any rows
from the result set, the "base" of the result set's cached rowset was
off-by-one.

Also add a regression test for the same.

This fixes the bug reported by Jan-Peter Seifert.

11 years agoRemove unused function.
Heikki Linnakangas [Tue, 24 Jun 2014 07:27:46 +0000 (10:27 +0300)]
Remove unused function.

Previous commit added a void return to a function with char * return value,
which generated a warning. On further inspection, the whole function is
used nowhere, so just remove it rather than try fixing the warning.

11 years agoThis patch fixes a NULL pointer dereference occurring when connecting
Hiroshi Inoue [Tue, 24 Jun 2014 03:22:15 +0000 (12:22 +0900)]
This patch fixes a NULL pointer dereference occurring when connecting
using SSPI authentication (without kerberos, a local Windows user trying
to connect to postgres instance on same host). Patch originally by
Nikhil R Deshpande, 1 line added for safety by me.

11 years agoFix compilation on Windows, broken by my previous commit.
Heikki Linnakangas [Mon, 23 Jun 2014 07:55:50 +0000 (10:55 +0300)]
Fix compilation on Windows, broken by my previous commit.

Michael Paquier

11 years agoRefactor SQLCancel() and add comments, for readability.
Heikki Linnakangas [Fri, 20 Jun 2014 16:43:20 +0000 (19:43 +0300)]
Refactor SQLCancel() and add comments, for readability.

11 years agoFix bug in SQLCancel().
Heikki Linnakangas [Fri, 20 Jun 2014 16:43:13 +0000 (19:43 +0300)]
Fix bug in SQLCancel().

If one thread was busy executing a savepoint statement, while another thread
calls SQLCancel() on the statement, SQLCancel() would try to release the
locks held by the other thread. That's extremely racy; if the other thread
tries to increment/decrement the lock_CC_for_rb counter at the same time,
we could end up releasing the lock to many times or too few times. Also,
releasing a pthread mutex from a different thread than the one who acquired
it is undefined behavior.

AFAICS the DiscardStatementSvp() call in SQLCancel() can be safely removed.
It's outright wrong and dangerous if the statement is busy executing in
a different thread, and the other codepaths in PGAPI_Cancel() already call
DiscardStatementSvp().

Bug report by Jade Koskela.

11 years agoFix broken buildX86-installer.ps1 due to the change to use psqlodbcm_cpu.wxs instead...
Hiroshi Inoue [Fri, 20 Jun 2014 02:09:19 +0000 (11:09 +0900)]
Fix broken buildX86-installer.ps1 due to the change to use psqlodbcm_cpu.wxs instead of psqlodbcm.wxs.

11 years agoDon't use PG_VERSION_xx() macros in original_CC_connect() because
Hiroshi Inoue [Fri, 20 Jun 2014 03:19:45 +0000 (12:19 +0900)]
Don't use PG_VERSION_xx() macros in original_CC_connect() because
it's not obtained from the server yet. This may fix another cause
of the problem Craig Ringer reported.

11 years agoMerge remote-tracking branch 'ringerc/fix-febe-protocol-desync-emptyquery'
Hiroshi Inoue [Fri, 20 Jun 2014 02:13:25 +0000 (11:13 +0900)]
Merge remote-tracking branch 'ringerc/fix-febe-protocol-desync-emptyquery'

11 years agoFix use of server-queried version before connection
Craig Ringer [Thu, 19 Jun 2014 05:56:57 +0000 (13:56 +0800)]
Fix use of server-queried version before connection

psqlODBC attempted to use the version that's queried from the server before it
was obtained from the server during the connection setup. Because the server
version is initialized to 0.0, tests for "server version >= 7.4" or "server
version >= 6.4" using the PG_VERSION_LT macro were always returning false.

Instead, use PROTOCOL_64 and PROTOCOL_74 tests against conninfo. These don't
offer any "greater than" form, so just test both. There's little point adding
anything prettier when it can all be removed when v1/v2 protocol support is
removed soon anyway.

The main symptom of this issue was that psqlODBC was sending an invalid
protocol message for the v3 protocol, "Q \0", causing the server to wait for
the second half of the length word forever. At connection close, the server
would emit:

    unexpected EOF within message length word

This issue was observed while tracking down problems with XA transactions in
MSDTC failing to commit after a successful prepare because an isolated tx
created via getLockedXAConn() got stuck here, but is not confined to that
problem.

11 years agoFix the problems using SQLFetch on prepared INSERT with RETURNING clause reported...
Hiroshi Inoue [Sun, 1 Jun 2014 05:42:21 +0000 (14:42 +0900)]
Fix the problems using SQLFetch on prepared INSERT with RETURNING clause reported by John Smith.

11 years agoClear errors for prepared statement for subsequent exections.
Hiroshi Inoue [Sun, 1 Jun 2014 09:35:50 +0000 (18:35 +0900)]
Clear errors for prepared statement for subsequent exections.

11 years agoIncrease digits used to convert from REAL/DOUBLEs to strings so that the reverse
Hiroshi Inoue [Thu, 19 Jun 2014 04:39:07 +0000 (10:24 +0545)]
Increase digits used to convert from REAL/DOUBLEs to strings so that the reverse
 conversions can recover original values. Patch originally by John Smith, slightly changed by me.

11 years agoSQL_NUMERIC_STRUCT was not available until ODBC 3.0
Heikki Linnakangas [Wed, 18 Jun 2014 18:08:07 +0000 (21:08 +0300)]
SQL_NUMERIC_STRUCT was not available until ODBC 3.0

Also add a prototype for ResolveNumericParam for readability.

11 years agoFix access to unallocated memory in IAsyncPG
Craig Ringer [Mon, 16 Jun 2014 13:16:31 +0000 (21:16 +0800)]
Fix access to unallocated memory in IAsyncPG

IAsyncPG was deleting its self, then returning an instance variable
by value. This is probably going to be safe pretty much all the time,
but it's still a memory error, and DrMemory (a Windows valgrind-alike)
complains about it:

Error #4: UNADDRESSABLE ACCESS: reading 0x00b1b2b0-0x00b1b2b4 4 byte(s)
# 0 pgenlista.dll!IAsyncPG::Release   [c:\users\administrator\desktop\psqlodbc\msdtc_enlist.cpp:352]
# 1 pgenlista.dll!CloseCommitThread   [c:\users\administrator\desktop\psqlodbc\msdtc_enlist.cpp:971]
# 2 MSVCR120D.dll!_callthreadstart    [f:\dd\vctools\crt\crtw32\startup\thread.c:255]
# 3 MSVCR120D.dll!_threadstart        [f:\dd\vctools\crt\crtw32\startup\thread.c:237]
# 4 KERNEL32.dll!BaseThreadInitThunk +0x11     (0x7768338a <KERNEL32.dll+0x1338a>)
Note: @0:00:57.879 in thread 4516
Note: next higher malloc: 0x00b1b420-0x00b1b440
Note: 0x00b1b2b0-0x00b1b2b4 overlaps memory 0x00b1b2a0-0x00b1b390 that was freed here:
Note: # 0 replace_operator_delete                              [d:\drmemory_package\common\alloc_replace.c:2524]
Note: # 1 pgenlista.dll!IAsyncPG::`scalar deleting destructor'
Note: # 2 pgenlista.dll!IAsyncPG::Release                      [c:\users\administrator\desktop\psqlodbc\msdtc_enlist.cpp:341]
Note: # 3 pgenlista.dll!CloseCommitThread                      [c:\users\administrator\desktop\psqlodbc\msdtc_enlist.cpp:971]
Note: # 4 MSVCR120D.dll!_callthreadstart                       [f:\dd\vctools\crt\crtw32\startup\thread.c:255]
Note: # 5 MSVCR120D.dll!_threadstart                           [f:\dd\vctools\crt\crtw32\startup\thread.c:237]
Note: # 6 KERNEL32.dll!BaseThreadInitThunk                    +0x11     (0x7768338a <KERNEL32.dll+0x1338a>)
Note: instruction: mov    0x10(%eax) -> %eax

This patch fixes the issue.