Resolve compile errors on unix.
Rename psqlodbc.def -> psqlodbc_win32.def. Improve internal *declare cursor* handling a little. Hiroshi Inoue
This commit is contained in:
parent
02b1a7fd51
commit
4ad1b5b766
@ -21,6 +21,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
|
#include "psqlodbc.h"
|
||||||
#ifdef MULTIBYTE
|
#ifdef MULTIBYTE
|
||||||
#include "multibyte.h"
|
#include "multibyte.h"
|
||||||
#endif
|
#endif
|
||||||
@ -938,6 +939,26 @@ into_table_from(const char *stmt)
|
|||||||
return isspace((unsigned char) stmt[4]);
|
return isspace((unsigned char) stmt[4]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*----------
|
||||||
|
* Check if the statement is
|
||||||
|
* SELECT ... FOR UPDATE .....
|
||||||
|
* This isn't really a strict check but ...
|
||||||
|
*----------
|
||||||
|
*/
|
||||||
|
static BOOL
|
||||||
|
table_for_update(const char *stmt, int *endpos)
|
||||||
|
{
|
||||||
|
const char *wstmt = stmt;
|
||||||
|
while (isspace((unsigned char) *(++wstmt)));
|
||||||
|
if (! *wstmt)
|
||||||
|
return FALSE;
|
||||||
|
if (strnicmp(wstmt, "update", 6))
|
||||||
|
return FALSE;
|
||||||
|
wstmt += 6;
|
||||||
|
*endpos = wstmt - stmt;
|
||||||
|
return !wstmt[0] || isspace((unsigned char) wstmt[0]);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function inserts parameters into an SQL statements.
|
* This function inserts parameters into an SQL statements.
|
||||||
* It will also modify a SELECT statement for use with declare/fetch cursors.
|
* It will also modify a SELECT statement for use with declare/fetch cursors.
|
||||||
@ -968,14 +989,17 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
Oid lobj_oid;
|
Oid lobj_oid;
|
||||||
int lobj_fd,
|
int lobj_fd,
|
||||||
retval;
|
retval;
|
||||||
BOOL check_select_into = FALSE; /* select into check */
|
BOOL check_cursor_ok = FALSE; /* check cursor restriction */
|
||||||
BOOL proc_no_param = TRUE;
|
BOOL proc_no_param = TRUE;
|
||||||
unsigned int declare_pos;
|
unsigned int declare_pos = 0;
|
||||||
ConnectionClass *conn = SC_get_conn(stmt);
|
ConnectionClass *conn = SC_get_conn(stmt);
|
||||||
ConnInfo *ci = &(conn->connInfo);
|
ConnInfo *ci = &(conn->connInfo);
|
||||||
BOOL prepare_dummy_cursor = FALSE;
|
BOOL prepare_dummy_cursor = FALSE;
|
||||||
|
char token_save[32];
|
||||||
|
int token_len;
|
||||||
|
BOOL prev_token_end;
|
||||||
#ifdef DRIVER_CURSOR_IMPLEMENT
|
#ifdef DRIVER_CURSOR_IMPLEMENT
|
||||||
BOOL ins_ctrl = FALSE;
|
BOOL search_from_pos = FALSE;
|
||||||
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
||||||
#ifdef PREPARE_TRIAL
|
#ifdef PREPARE_TRIAL
|
||||||
prepare_dummy_cursor = stmt->pre_executing;
|
prepare_dummy_cursor = stmt->pre_executing;
|
||||||
@ -1012,7 +1036,7 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
||||||
else if (!stmt->ti || stmt->ntab != 1)
|
else if (!stmt->ti || stmt->ntab != 1)
|
||||||
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
||||||
else ins_ctrl = TRUE;
|
else search_from_pos = TRUE;
|
||||||
}
|
}
|
||||||
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
||||||
|
|
||||||
@ -1021,7 +1045,10 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
sprintf(stmt->cursor_name, "SQL_CUR%p", stmt);
|
sprintf(stmt->cursor_name, "SQL_CUR%p", stmt);
|
||||||
oldstmtlen = strlen(old_statement);
|
oldstmtlen = strlen(old_statement);
|
||||||
CVT_INIT(oldstmtlen);
|
CVT_INIT(oldstmtlen);
|
||||||
|
|
||||||
stmt->miscinfo = 0;
|
stmt->miscinfo = 0;
|
||||||
|
token_len = 0;
|
||||||
|
prev_token_end = TRUE;
|
||||||
/* For selects, prepend a declare cursor to the statement */
|
/* For selects, prepend a declare cursor to the statement */
|
||||||
if (stmt->statement_type == STMT_TYPE_SELECT)
|
if (stmt->statement_type == STMT_TYPE_SELECT)
|
||||||
{
|
{
|
||||||
@ -1035,10 +1062,10 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
}
|
}
|
||||||
else if (ci->drivers.use_declarefetch)
|
else if (ci->drivers.use_declarefetch)
|
||||||
SC_set_fetchcursor(stmt);
|
SC_set_fetchcursor(stmt);
|
||||||
sprintf(new_statement, "%s declare %s cursor for ",
|
sprintf(new_statement, "%sdeclare %s cursor for ",
|
||||||
new_statement, stmt->cursor_name);
|
new_statement, stmt->cursor_name);
|
||||||
npos = strlen(new_statement);
|
npos = strlen(new_statement);
|
||||||
check_select_into = TRUE;
|
check_cursor_ok = TRUE;
|
||||||
declare_pos = npos;
|
declare_pos = npos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1176,28 +1203,68 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
in_escape = TRUE;
|
in_escape = TRUE;
|
||||||
else if (oldchar == '\"')
|
else if (oldchar == '\"')
|
||||||
in_dquote = TRUE;
|
in_dquote = TRUE;
|
||||||
else if (check_select_into && /* select into check */
|
else
|
||||||
opos > 0 &&
|
|
||||||
isspace((unsigned char) old_statement[opos - 1]) &&
|
|
||||||
into_table_from(&old_statement[opos]))
|
|
||||||
{
|
{
|
||||||
stmt->statement_type = STMT_TYPE_CREATE;
|
if (isspace(oldchar))
|
||||||
SC_no_pre_executable(stmt);
|
{
|
||||||
SC_no_fetchcursor(stmt);
|
if (!prev_token_end)
|
||||||
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
{
|
||||||
memmove(new_statement, new_statement + declare_pos, npos - declare_pos);
|
prev_token_end = TRUE;
|
||||||
npos -= declare_pos;
|
token_save[token_len] = '\0';
|
||||||
}
|
if (token_len == 4)
|
||||||
|
{
|
||||||
|
if (check_cursor_ok &&
|
||||||
|
into_table_from(&old_statement[opos - token_len]))
|
||||||
|
{
|
||||||
|
stmt->statement_type = STMT_TYPE_CREATE;
|
||||||
|
SC_no_pre_executable(stmt);
|
||||||
|
SC_no_fetchcursor(stmt);
|
||||||
|
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
||||||
|
memmove(new_statement, new_statement + declare_pos, npos - declare_pos);
|
||||||
|
npos -= declare_pos;
|
||||||
|
}
|
||||||
#ifdef DRIVER_CURSOR_IMPLEMENT
|
#ifdef DRIVER_CURSOR_IMPLEMENT
|
||||||
else if (ins_ctrl && /* select into check */
|
else if (search_from_pos && /* where's from clause */
|
||||||
opos > 0 &&
|
strnicmp(token_save, "from", 4) == 0)
|
||||||
isspace((unsigned char) old_statement[opos - 1]) &&
|
{
|
||||||
strnicmp(&old_statement[opos], "from", 4) == 0)
|
search_from_pos = FALSE;
|
||||||
{
|
npos -= 5;
|
||||||
ins_ctrl = FALSE;
|
CVT_APPEND_STR(", CTID, OID from");
|
||||||
CVT_APPEND_STR(", CTID, OID ");
|
}
|
||||||
}
|
|
||||||
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
||||||
|
}
|
||||||
|
if (token_len == 3)
|
||||||
|
{
|
||||||
|
int endpos;
|
||||||
|
if (check_cursor_ok &&
|
||||||
|
strnicmp(token_save, "for", 3) == 0 &&
|
||||||
|
table_for_update(&old_statement[opos], &endpos))
|
||||||
|
{
|
||||||
|
SC_no_fetchcursor(stmt);
|
||||||
|
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
||||||
|
if (prepare_dummy_cursor)
|
||||||
|
{
|
||||||
|
npos -= 4;
|
||||||
|
opos += endpos;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
memmove(new_statement, new_statement + declare_pos, npos - declare_pos);
|
||||||
|
npos -= declare_pos;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (prev_token_end)
|
||||||
|
{
|
||||||
|
prev_token_end = FALSE;
|
||||||
|
token_save[0] = oldchar;
|
||||||
|
token_len = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
token_save[token_len++] = oldchar;
|
||||||
|
}
|
||||||
CVT_APPEND_CHAR(oldchar);
|
CVT_APPEND_CHAR(oldchar);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -1634,7 +1701,7 @@ copy_statement_with_parameters(StatementClass *stmt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DRIVER_CURSOR_IMPLEMENT
|
#ifdef DRIVER_CURSOR_IMPLEMENT
|
||||||
if (ins_ctrl)
|
if (search_from_pos)
|
||||||
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
stmt->options.scroll_concurrency = SQL_CONCUR_READ_ONLY;
|
||||||
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
#endif /* DRIVER_CURSOR_IMPLEMENT */
|
||||||
#ifdef PREPARE_TRIAL
|
#ifdef PREPARE_TRIAL
|
||||||
@ -2142,7 +2209,7 @@ decode(const char *in, char *out)
|
|||||||
*-------
|
*-------
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
convert_lo(StatementClass *stmt, void *value, Int2 fCType, PTR rgbValue,
|
convert_lo(StatementClass *stmt, const void *value, Int2 fCType, PTR rgbValue,
|
||||||
SDWORD cbValueMax, SDWORD *pcbValue)
|
SDWORD cbValueMax, SDWORD *pcbValue)
|
||||||
{
|
{
|
||||||
Oid oid;
|
Oid oid;
|
||||||
|
@ -29,8 +29,8 @@ typedef struct
|
|||||||
int ss;
|
int ss;
|
||||||
} SIMPLE_TIME;
|
} SIMPLE_TIME;
|
||||||
|
|
||||||
int copy_and_convert_field_bindinfo(StatementClass *stmt, Int4 field_type, const void *value, int col);
|
int copy_and_convert_field_bindinfo(StatementClass *stmt, Int4 field_type, void *value, int col);
|
||||||
int copy_and_convert_field(StatementClass *stmt, Int4 field_type, const void *value, Int2 fCType,
|
int copy_and_convert_field(StatementClass *stmt, Int4 field_type, void *value, Int2 fCType,
|
||||||
PTR rgbValue, SDWORD cbValueMax, SDWORD *pcbValue);
|
PTR rgbValue, SDWORD cbValueMax, SDWORD *pcbValue);
|
||||||
|
|
||||||
int copy_statement_with_parameters(StatementClass *stmt);
|
int copy_statement_with_parameters(StatementClass *stmt);
|
||||||
|
@ -458,11 +458,11 @@ PGAPI_Cancel(
|
|||||||
static char *func = "PGAPI_Cancel";
|
static char *func = "PGAPI_Cancel";
|
||||||
StatementClass *stmt = (StatementClass *) hstmt;
|
StatementClass *stmt = (StatementClass *) hstmt;
|
||||||
RETCODE result;
|
RETCODE result;
|
||||||
|
ConnInfo *ci;
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
HMODULE hmodule;
|
HMODULE hmodule;
|
||||||
FARPROC addr;
|
FARPROC addr;
|
||||||
ConnInfo *ci;
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -51,15 +51,15 @@
|
|||||||
* ODBCINST_INI
|
* ODBCINST_INI
|
||||||
*/
|
*/
|
||||||
DWORD
|
DWORD
|
||||||
GetPrivateProfileString(char *theSection, /* section name */
|
GetPrivateProfileString(const char *theSection, /* section name */
|
||||||
char *theKey, /* search key name */
|
const char *theKey, /* search key name */
|
||||||
char *theDefault, /* default value if not
|
const char *theDefault, /* default value if not
|
||||||
* found */
|
* found */
|
||||||
char *theReturnBuffer, /* return value stored
|
char *theReturnBuffer, /* return value stored
|
||||||
* here */
|
* here */
|
||||||
size_t theReturnBufferLength, /* byte length of return
|
size_t theReturnBufferLength, /* byte length of return
|
||||||
* buffer */
|
* buffer */
|
||||||
char *theIniFileName) /* pathname of ini file to
|
const char *theIniFileName) /* pathname of ini file to
|
||||||
* search */
|
* search */
|
||||||
{
|
{
|
||||||
char buf[MAXPGPATH];
|
char buf[MAXPGPATH];
|
||||||
@ -273,10 +273,10 @@ GetPrivateProfileString(char *theSection, /* section name */
|
|||||||
|
|
||||||
|
|
||||||
DWORD
|
DWORD
|
||||||
WritePrivateProfileString(char *theSection, /* section name */
|
WritePrivateProfileString(const char *theSection, /* section name */
|
||||||
char *theKey, /* write key name */
|
const char *theKey, /* write key name */
|
||||||
char *theBuffer, /* input buffer */
|
const char *theBuffer, /* input buffer */
|
||||||
char *theIniFileName) /* pathname of ini file to
|
const char *theIniFileName) /* pathname of ini file to
|
||||||
* write */
|
* write */
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -17,22 +17,22 @@ extern "C"
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
DWORD
|
DWORD
|
||||||
GetPrivateProfileString(char *theSection, /* section name */
|
GetPrivateProfileString(const char *theSection, /* section name */
|
||||||
char *theKey, /* search key name */
|
const char *theKey, /* search key name */
|
||||||
char *theDefault, /* default value if not
|
const char *theDefault, /* default value if not
|
||||||
* found */
|
* found */
|
||||||
char *theReturnBuffer, /* return valuse stored
|
char *theReturnBuffer, /* return valuse stored
|
||||||
* here */
|
* here */
|
||||||
size_t theBufferLength, /* byte length of return
|
size_t theBufferLength, /* byte length of return
|
||||||
* buffer */
|
* buffer */
|
||||||
char *theIniFileName); /* pathname of ini file
|
const char *theIniFileName); /* pathname of ini file
|
||||||
* to search */
|
* to search */
|
||||||
|
|
||||||
DWORD
|
DWORD
|
||||||
WritePrivateProfileString(char *theSection, /* section name */
|
WritePrivateProfileString(const char *theSection, /* section name */
|
||||||
char *theKey, /* write key name */
|
const char *theKey, /* write key name */
|
||||||
char *theBuffer, /* input buffer */
|
const char *theBuffer, /* input buffer */
|
||||||
char *theIniFileName); /* pathname of ini file
|
const char *theIniFileName); /* pathname of ini file
|
||||||
* to write */
|
* to write */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -32,8 +32,6 @@
|
|||||||
#define FALSE (BOOL)0
|
#define FALSE (BOOL)0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern GLOBAL_VALUES globals;
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Used for building a Manual Result only
|
* Used for building a Manual Result only
|
||||||
@ -119,7 +117,7 @@ QR_Constructor()
|
|||||||
rv->cursor = NULL;
|
rv->cursor = NULL;
|
||||||
rv->aborted = FALSE;
|
rv->aborted = FALSE;
|
||||||
|
|
||||||
rv->cache_size = globals.fetch_max;
|
rv->cache_size = 0;
|
||||||
rv->rowset_size = 1;
|
rv->rowset_size = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -232,10 +232,10 @@ struct StatementClass_
|
|||||||
/* misc info */
|
/* misc info */
|
||||||
#define SC_set_pre_executable(a) (a->miscinfo |= 1L)
|
#define SC_set_pre_executable(a) (a->miscinfo |= 1L)
|
||||||
#define SC_no_pre_executable(a) (a->miscinfo &= ~1L)
|
#define SC_no_pre_executable(a) (a->miscinfo &= ~1L)
|
||||||
#define SC_is_pre_executable(a) (a->miscinfo & 1L != 0)
|
#define SC_is_pre_executable(a) ((a->miscinfo & 1L) != 0)
|
||||||
#define SC_set_fetchcursor(a) (a->miscinfo |= 2L)
|
#define SC_set_fetchcursor(a) (a->miscinfo |= 2L)
|
||||||
#define SC_no_fetchcursor(a) (a->miscinfo &= ~2L)
|
#define SC_no_fetchcursor(a) (a->miscinfo &= ~2L)
|
||||||
#define SC_is_fetchcursor(a) (a->miscinfo & 2L != 0)
|
#define SC_is_fetchcursor(a) ((a->miscinfo & 2L) != 0)
|
||||||
|
|
||||||
/* Statement prototypes */
|
/* Statement prototypes */
|
||||||
StatementClass *SC_Constructor(void);
|
StatementClass *SC_Constructor(void);
|
||||||
|
@ -139,8 +139,8 @@ BSC32_FLAGS=/nologo /o"$(OUTDIR)\psqlodbc.bsc"
|
|||||||
BSC32_SBRS= \
|
BSC32_SBRS= \
|
||||||
|
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
LINK32_FLAGS=kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /incremental:no /pdb:"$(OUTDIR)\psqlodbc.pdb" /machine:I386 /def:"psqlodbc.def" /out:"$(OUTDIR)\psqlodbc.dll" /implib:"$(OUTDIR)\psqlodbc.lib"
|
LINK32_FLAGS=kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /incremental:no /pdb:"$(OUTDIR)\psqlodbc.pdb" /machine:I386 /def:"psqlodbc_win32.def" /out:"$(OUTDIR)\psqlodbc.dll" /implib:"$(OUTDIR)\psqlodbc.lib"
|
||||||
DEF_FILE= "psqlodbc.def"
|
DEF_FILE= "psqlodbc_win32.def"
|
||||||
LINK32_OBJS= \
|
LINK32_OBJS= \
|
||||||
"$(INTDIR)\bind.obj" \
|
"$(INTDIR)\bind.obj" \
|
||||||
"$(INTDIR)\columninfo.obj" \
|
"$(INTDIR)\columninfo.obj" \
|
||||||
@ -277,8 +277,8 @@ BSC32_FLAGS=/nologo /o"$(OUTDIR)\psqlodbc.bsc"
|
|||||||
BSC32_SBRS= \
|
BSC32_SBRS= \
|
||||||
|
|
||||||
LINK32=link.exe
|
LINK32=link.exe
|
||||||
LINK32_FLAGS=kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /incremental:yes /pdb:"$(OUTDIR)\psqlodbc.pdb" /debug /machine:I386 /def:"psqlodbc.def" /out:"$(OUTDIR)\psqlodbc.dll" /implib:"$(OUTDIR)\psqlodbc.lib" /pdbtype:sept
|
LINK32_FLAGS=kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib wsock32.lib /nologo /dll /incremental:yes /pdb:"$(OUTDIR)\psqlodbc.pdb" /debug /machine:I386 /def:"psqlodbc_win32.def" /out:"$(OUTDIR)\psqlodbc.dll" /implib:"$(OUTDIR)\psqlodbc.lib" /pdbtype:sept
|
||||||
DEF_FILE= "psqlodbc.def"
|
DEF_FILE= "psqlodbc_win32.def"
|
||||||
LINK32_OBJS= \
|
LINK32_OBJS= \
|
||||||
"$(INTDIR)\bind.obj" \
|
"$(INTDIR)\bind.obj" \
|
||||||
"$(INTDIR)\columninfo.obj" \
|
"$(INTDIR)\columninfo.obj" \
|
||||||
|
Loading…
x
Reference in New Issue
Block a user