4 * Copyright 1999 Xiang Li, Corel Corporation
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 * Proxy ODBC driver manager. This manager delegates all ODBC
22 * calls to a real ODBC driver manager named by the environment
23 * variable LIB_ODBC_DRIVER_MANAGER, or to libodbc.so if the
24 * variable is not set.
29 #include "wine/port.h"
40 #include "wine/debug.h"
41 #include "wine/library.h"
42 #include "wine/unicode.h"
48 #include "proxyodbc.h"
50 static BOOL
ODBC_LoadDriverManager(void);
51 static BOOL
ODBC_LoadDMFunctions(void);
53 WINE_DEFAULT_DEBUG_CHANNEL(odbc
);
55 static const DM_FUNC template_func
[] =
57 /* 00 */ { SQL_API_SQLALLOCCONNECT
, "SQLAllocConnect", SQLAllocConnect
, NULL
, NULL
},
58 /* 01 */ { SQL_API_SQLALLOCENV
, "SQLAllocEnv", SQLAllocEnv
, NULL
, NULL
},
59 /* 02 */ { SQL_API_SQLALLOCHANDLE
, "SQLAllocHandle", SQLAllocHandle
, NULL
, NULL
},
60 /* 03 */ { SQL_API_SQLALLOCSTMT
, "SQLAllocStmt", SQLAllocStmt
, NULL
, NULL
},
61 /* 04 */ { SQL_API_SQLALLOCHANDLESTD
, "SQLAllocHandleStd", SQLAllocHandleStd
, NULL
, NULL
},
62 /* 05 */ { SQL_API_SQLBINDCOL
, "SQLBindCol", SQLBindCol
, NULL
, NULL
},
63 /* 06 */ { SQL_API_SQLBINDPARAM
, "SQLBindParam", SQLBindParam
, NULL
, NULL
},
64 /* 07 */ { SQL_API_SQLBINDPARAMETER
, "SQLBindParameter", SQLBindParameter
, NULL
, NULL
},
65 /* 08 */ { SQL_API_SQLBROWSECONNECT
, "SQLBrowseConnect", SQLBrowseConnect
, NULL
, NULL
},
66 /* 09 */ { SQL_API_SQLBULKOPERATIONS
, "SQLBulkOperations", SQLBulkOperations
, NULL
, NULL
},
67 /* 10 */ { SQL_API_SQLCANCEL
, "SQLCancel", SQLCancel
, NULL
, NULL
},
68 /* 11 */ { SQL_API_SQLCLOSECURSOR
, "SQLCloseCursor", SQLCloseCursor
, NULL
, NULL
},
69 /* 12 */ { SQL_API_SQLCOLATTRIBUTE
, "SQLColAttribute", SQLColAttribute
, NULL
, NULL
},
70 /* 13 */ { SQL_API_SQLCOLATTRIBUTES
, "SQLColAttributes", SQLColAttributes
, NULL
, NULL
},
71 /* 14 */ { SQL_API_SQLCOLUMNPRIVILEGES
, "SQLColumnPrivileges", SQLColumnPrivileges
, NULL
, NULL
},
72 /* 15 */ { SQL_API_SQLCOLUMNS
, "SQLColumns", SQLColumns
, NULL
, NULL
},
73 /* 16 */ { SQL_API_SQLCONNECT
, "SQLConnect", SQLConnect
, NULL
, NULL
},
74 /* 17 */ { SQL_API_SQLCOPYDESC
, "SQLCopyDesc", SQLCopyDesc
, NULL
, NULL
},
75 /* 18 */ { SQL_API_SQLDATASOURCES
, "SQLDataSources", SQLDataSources
, NULL
, NULL
},
76 /* 19 */ { SQL_API_SQLDESCRIBECOL
, "SQLDescribeCol", SQLDescribeCol
, NULL
, NULL
},
77 /* 20 */ { SQL_API_SQLDESCRIBEPARAM
, "SQLDescribeParam", SQLDescribeParam
, NULL
, NULL
},
78 /* 21 */ { SQL_API_SQLDISCONNECT
, "SQLDisconnect", SQLDisconnect
, NULL
, NULL
},
79 /* 22 */ { SQL_API_SQLDRIVERCONNECT
, "SQLDriverConnect", SQLDriverConnect
, NULL
, NULL
},
80 /* 23 */ { SQL_API_SQLDRIVERS
, "SQLDrivers", SQLDrivers
, NULL
, NULL
},
81 /* 24 */ { SQL_API_SQLENDTRAN
, "SQLEndTran", SQLEndTran
, NULL
, NULL
},
82 /* 25 */ { SQL_API_SQLERROR
, "SQLError", SQLError
, NULL
, NULL
},
83 /* 26 */ { SQL_API_SQLEXECDIRECT
, "SQLExecDirect", SQLExecDirect
, NULL
, NULL
},
84 /* 27 */ { SQL_API_SQLEXECUTE
, "SQLExecute", SQLExecute
, NULL
, NULL
},
85 /* 28 */ { SQL_API_SQLEXTENDEDFETCH
, "SQLExtendedFetch", SQLExtendedFetch
, NULL
, NULL
},
86 /* 29 */ { SQL_API_SQLFETCH
, "SQLFetch", SQLFetch
, NULL
, NULL
},
87 /* 30 */ { SQL_API_SQLFETCHSCROLL
, "SQLFetchScroll", SQLFetchScroll
, NULL
, NULL
},
88 /* 31 */ { SQL_API_SQLFOREIGNKEYS
, "SQLForeignKeys", SQLForeignKeys
, NULL
, NULL
},
89 /* 32 */ { SQL_API_SQLFREEENV
, "SQLFreeEnv", SQLFreeEnv
, NULL
, NULL
},
90 /* 33 */ { SQL_API_SQLFREEHANDLE
, "SQLFreeHandle", SQLFreeHandle
, NULL
, NULL
},
91 /* 34 */ { SQL_API_SQLFREESTMT
, "SQLFreeStmt", SQLFreeStmt
, NULL
, NULL
},
92 /* 35 */ { SQL_API_SQLFREECONNECT
, "SQLFreeConnect", SQLFreeConnect
, NULL
, NULL
},
93 /* 36 */ { SQL_API_SQLGETCONNECTATTR
, "SQLGetConnectAttr", SQLGetConnectAttr
, NULL
, NULL
},
94 /* 37 */ { SQL_API_SQLGETCONNECTOPTION
, "SQLGetConnectOption", SQLGetConnectOption
, NULL
, NULL
},
95 /* 38 */ { SQL_API_SQLGETCURSORNAME
, "SQLGetCursorName", SQLGetCursorName
, NULL
, NULL
},
96 /* 39 */ { SQL_API_SQLGETDATA
, "SQLGetData", SQLGetData
, NULL
, NULL
},
97 /* 40 */ { SQL_API_SQLGETDESCFIELD
, "SQLGetDescField", SQLGetDescField
, NULL
, NULL
},
98 /* 41 */ { SQL_API_SQLGETDESCREC
, "SQLGetDescRec", SQLGetDescRec
, NULL
, NULL
},
99 /* 42 */ { SQL_API_SQLGETDIAGFIELD
, "SQLGetDiagField", SQLGetDiagField
, NULL
, NULL
},
100 /* 43 */ { SQL_API_SQLGETENVATTR
, "SQLGetEnvAttr", SQLGetEnvAttr
, NULL
, NULL
},
101 /* 44 */ { SQL_API_SQLGETFUNCTIONS
, "SQLGetFunctions", SQLGetFunctions
, NULL
, NULL
},
102 /* 45 */ { SQL_API_SQLGETINFO
, "SQLGetInfo", SQLGetInfo
, NULL
, NULL
},
103 /* 46 */ { SQL_API_SQLGETSTMTATTR
, "SQLGetStmtAttr", SQLGetStmtAttr
, NULL
, NULL
},
104 /* 47 */ { SQL_API_SQLGETSTMTOPTION
, "SQLGetStmtOption", SQLGetStmtOption
, NULL
, NULL
},
105 /* 48 */ { SQL_API_SQLGETTYPEINFO
, "SQLGetTypeInfo", SQLGetTypeInfo
, NULL
, NULL
},
106 /* 49 */ { SQL_API_SQLMORERESULTS
, "SQLMoreResults", SQLMoreResults
, NULL
, NULL
},
107 /* 50 */ { SQL_API_SQLNATIVESQL
, "SQLNativeSql", SQLNativeSql
, NULL
, NULL
},
108 /* 51 */ { SQL_API_SQLNUMPARAMS
, "SQLNumParams", SQLNumParams
, NULL
, NULL
},
109 /* 52 */ { SQL_API_SQLNUMRESULTCOLS
, "SQLNumResultCols", SQLNumResultCols
, NULL
, NULL
},
110 /* 53 */ { SQL_API_SQLPARAMDATA
, "SQLParamData", SQLParamData
, NULL
, NULL
},
111 /* 54 */ { SQL_API_SQLPARAMOPTIONS
, "SQLParamOptions", SQLParamOptions
, NULL
, NULL
},
112 /* 55 */ { SQL_API_SQLPREPARE
, "SQLPrepare", SQLPrepare
, NULL
, NULL
},
113 /* 56 */ { SQL_API_SQLPRIMARYKEYS
, "SQLPrimaryKeys", SQLPrimaryKeys
, NULL
, NULL
},
114 /* 57 */ { SQL_API_SQLPROCEDURECOLUMNS
, "SQLProcedureColumns", SQLProcedureColumns
, NULL
, NULL
},
115 /* 58 */ { SQL_API_SQLPROCEDURES
, "SQLProcedures", SQLProcedures
, NULL
, NULL
},
116 /* 59 */ { SQL_API_SQLPUTDATA
, "SQLPutData", SQLPutData
, NULL
, NULL
},
117 /* 60 */ { SQL_API_SQLROWCOUNT
, "SQLRowCount", SQLRowCount
, NULL
, NULL
},
118 /* 61 */ { SQL_API_SQLSETCONNECTATTR
, "SQLSetConnectAttr", SQLSetConnectAttr
, NULL
, NULL
},
119 /* 62 */ { SQL_API_SQLSETCONNECTOPTION
, "SQLSetConnectOption", SQLSetConnectOption
, NULL
, NULL
},
120 /* 63 */ { SQL_API_SQLSETCURSORNAME
, "SQLSetCursorName", SQLSetCursorName
, NULL
, NULL
},
121 /* 64 */ { SQL_API_SQLSETDESCFIELD
, "SQLSetDescField", SQLSetDescField
, NULL
, NULL
},
122 /* 65 */ { SQL_API_SQLSETDESCREC
, "SQLSetDescRec", SQLSetDescRec
, NULL
, NULL
},
123 /* 66 */ { SQL_API_SQLSETENVATTR
, "SQLSetEnvAttr", SQLSetEnvAttr
, NULL
, NULL
},
124 /* 67 */ { SQL_API_SQLSETPARAM
, "SQLSetParam", SQLSetParam
, NULL
, NULL
},
125 /* 68 */ { SQL_API_SQLSETPOS
, "SQLSetPos", SQLSetPos
, NULL
, NULL
},
126 /* 69 */ { SQL_API_SQLSETSCROLLOPTIONS
, "SQLSetScrollOptions", SQLSetScrollOptions
, NULL
, NULL
},
127 /* 70 */ { SQL_API_SQLSETSTMTATTR
, "SQLSetStmtAttr", SQLSetStmtAttr
, NULL
, NULL
},
128 /* 71 */ { SQL_API_SQLSETSTMTOPTION
, "SQLSetStmtOption", SQLSetStmtOption
, NULL
, NULL
},
129 /* 72 */ { SQL_API_SQLSPECIALCOLUMNS
, "SQLSpecialColumns", SQLSpecialColumns
, NULL
, NULL
},
130 /* 73 */ { SQL_API_SQLSTATISTICS
, "SQLStatistics", SQLStatistics
, NULL
, NULL
},
131 /* 74 */ { SQL_API_SQLTABLEPRIVILEGES
, "SQLTablePrivileges", SQLTablePrivileges
, NULL
, NULL
},
132 /* 75 */ { SQL_API_SQLTABLES
, "SQLTables", SQLTables
, NULL
, NULL
},
133 /* 76 */ { SQL_API_SQLTRANSACT
, "SQLTransact", SQLTransact
, NULL
, NULL
},
134 /* 77 */ { SQL_API_SQLGETDIAGREC
, "SQLGetDiagRec", SQLGetDiagRec
, NULL
, NULL
},
137 static PROXYHANDLE gProxyHandle
;
139 /* What is the difference between these two (dmHandle cf READY_AND_dmHandle)? When does one use one and when the other? */
141 #define CHECK_dmHandle() \
143 if (gProxyHandle.dmHandle == NULL) \
145 TRACE ("Not ready\n"); \
150 #define CHECK_READY_AND_dmHandle() \
152 if (!gProxyHandle.bFunctionReady || gProxyHandle.dmHandle == NULL) \
154 TRACE ("Not ready\n"); \
159 static SQLRETURN
SQLDummyFunc(void)
161 TRACE("SQLDummyFunc:\n");
165 /***********************************************************************
166 * ODBC_ReplicateODBCInstToRegistry
172 * Utility to ODBC_ReplicateToRegistry to replicate the drivers of the
173 * ODBCINST.INI settings
175 * The driver settings are not replicated to the registry. If we were to
176 * replicate them we would need to decide whether to replicate all settings
177 * or to do some translation; whether to remove any entries present only in
178 * the windows registry, etc.
181 static void ODBC_ReplicateODBCInstToRegistry (SQLHENV hEnv
)
188 TRACE ("Driver settings are not currently replicated to the registry\n");
189 if ((reg_ret
= RegCreateKeyExA (HKEY_LOCAL_MACHINE
,
190 "Software\\ODBC\\ODBCINST.INI", 0, NULL
,
191 REG_OPTION_NON_VOLATILE
,
192 KEY_ALL_ACCESS
/* a couple more than we need */, NULL
,
193 &hODBCInst
, NULL
)) == ERROR_SUCCESS
)
196 if ((reg_ret
= RegCreateKeyExA (hODBCInst
, "ODBC Drivers", 0,
197 NULL
, REG_OPTION_NON_VOLATILE
,
198 KEY_ALL_ACCESS
/* overkill */, NULL
, &hDrivers
, NULL
))
204 SQLSMALLINT sizedesc
;
207 dirn
= SQL_FETCH_FIRST
;
208 while ((sql_ret
= SQLDrivers (hEnv
, dirn
, (SQLCHAR
*)desc
, sizeof(desc
),
209 &sizedesc
, NULL
, 0, NULL
)) == SQL_SUCCESS
||
210 sql_ret
== SQL_SUCCESS_WITH_INFO
)
212 /* FIXME Do some proper handling of the SUCCESS_WITH_INFO */
213 dirn
= SQL_FETCH_NEXT
;
214 if (sizedesc
== lstrlenA(desc
))
217 if ((reg_ret
= RegQueryValueExA (hDrivers
, desc
, NULL
,
218 NULL
, NULL
, NULL
)) == ERROR_FILE_NOT_FOUND
)
220 if ((reg_ret
= RegSetValueExA (hDrivers
, desc
, 0,
221 REG_SZ
, (const BYTE
*)"Installed", 10)) != ERROR_SUCCESS
)
223 TRACE ("Error %d replicating driver %s\n",
228 else if (reg_ret
!= ERROR_SUCCESS
)
230 TRACE ("Error %d checking for %s in drivers\n",
234 if ((reg_ret
= RegCreateKeyExA (hODBCInst
, desc
, 0,
235 NULL
, REG_OPTION_NON_VOLATILE
,
236 KEY_ALL_ACCESS
, NULL
, &hThis
, NULL
))
239 /* FIXME This is where the settings go.
240 * I suggest that if the disposition says it
241 * exists then we leave it alone. Alternatively
242 * include an extra value to flag that it is
243 * a replication of the unixODBC/iODBC/...
245 if ((reg_ret
= RegCloseKey (hThis
)) !=
247 TRACE ("Error %d closing %s key\n", reg_ret
,
252 TRACE ("Error %d ensuring driver key %s\n",
259 WARN ("Unusually long driver name %s not replicated\n",
264 if (sql_ret
!= SQL_NO_DATA
)
266 TRACE ("Error %d enumerating drivers\n", (int)sql_ret
);
269 if ((reg_ret
= RegCloseKey (hDrivers
)) != ERROR_SUCCESS
)
271 TRACE ("Error %d closing hDrivers\n", reg_ret
);
276 TRACE ("Error %d opening HKLM\\S\\O\\OI\\Drivers\n", reg_ret
);
278 if ((reg_ret
= RegCloseKey (hODBCInst
)) != ERROR_SUCCESS
)
280 TRACE ("Error %d closing HKLM\\S\\O\\ODBCINST.INI\n", reg_ret
);
285 TRACE ("Error %d opening HKLM\\S\\O\\ODBCINST.INI\n", reg_ret
);
289 WARN ("May not have replicated all ODBC drivers to the registry\n");
293 /***********************************************************************
294 * ODBC_ReplicateODBCToRegistry
300 * Utility to ODBC_ReplicateToRegistry to replicate either the USER or
303 * For now simply place the "Driver description" (as returned by SQLDataSources)
304 * into the registry as the driver. This is enough to satisfy Crystal's
305 * requirement that there be a driver entry. (It doesn't seem to care what
307 * A slightly more accurate setting would be to access the registry to find
308 * the actual driver library for the given description (which appears to map
309 * to one of the HKLM/Software/ODBC/ODBCINST.INI keys). (If you do this note
310 * that this will add a requirement that this function be called after
311 * ODBC_ReplicateODBCInstToRegistry)
313 static void ODBC_ReplicateODBCToRegistry (int is_user
, SQLHENV hEnv
)
319 CHAR dsn
[SQL_MAX_DSN_LENGTH
+ 1];
322 SQLSMALLINT sizedesc
;
324 const char *which
= is_user
? "user" : "system";
327 if ((reg_ret
= RegCreateKeyExA (
328 is_user
? HKEY_CURRENT_USER
: HKEY_LOCAL_MACHINE
,
329 "Software\\ODBC\\ODBC.INI", 0, NULL
, REG_OPTION_NON_VOLATILE
,
330 KEY_ALL_ACCESS
/* a couple more than we need */, NULL
, &hODBC
,
331 NULL
)) == ERROR_SUCCESS
)
334 dirn
= is_user
? SQL_FETCH_FIRST_USER
: SQL_FETCH_FIRST_SYSTEM
;
335 while ((sql_ret
= SQLDataSources (hEnv
, dirn
,
336 (SQLCHAR
*)dsn
, sizeof(dsn
), &sizedsn
,
337 (SQLCHAR
*)desc
, sizeof(desc
), &sizedesc
)) == SQL_SUCCESS
338 || sql_ret
== SQL_SUCCESS_WITH_INFO
)
340 /* FIXME Do some proper handling of the SUCCESS_WITH_INFO */
341 dirn
= SQL_FETCH_NEXT
;
342 if (sizedsn
== lstrlenA(dsn
) && sizedesc
== lstrlenA(desc
))
345 if ((reg_ret
= RegCreateKeyExA (hODBC
, dsn
, 0,
346 NULL
, REG_OPTION_NON_VOLATILE
,
347 KEY_ALL_ACCESS
, NULL
, &hDSN
, NULL
))
350 static const char DRIVERKEY
[] = "Driver";
351 if ((reg_ret
= RegQueryValueExA (hDSN
, DRIVERKEY
,
352 NULL
, NULL
, NULL
, NULL
))
353 == ERROR_FILE_NOT_FOUND
)
355 if ((reg_ret
= RegSetValueExA (hDSN
, DRIVERKEY
, 0,
356 REG_SZ
, (LPBYTE
)desc
, sizedesc
)) != ERROR_SUCCESS
)
358 TRACE ("Error %d replicating description of "
359 "%s(%s)\n", reg_ret
, dsn
, desc
);
363 else if (reg_ret
!= ERROR_SUCCESS
)
365 TRACE ("Error %d checking for description of %s\n",
369 if ((reg_ret
= RegCloseKey (hDSN
)) != ERROR_SUCCESS
)
371 TRACE ("Error %d closing %s DSN key %s\n",
372 reg_ret
, which
, dsn
);
377 TRACE ("Error %d opening %s DSN key %s\n",
378 reg_ret
, which
, dsn
);
384 WARN ("Unusually long %s data source name %s (%s) not "
385 "replicated\n", which
, dsn
, desc
);
389 if (sql_ret
!= SQL_NO_DATA
)
391 TRACE ("Error %d enumerating %s datasources\n",
392 (int)sql_ret
, which
);
395 if ((reg_ret
= RegCloseKey (hODBC
)) != ERROR_SUCCESS
)
397 TRACE ("Error %d closing %s ODBC.INI registry key\n", reg_ret
,
403 TRACE ("Error %d creating/opening %s ODBC.INI registry key\n",
408 WARN ("May not have replicated all %s ODBC DSNs to the registry\n",
413 /***********************************************************************
414 * ODBC_ReplicateToRegistry
420 * Unfortunately some of the functions that Windows documents as being part
421 * of the ODBC API it implements directly during compilation or something
422 * in terms of registry access functions.
423 * e.g. SQLGetInstalledDrivers queries the list at
424 * HKEY_LOCAL_MACHINE\Software\ODBC\ODBCINST.INI\ODBC Drivers
426 * This function is called when the driver manager is loaded and is used
427 * to replicate the appropriate details into the Wine registry
430 static void ODBC_ReplicateToRegistry (void)
435 if ((sql_ret
= SQLAllocEnv (&hEnv
)) == SQL_SUCCESS
)
437 ODBC_ReplicateODBCInstToRegistry (hEnv
);
438 ODBC_ReplicateODBCToRegistry (0 /* system dsns */, hEnv
);
439 ODBC_ReplicateODBCToRegistry (1 /* user dsns */, hEnv
);
441 if ((sql_ret
= SQLFreeEnv (hEnv
)) != SQL_SUCCESS
)
443 TRACE ("Error %d freeing the SQL environment.\n", (int)sql_ret
);
448 TRACE ("Error %d opening an SQL environment.\n", (int)sql_ret
);
449 WARN ("The external ODBC settings have not been replicated to the"
454 /***********************************************************************
455 * DllMain [Internal] Initializes the internal 'ODBC32.DLL'.
458 * hinstDLL [I] handle to the DLL's instance
460 * lpvReserved [I] reserved, must be NULL
467 BOOL WINAPI
DllMain(HINSTANCE hinstDLL
, DWORD fdwReason
, LPVOID lpvReserved
)
470 TRACE("Initializing or Finalizing proxy ODBC: %p,%x,%p\n", hinstDLL
, fdwReason
, lpvReserved
);
472 if (fdwReason
== DLL_PROCESS_ATTACH
)
474 TRACE("Loading ODBC...\n");
475 DisableThreadLibraryCalls(hinstDLL
);
476 if (ODBC_LoadDriverManager())
478 ODBC_LoadDMFunctions();
479 ODBC_ReplicateToRegistry();
482 else if (fdwReason
== DLL_PROCESS_DETACH
)
484 TRACE("Unloading ODBC...\n");
485 if (gProxyHandle
.bFunctionReady
)
487 for ( i
= 0; i
< NUM_SQLFUNC
; i
++ )
489 gProxyHandle
.functions
[i
].func
= SQLDummyFunc
;
493 if (gProxyHandle
.dmHandle
)
495 wine_dlclose(gProxyHandle
.dmHandle
,NULL
,0);
496 gProxyHandle
.dmHandle
= NULL
;
503 /***********************************************************************
504 * ODBC_LoadDriverManager [Internal] Load ODBC library.
513 static BOOL
ODBC_LoadDriverManager(void)
515 const char *s
= getenv("LIB_ODBC_DRIVER_MANAGER");
520 gProxyHandle
.bFunctionReady
= FALSE
;
522 #ifdef SONAME_LIBODBC
523 if (!s
|| !s
[0]) s
= SONAME_LIBODBC
;
525 if (!s
|| !s
[0]) goto failed
;
527 gProxyHandle
.dmHandle
= wine_dlopen(s
, RTLD_LAZY
| RTLD_GLOBAL
, error
, sizeof(error
));
529 if (gProxyHandle
.dmHandle
!= NULL
)
531 gProxyHandle
.nErrorType
= ERROR_FREE
;
535 WARN("failed to open library %s: %s\n", debugstr_a(s
), error
);
536 gProxyHandle
.nErrorType
= ERROR_LIBRARY_NOT_FOUND
;
541 /***********************************************************************
542 * ODBC_LoadDMFunctions [Internal] Populate function table.
551 static BOOL
ODBC_LoadDMFunctions(void)
556 if (gProxyHandle
.dmHandle
== NULL
)
559 for ( i
= 0; i
< NUM_SQLFUNC
; i
++ )
563 gProxyHandle
.functions
[i
] = template_func
[i
];
564 gProxyHandle
.functions
[i
].func
= wine_dlsym(gProxyHandle
.dmHandle
,
565 gProxyHandle
.functions
[i
].name
, error
, sizeof(error
));
569 ERR("Failed to load function %s\n",gProxyHandle
.functions
[i
].name
);
570 gProxyHandle
.functions
[i
].func
= SQLDummyFunc
;
574 /* Build Unicode function name for this function */
575 pFuncNameW
= HeapAlloc(GetProcessHeap(), 0, strlen(gProxyHandle
.functions
[i
].name
) + 2);
576 strcpy(pFuncNameW
, gProxyHandle
.functions
[i
].name
);
577 pFuncNameW
[strlen(gProxyHandle
.functions
[i
].name
) + 1] = '\0';
578 pFuncNameW
[strlen(gProxyHandle
.functions
[i
].name
)] = 'W';
580 gProxyHandle
.functions
[i
].funcW
= wine_dlsym(gProxyHandle
.dmHandle
,
581 pFuncNameW
, error
, sizeof(error
));
584 /* TRACE("Failed to load function %s, possibly no Unicode version is required\n", pFuncNameW); */
585 gProxyHandle
.functions
[i
].funcW
= NULL
;
587 HeapFree(GetProcessHeap(), 0, pFuncNameW
);
591 gProxyHandle
.bFunctionReady
= TRUE
;
597 /*************************************************************************
598 * SQLAllocConnect [ODBC32.001]
600 SQLRETURN WINAPI
SQLAllocConnect(SQLHENV EnvironmentHandle
, SQLHDBC
*ConnectionHandle
)
603 TRACE("Env=%lx\n",EnvironmentHandle
);
605 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
607 *ConnectionHandle
= SQL_NULL_HDBC
;
608 TRACE("Not ready\n");
612 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCCONNECT
].func
);
613 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCCONNECT
].func
)
614 (EnvironmentHandle
, ConnectionHandle
);
615 TRACE("Returns ret=%d, Handle %lx\n",ret
, *ConnectionHandle
);
620 /*************************************************************************
621 * SQLAllocEnv [ODBC32.002]
623 SQLRETURN WINAPI
SQLAllocEnv(SQLHENV
*EnvironmentHandle
)
628 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
630 *EnvironmentHandle
= SQL_NULL_HENV
;
631 TRACE("Not ready\n");
635 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCENV
].func
);
636 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCENV
].func
) (EnvironmentHandle
);
637 TRACE("Returns ret=%d, Env=%lx\n",ret
, *EnvironmentHandle
);
642 /*************************************************************************
643 * SQLAllocHandle [ODBC32.024]
645 SQLRETURN WINAPI
SQLAllocHandle(SQLSMALLINT HandleType
, SQLHANDLE InputHandle
, SQLHANDLE
*OutputHandle
)
648 TRACE("(Type=%d, Handle=%lx)\n",HandleType
,InputHandle
);
650 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
652 if (gProxyHandle
.nErrorType
== ERROR_LIBRARY_NOT_FOUND
)
653 WARN("ProxyODBC: Cannot load ODBC driver manager library.\n");
655 if (HandleType
== SQL_HANDLE_ENV
)
656 *OutputHandle
= SQL_NULL_HENV
;
657 else if (HandleType
== SQL_HANDLE_DBC
)
658 *OutputHandle
= SQL_NULL_HDBC
;
659 else if (HandleType
== SQL_HANDLE_STMT
)
660 *OutputHandle
= SQL_NULL_HSTMT
;
661 else if (HandleType
== SQL_HANDLE_DESC
)
662 *OutputHandle
= SQL_NULL_HDESC
;
664 TRACE ("Not ready\n");
668 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCHANDLE
].func
);
669 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCHANDLE
].func
)
670 (HandleType
, InputHandle
, OutputHandle
);
671 TRACE("Returns ret=%d, Handle=%lx\n",ret
, *OutputHandle
);
676 /*************************************************************************
677 * SQLAllocStmt [ODBC32.003]
679 SQLRETURN WINAPI
SQLAllocStmt(SQLHDBC ConnectionHandle
, SQLHSTMT
*StatementHandle
)
683 TRACE("(Connection=%lx)\n",ConnectionHandle
);
685 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
687 *StatementHandle
= SQL_NULL_HSTMT
;
688 TRACE ("Not ready\n");
692 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCSTMT
].func
);
693 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCSTMT
].func
)
694 (ConnectionHandle
, StatementHandle
);
695 TRACE ("Returns ret=%d, Handle=%lx\n", ret
, *StatementHandle
);
700 /*************************************************************************
701 * SQLAllocHandleStd [ODBC32.077]
703 SQLRETURN WINAPI
SQLAllocHandleStd( SQLSMALLINT HandleType
,
704 SQLHANDLE InputHandle
, SQLHANDLE
*OutputHandle
)
706 TRACE("ProxyODBC: SQLAllocHandleStd.\n");
708 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
710 if (gProxyHandle
.nErrorType
== ERROR_LIBRARY_NOT_FOUND
)
711 WARN("ProxyODBC: Cannot load ODBC driver manager library.\n");
713 if (HandleType
== SQL_HANDLE_ENV
)
714 *OutputHandle
= SQL_NULL_HENV
;
715 else if (HandleType
== SQL_HANDLE_DBC
)
716 *OutputHandle
= SQL_NULL_HDBC
;
717 else if (HandleType
== SQL_HANDLE_STMT
)
718 *OutputHandle
= SQL_NULL_HSTMT
;
719 else if (HandleType
== SQL_HANDLE_DESC
)
720 *OutputHandle
= SQL_NULL_HDESC
;
725 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCHANDLESTD
].func
);
726 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLALLOCHANDLESTD
].func
)
727 (HandleType
, InputHandle
, OutputHandle
);
731 /*************************************************************************
732 * SQLBindCol [ODBC32.004]
734 SQLRETURN WINAPI
SQLBindCol(SQLHSTMT StatementHandle
,
735 SQLUSMALLINT ColumnNumber
, SQLSMALLINT TargetType
,
736 SQLPOINTER TargetValue
, SQLINTEGER BufferLength
,
737 SQLINTEGER
*StrLen_or_Ind
)
741 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
743 TRACE ("Not ready\n");
747 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDCOL
].func
);
748 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDCOL
].func
)
749 (StatementHandle
, ColumnNumber
, TargetType
,
750 TargetValue
, BufferLength
, StrLen_or_Ind
);
754 /*************************************************************************
755 * SQLBindParam [ODBC32.025]
757 SQLRETURN WINAPI
SQLBindParam(SQLHSTMT StatementHandle
,
758 SQLUSMALLINT ParameterNumber
, SQLSMALLINT ValueType
,
759 SQLSMALLINT ParameterType
, SQLUINTEGER LengthPrecision
,
760 SQLSMALLINT ParameterScale
, SQLPOINTER ParameterValue
,
761 SQLINTEGER
*StrLen_or_Ind
)
765 CHECK_READY_AND_dmHandle();
767 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDPARAM
].func
);
768 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDPARAM
].func
)
769 (StatementHandle
, ParameterNumber
, ValueType
,
770 ParameterScale
, ParameterValue
, StrLen_or_Ind
);
774 /*************************************************************************
775 * SQLCancel [ODBC32.005]
777 SQLRETURN WINAPI
SQLCancel(SQLHSTMT StatementHandle
)
781 CHECK_READY_AND_dmHandle();
783 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCANCEL
].func
);
784 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCANCEL
].func
) (StatementHandle
);
788 /*************************************************************************
789 * SQLCloseCursor [ODBC32.026]
791 SQLRETURN WINAPI
SQLCloseCursor(SQLHSTMT StatementHandle
)
794 TRACE("(Handle=%lx)\n",StatementHandle
);
796 CHECK_READY_AND_dmHandle();
798 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCLOSECURSOR
].func
);
799 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCLOSECURSOR
].func
) (StatementHandle
);
800 TRACE("returns %d\n",ret
);
805 /*************************************************************************
806 * SQLColAttribute [ODBC32.027]
808 SQLRETURN WINAPI
SQLColAttribute (SQLHSTMT StatementHandle
,
809 SQLUSMALLINT ColumnNumber
, SQLUSMALLINT FieldIdentifier
,
810 SQLPOINTER CharacterAttribute
, SQLSMALLINT BufferLength
,
811 SQLSMALLINT
*StringLength
, SQLPOINTER NumericAttribute
)
815 CHECK_READY_AND_dmHandle();
817 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTE
].func
);
818 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTE
].func
)
819 (StatementHandle
, ColumnNumber
, FieldIdentifier
,
820 CharacterAttribute
, BufferLength
, StringLength
, NumericAttribute
);
824 /*************************************************************************
825 * SQLColumns [ODBC32.040]
827 SQLRETURN WINAPI
SQLColumns(SQLHSTMT StatementHandle
,
828 SQLCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
829 SQLCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
830 SQLCHAR
*TableName
, SQLSMALLINT NameLength3
,
831 SQLCHAR
*ColumnName
, SQLSMALLINT NameLength4
)
835 CHECK_READY_AND_dmHandle();
837 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNS
].func
);
838 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNS
].func
)
839 (StatementHandle
, CatalogName
, NameLength1
,
840 SchemaName
, NameLength2
, TableName
, NameLength3
, ColumnName
, NameLength4
);
844 /*************************************************************************
845 * SQLConnect [ODBC32.007]
847 SQLRETURN WINAPI
SQLConnect(SQLHDBC ConnectionHandle
,
848 SQLCHAR
*ServerName
, SQLSMALLINT NameLength1
,
849 SQLCHAR
*UserName
, SQLSMALLINT NameLength2
,
850 SQLCHAR
*Authentication
, SQLSMALLINT NameLength3
)
853 TRACE("(Server=%.*s)\n",NameLength1
, ServerName
);
855 CHECK_READY_AND_dmHandle();
857 strcpy( (LPSTR
)gProxyHandle
.ServerName
, (LPSTR
)ServerName
);
858 strcpy( (LPSTR
)gProxyHandle
.UserName
, (LPSTR
)UserName
);
860 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCONNECT
].func
);
861 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCONNECT
].func
)
862 (ConnectionHandle
, ServerName
, NameLength1
,
863 UserName
, NameLength2
, Authentication
, NameLength3
);
865 TRACE("returns %d\n",ret
);
870 /*************************************************************************
871 * SQLCopyDesc [ODBC32.028]
873 SQLRETURN WINAPI
SQLCopyDesc(SQLHDESC SourceDescHandle
, SQLHDESC TargetDescHandle
)
877 CHECK_READY_AND_dmHandle();
879 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOPYDESC
].func
);
880 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOPYDESC
].func
)
881 (SourceDescHandle
, TargetDescHandle
);
885 /*************************************************************************
886 * SQLDataSources [ODBC32.057]
888 SQLRETURN WINAPI
SQLDataSources(SQLHENV EnvironmentHandle
,
889 SQLUSMALLINT Direction
, SQLCHAR
*ServerName
,
890 SQLSMALLINT BufferLength1
, SQLSMALLINT
*NameLength1
,
891 SQLCHAR
*Description
, SQLSMALLINT BufferLength2
,
892 SQLSMALLINT
*NameLength2
)
896 TRACE("EnvironmentHandle = %p\n", (LPVOID
)EnvironmentHandle
);
898 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
900 ERR("Error: empty dm handle (gProxyHandle.dmHandle == NULL)\n");
904 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLDATASOURCES
].func
);
905 ret
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDATASOURCES
].func
)
906 (EnvironmentHandle
, Direction
, ServerName
,
907 BufferLength1
, NameLength1
, Description
, BufferLength2
, NameLength2
);
911 TRACE("returns: %d \t", ret
);
912 if (*NameLength1
> 0)
913 TRACE("DataSource = %s,", ServerName
);
914 if (*NameLength2
> 0)
915 TRACE(" Description = %s", Description
);
923 /*************************************************************************
924 * SQLDescribeCol [ODBC32.008]
926 SQLRETURN WINAPI
SQLDescribeCol(SQLHSTMT StatementHandle
,
927 SQLUSMALLINT ColumnNumber
, SQLCHAR
*ColumnName
,
928 SQLSMALLINT BufferLength
, SQLSMALLINT
*NameLength
,
929 SQLSMALLINT
*DataType
, SQLUINTEGER
*ColumnSize
,
930 SQLSMALLINT
*DecimalDigits
, SQLSMALLINT
*Nullable
)
934 CHECK_READY_AND_dmHandle();
936 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBECOL
].func
);
937 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBECOL
].func
)
938 (StatementHandle
, ColumnNumber
, ColumnName
,
939 BufferLength
, NameLength
, DataType
, ColumnSize
, DecimalDigits
, Nullable
);
943 /*************************************************************************
944 * SQLDisconnect [ODBC32.009]
946 SQLRETURN WINAPI
SQLDisconnect(SQLHDBC ConnectionHandle
)
949 TRACE("(Handle=%lx)\n", ConnectionHandle
);
951 CHECK_READY_AND_dmHandle();
953 gProxyHandle
.ServerName
[0] = '\0';
954 gProxyHandle
.UserName
[0] = '\0';
956 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLDISCONNECT
].func
);
957 ret
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDISCONNECT
].func
) (ConnectionHandle
);
958 TRACE("returns %d\n",ret
);
963 /*************************************************************************
964 * SQLEndTran [ODBC32.029]
966 SQLRETURN WINAPI
SQLEndTran(SQLSMALLINT HandleType
, SQLHANDLE Handle
, SQLSMALLINT CompletionType
)
970 CHECK_READY_AND_dmHandle();
972 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLENDTRAN
].func
);
973 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLENDTRAN
].func
) (HandleType
, Handle
, CompletionType
);
977 /*************************************************************************
978 * SQLError [ODBC32.010]
980 SQLRETURN WINAPI
SQLError(SQLHENV EnvironmentHandle
,
981 SQLHDBC ConnectionHandle
, SQLHSTMT StatementHandle
,
982 SQLCHAR
*Sqlstate
, SQLINTEGER
*NativeError
,
983 SQLCHAR
*MessageText
, SQLSMALLINT BufferLength
,
984 SQLSMALLINT
*TextLength
)
988 CHECK_READY_AND_dmHandle();
990 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLERROR
].func
);
991 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLERROR
].func
)
992 (EnvironmentHandle
, ConnectionHandle
, StatementHandle
,
993 Sqlstate
, NativeError
, MessageText
, BufferLength
, TextLength
);
997 /*************************************************************************
998 * SQLExecDirect [ODBC32.011]
1000 SQLRETURN WINAPI
SQLExecDirect(SQLHSTMT StatementHandle
, SQLCHAR
*StatementText
, SQLINTEGER TextLength
)
1004 CHECK_READY_AND_dmHandle();
1006 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECDIRECT
].func
);
1007 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECDIRECT
].func
)
1008 (StatementHandle
, StatementText
, TextLength
);
1012 /*************************************************************************
1013 * SQLExecute [ODBC32.012]
1015 SQLRETURN WINAPI
SQLExecute(SQLHSTMT StatementHandle
)
1019 CHECK_READY_AND_dmHandle();
1021 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECUTE
].func
);
1022 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECUTE
].func
) (StatementHandle
);
1026 /*************************************************************************
1027 * SQLFetch [ODBC32.013]
1029 SQLRETURN WINAPI
SQLFetch(SQLHSTMT StatementHandle
)
1033 CHECK_READY_AND_dmHandle();
1035 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFETCH
].func
);
1036 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFETCH
].func
) (StatementHandle
);
1040 /*************************************************************************
1041 * SQLFetchScroll [ODBC32.030]
1043 SQLRETURN WINAPI
SQLFetchScroll(SQLHSTMT StatementHandle
, SQLSMALLINT FetchOrientation
, SQLINTEGER FetchOffset
)
1049 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFETCHSCROLL
].func
);
1050 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFETCHSCROLL
].func
)
1051 (StatementHandle
, FetchOrientation
, FetchOffset
);
1055 /*************************************************************************
1056 * SQLFreeConnect [ODBC32.014]
1058 SQLRETURN WINAPI
SQLFreeConnect(SQLHDBC ConnectionHandle
)
1061 TRACE("(Handle=%lx)\n",ConnectionHandle
);
1065 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREECONNECT
].func
);
1066 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREECONNECT
].func
) (ConnectionHandle
);
1067 TRACE("Returns %d\n",ret
);
1072 /*************************************************************************
1073 * SQLFreeEnv [ODBC32.015]
1075 SQLRETURN WINAPI
SQLFreeEnv(SQLHENV EnvironmentHandle
)
1078 TRACE("(Env=%lx)\n",EnvironmentHandle
);
1082 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREEENV
].func
);
1083 ret
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREEENV
].func
) (EnvironmentHandle
);
1084 TRACE("Returns %d\n",ret
);
1089 /*************************************************************************
1090 * SQLFreeHandle [ODBC32.031]
1092 SQLRETURN WINAPI
SQLFreeHandle(SQLSMALLINT HandleType
, SQLHANDLE Handle
)
1095 TRACE("(Type=%d, Handle=%lx)\n",HandleType
,Handle
);
1099 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREEHANDLE
].func
);
1100 ret
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREEHANDLE
].func
)
1101 (HandleType
, Handle
);
1102 TRACE ("Returns %d\n",ret
);
1107 /*************************************************************************
1108 * SQLFreeStmt [ODBC32.016]
1110 SQLRETURN WINAPI
SQLFreeStmt(SQLHSTMT StatementHandle
, SQLUSMALLINT Option
)
1113 TRACE("(Handle %lx, Option=%d)\n",StatementHandle
, Option
);
1117 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREESTMT
].func
);
1118 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLFREESTMT
].func
)
1119 (StatementHandle
, Option
);
1120 TRACE("Returns %d\n",ret
);
1125 /*************************************************************************
1126 * SQLGetConnectAttr [ODBC32.032]
1128 SQLRETURN WINAPI
SQLGetConnectAttr(SQLHDBC ConnectionHandle
,
1129 SQLINTEGER Attribute
, SQLPOINTER Value
,
1130 SQLINTEGER BufferLength
, SQLINTEGER
*StringLength
)
1136 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTATTR
].func
);
1137 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTATTR
].func
)
1138 (ConnectionHandle
, Attribute
, Value
,
1139 BufferLength
, StringLength
);
1143 /*************************************************************************
1144 * SQLGetConnectOption [ODBC32.042]
1146 SQLRETURN WINAPI
SQLGetConnectOption(SQLHDBC ConnectionHandle
, SQLUSMALLINT Option
, SQLPOINTER Value
)
1152 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTOPTION
].func
);
1153 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTOPTION
].func
)
1154 (ConnectionHandle
, Option
, Value
);
1158 /*************************************************************************
1159 * SQLGetCursorName [ODBC32.017]
1161 SQLRETURN WINAPI
SQLGetCursorName(SQLHSTMT StatementHandle
,
1162 SQLCHAR
*CursorName
, SQLSMALLINT BufferLength
,
1163 SQLSMALLINT
*NameLength
)
1169 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCURSORNAME
].func
);
1170 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCURSORNAME
].func
)
1171 (StatementHandle
, CursorName
, BufferLength
, NameLength
);
1175 /*************************************************************************
1176 * SQLGetData [ODBC32.043]
1178 SQLRETURN WINAPI
SQLGetData(SQLHSTMT StatementHandle
,
1179 SQLUSMALLINT ColumnNumber
, SQLSMALLINT TargetType
,
1180 SQLPOINTER TargetValue
, SQLINTEGER BufferLength
,
1181 SQLINTEGER
*StrLen_or_Ind
)
1187 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDATA
].func
);
1188 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDATA
].func
)
1189 (StatementHandle
, ColumnNumber
, TargetType
,
1190 TargetValue
, BufferLength
, StrLen_or_Ind
);
1194 /*************************************************************************
1195 * SQLGetDescField [ODBC32.033]
1197 SQLRETURN WINAPI
SQLGetDescField(SQLHDESC DescriptorHandle
,
1198 SQLSMALLINT RecNumber
, SQLSMALLINT FieldIdentifier
,
1199 SQLPOINTER Value
, SQLINTEGER BufferLength
,
1200 SQLINTEGER
*StringLength
)
1206 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCFIELD
].func
);
1207 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCFIELD
].func
)
1208 (DescriptorHandle
, RecNumber
, FieldIdentifier
,
1209 Value
, BufferLength
, StringLength
);
1213 /*************************************************************************
1214 * SQLGetDescRec [ODBC32.034]
1216 SQLRETURN WINAPI
SQLGetDescRec(SQLHDESC DescriptorHandle
,
1217 SQLSMALLINT RecNumber
, SQLCHAR
*Name
,
1218 SQLSMALLINT BufferLength
, SQLSMALLINT
*StringLength
,
1219 SQLSMALLINT
*Type
, SQLSMALLINT
*SubType
,
1220 SQLINTEGER
*Length
, SQLSMALLINT
*Precision
,
1221 SQLSMALLINT
*Scale
, SQLSMALLINT
*Nullable
)
1227 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCREC
].func
);
1228 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCREC
].func
)
1229 (DescriptorHandle
, RecNumber
, Name
, BufferLength
,
1230 StringLength
, Type
, SubType
, Length
, Precision
, Scale
, Nullable
);
1234 /*************************************************************************
1235 * SQLGetDiagField [ODBC32.035]
1237 SQLRETURN WINAPI
SQLGetDiagField(SQLSMALLINT HandleType
, SQLHANDLE Handle
,
1238 SQLSMALLINT RecNumber
, SQLSMALLINT DiagIdentifier
,
1239 SQLPOINTER DiagInfo
, SQLSMALLINT BufferLength
,
1240 SQLSMALLINT
*StringLength
)
1246 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGFIELD
].func
);
1247 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGFIELD
].func
)
1248 (HandleType
, Handle
, RecNumber
, DiagIdentifier
,
1249 DiagInfo
, BufferLength
, StringLength
);
1253 /*************************************************************************
1254 * SQLGetDiagRec [ODBC32.036]
1256 SQLRETURN WINAPI
SQLGetDiagRec(SQLSMALLINT HandleType
, SQLHANDLE Handle
,
1257 SQLSMALLINT RecNumber
, SQLCHAR
*Sqlstate
,
1258 SQLINTEGER
*NativeError
, SQLCHAR
*MessageText
,
1259 SQLSMALLINT BufferLength
, SQLSMALLINT
*TextLength
)
1265 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGREC
].func
);
1266 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGREC
].func
)
1267 (HandleType
, Handle
, RecNumber
, Sqlstate
, NativeError
,
1268 MessageText
, BufferLength
, TextLength
);
1272 /*************************************************************************
1273 * SQLGetEnvAttr [ODBC32.037]
1275 SQLRETURN WINAPI
SQLGetEnvAttr(SQLHENV EnvironmentHandle
,
1276 SQLINTEGER Attribute
, SQLPOINTER Value
,
1277 SQLINTEGER BufferLength
, SQLINTEGER
*StringLength
)
1283 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETENVATTR
].func
);
1284 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETENVATTR
].func
)
1285 (EnvironmentHandle
, Attribute
, Value
, BufferLength
, StringLength
);
1289 /*************************************************************************
1290 * SQLGetFunctions [ODBC32.044]
1292 SQLRETURN WINAPI
SQLGetFunctions(SQLHDBC ConnectionHandle
, SQLUSMALLINT FunctionId
, SQLUSMALLINT
*Supported
)
1298 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETFUNCTIONS
].func
);
1299 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETFUNCTIONS
].func
)
1300 (ConnectionHandle
, FunctionId
, Supported
);
1304 /*************************************************************************
1305 * SQLGetInfo [ODBC32.045]
1307 SQLRETURN WINAPI
SQLGetInfo(SQLHDBC ConnectionHandle
,
1308 SQLUSMALLINT InfoType
, SQLPOINTER InfoValue
,
1309 SQLSMALLINT BufferLength
, SQLSMALLINT
*StringLength
)
1315 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETINFO
].func
);
1316 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETINFO
].func
)
1317 (ConnectionHandle
, InfoType
, InfoValue
, BufferLength
, StringLength
);
1321 /*************************************************************************
1322 * SQLGetStmtAttr [ODBC32.038]
1324 SQLRETURN WINAPI
SQLGetStmtAttr(SQLHSTMT StatementHandle
,
1325 SQLINTEGER Attribute
, SQLPOINTER Value
,
1326 SQLINTEGER BufferLength
, SQLINTEGER
*StringLength
)
1332 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTATTR
].func
);
1333 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTATTR
].func
)
1334 (StatementHandle
, Attribute
, Value
, BufferLength
, StringLength
);
1338 /*************************************************************************
1339 * SQLGetStmtOption [ODBC32.046]
1341 SQLRETURN WINAPI
SQLGetStmtOption(SQLHSTMT StatementHandle
, SQLUSMALLINT Option
, SQLPOINTER Value
)
1347 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTOPTION
].func
);
1348 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTOPTION
].func
)
1349 (StatementHandle
, Option
, Value
);
1353 /*************************************************************************
1354 * SQLGetTypeInfo [ODBC32.047]
1356 SQLRETURN WINAPI
SQLGetTypeInfo(SQLHSTMT StatementHandle
, SQLSMALLINT DataType
)
1362 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETTYPEINFO
].func
);
1363 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETTYPEINFO
].func
)
1364 (StatementHandle
, DataType
);
1368 /*************************************************************************
1369 * SQLNumResultCols [ODBC32.018]
1371 SQLRETURN WINAPI
SQLNumResultCols(SQLHSTMT StatementHandle
, SQLSMALLINT
*ColumnCount
)
1377 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNUMRESULTCOLS
].func
);
1378 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNUMRESULTCOLS
].func
)
1379 (StatementHandle
, ColumnCount
);
1383 /*************************************************************************
1384 * SQLParamData [ODBC32.048]
1386 SQLRETURN WINAPI
SQLParamData(SQLHSTMT StatementHandle
, SQLPOINTER
*Value
)
1392 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPARAMDATA
].func
);
1393 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPARAMDATA
].func
)
1394 (StatementHandle
, Value
);
1398 /*************************************************************************
1399 * SQLPrepare [ODBC32.019]
1401 SQLRETURN WINAPI
SQLPrepare(SQLHSTMT StatementHandle
, SQLCHAR
*StatementText
, SQLINTEGER TextLength
)
1407 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPREPARE
].func
);
1408 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPREPARE
].func
)
1409 (StatementHandle
, StatementText
, TextLength
);
1413 /*************************************************************************
1414 * SQLPutData [ODBC32.049]
1416 SQLRETURN WINAPI
SQLPutData(SQLHSTMT StatementHandle
, SQLPOINTER Data
, SQLINTEGER StrLen_or_Ind
)
1422 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPUTDATA
].func
);
1423 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPUTDATA
].func
)
1424 (StatementHandle
, Data
, StrLen_or_Ind
);
1428 /*************************************************************************
1429 * SQLRowCount [ODBC32.020]
1431 SQLRETURN WINAPI
SQLRowCount(SQLHSTMT StatementHandle
, SQLINTEGER
*RowCount
)
1437 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLROWCOUNT
].func
);
1438 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLROWCOUNT
].func
)
1439 (StatementHandle
, RowCount
);
1443 /*************************************************************************
1444 * SQLSetConnectAttr [ODBC32.039]
1446 SQLRETURN WINAPI
SQLSetConnectAttr(SQLHDBC ConnectionHandle
, SQLINTEGER Attribute
,
1447 SQLPOINTER Value
, SQLINTEGER StringLength
)
1453 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTATTR
].func
);
1454 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTATTR
].func
)
1455 (ConnectionHandle
, Attribute
, Value
, StringLength
);
1459 /*************************************************************************
1460 * SQLSetConnectOption [ODBC32.050]
1462 SQLRETURN WINAPI
SQLSetConnectOption(SQLHDBC ConnectionHandle
, SQLUSMALLINT Option
, SQLUINTEGER Value
)
1468 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTOPTION
].func
);
1469 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTOPTION
].func
)
1470 (ConnectionHandle
, Option
, Value
);
1474 /*************************************************************************
1475 * SQLSetCursorName [ODBC32.021]
1477 SQLRETURN WINAPI
SQLSetCursorName(SQLHSTMT StatementHandle
, SQLCHAR
*CursorName
, SQLSMALLINT NameLength
)
1483 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCURSORNAME
].func
);
1484 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCURSORNAME
].func
)
1485 (StatementHandle
, CursorName
, NameLength
);
1489 /*************************************************************************
1490 * SQLSetDescField [ODBC32.073]
1492 SQLRETURN WINAPI
SQLSetDescField(SQLHDESC DescriptorHandle
,
1493 SQLSMALLINT RecNumber
, SQLSMALLINT FieldIdentifier
,
1494 SQLPOINTER Value
, SQLINTEGER BufferLength
)
1500 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCFIELD
].func
);
1501 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCFIELD
].func
)
1502 (DescriptorHandle
, RecNumber
, FieldIdentifier
, Value
, BufferLength
);
1506 /*************************************************************************
1507 * SQLSetDescRec [ODBC32.074]
1509 SQLRETURN WINAPI
SQLSetDescRec(SQLHDESC DescriptorHandle
,
1510 SQLSMALLINT RecNumber
, SQLSMALLINT Type
,
1511 SQLSMALLINT SubType
, SQLINTEGER Length
,
1512 SQLSMALLINT Precision
, SQLSMALLINT Scale
,
1513 SQLPOINTER Data
, SQLINTEGER
*StringLength
,
1514 SQLINTEGER
*Indicator
)
1520 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCREC
].func
);
1521 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCREC
].func
)
1522 (DescriptorHandle
, RecNumber
, Type
, SubType
, Length
,
1523 Precision
, Scale
, Data
, StringLength
, Indicator
);
1527 /*************************************************************************
1528 * SQLSetEnvAttr [ODBC32.075]
1530 SQLRETURN WINAPI
SQLSetEnvAttr(SQLHENV EnvironmentHandle
,
1531 SQLINTEGER Attribute
, SQLPOINTER Value
,
1532 SQLINTEGER StringLength
)
1538 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETENVATTR
].func
);
1539 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETENVATTR
].func
)
1540 (EnvironmentHandle
, Attribute
, Value
, StringLength
);
1544 /*************************************************************************
1545 * SQLSetParam [ODBC32.022]
1547 SQLRETURN WINAPI
SQLSetParam(SQLHSTMT StatementHandle
,
1548 SQLUSMALLINT ParameterNumber
, SQLSMALLINT ValueType
,
1549 SQLSMALLINT ParameterType
, SQLUINTEGER LengthPrecision
,
1550 SQLSMALLINT ParameterScale
, SQLPOINTER ParameterValue
,
1551 SQLINTEGER
*StrLen_or_Ind
)
1557 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETPARAM
].func
);
1558 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETPARAM
].func
)
1559 (StatementHandle
, ParameterNumber
, ValueType
, ParameterType
, LengthPrecision
,
1560 ParameterScale
, ParameterValue
, StrLen_or_Ind
);
1564 /*************************************************************************
1565 * SQLSetStmtAttr [ODBC32.076]
1567 SQLRETURN WINAPI
SQLSetStmtAttr(SQLHSTMT StatementHandle
,
1568 SQLINTEGER Attribute
, SQLPOINTER Value
,
1569 SQLINTEGER StringLength
)
1575 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTATTR
].func
);
1576 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTATTR
].func
)
1577 (StatementHandle
, Attribute
, Value
, StringLength
);
1581 /*************************************************************************
1582 * SQLSetStmtOption [ODBC32.051]
1584 SQLRETURN WINAPI
SQLSetStmtOption(SQLHSTMT StatementHandle
, SQLUSMALLINT Option
, SQLUINTEGER Value
)
1590 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTOPTION
].func
);
1591 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTOPTION
].func
)
1592 (StatementHandle
, Option
, Value
);
1596 /*************************************************************************
1597 * SQLSpecialColumns [ODBC32.052]
1599 SQLRETURN WINAPI
SQLSpecialColumns(SQLHSTMT StatementHandle
,
1600 SQLUSMALLINT IdentifierType
, SQLCHAR
*CatalogName
,
1601 SQLSMALLINT NameLength1
, SQLCHAR
*SchemaName
,
1602 SQLSMALLINT NameLength2
, SQLCHAR
*TableName
,
1603 SQLSMALLINT NameLength3
, SQLUSMALLINT Scope
,
1604 SQLUSMALLINT Nullable
)
1609 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSPECIALCOLUMNS
].func
);
1610 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSPECIALCOLUMNS
].func
)
1611 (StatementHandle
, IdentifierType
, CatalogName
, NameLength1
, SchemaName
,
1612 NameLength2
, TableName
, NameLength3
, Scope
, Nullable
);
1616 /*************************************************************************
1617 * SQLStatistics [ODBC32.053]
1619 SQLRETURN WINAPI
SQLStatistics(SQLHSTMT StatementHandle
,
1620 SQLCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
1621 SQLCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
1622 SQLCHAR
*TableName
, SQLSMALLINT NameLength3
,
1623 SQLUSMALLINT Unique
, SQLUSMALLINT Reserved
)
1629 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSTATISTICS
].func
);
1630 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSTATISTICS
].func
)
1631 (StatementHandle
, CatalogName
, NameLength1
, SchemaName
, NameLength2
,
1632 TableName
, NameLength3
, Unique
, Reserved
);
1636 /*************************************************************************
1637 * SQLTables [ODBC32.054]
1639 SQLRETURN WINAPI
SQLTables(SQLHSTMT StatementHandle
,
1640 SQLCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
1641 SQLCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
1642 SQLCHAR
*TableName
, SQLSMALLINT NameLength3
,
1643 SQLCHAR
*TableType
, SQLSMALLINT NameLength4
)
1649 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLES
].func
);
1650 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLES
].func
)
1651 (StatementHandle
, CatalogName
, NameLength1
,
1652 SchemaName
, NameLength2
, TableName
, NameLength3
, TableType
, NameLength4
);
1656 /*************************************************************************
1657 * SQLTransact [ODBC32.023]
1659 SQLRETURN WINAPI
SQLTransact(SQLHENV EnvironmentHandle
, SQLHDBC ConnectionHandle
,
1660 SQLUSMALLINT CompletionType
)
1666 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTRANSACT
].func
);
1667 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTRANSACT
].func
)
1668 (EnvironmentHandle
, ConnectionHandle
, CompletionType
);
1672 /*************************************************************************
1673 * SQLBrowseConnect [ODBC32.055]
1675 SQLRETURN WINAPI
SQLBrowseConnect(
1677 SQLCHAR
*szConnStrIn
,
1678 SQLSMALLINT cbConnStrIn
,
1679 SQLCHAR
*szConnStrOut
,
1680 SQLSMALLINT cbConnStrOutMax
,
1681 SQLSMALLINT
*pcbConnStrOut
)
1687 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBROWSECONNECT
].func
);
1688 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBROWSECONNECT
].func
)
1689 (hdbc
, szConnStrIn
, cbConnStrIn
, szConnStrOut
, cbConnStrOutMax
, pcbConnStrOut
);
1693 /*************************************************************************
1694 * SQLBulkOperations [ODBC32.078]
1696 SQLRETURN WINAPI
SQLBulkOperations(
1697 SQLHSTMT StatementHandle
,
1698 SQLSMALLINT Operation
)
1704 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBULKOPERATIONS
].func
);
1705 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBULKOPERATIONS
].func
)
1706 (StatementHandle
, Operation
);
1710 /*************************************************************************
1711 * SQLColAttributes [ODBC32.006]
1713 SQLRETURN WINAPI
SQLColAttributes(
1716 SQLUSMALLINT fDescType
,
1718 SQLSMALLINT cbDescMax
,
1719 SQLSMALLINT
*pcbDesc
,
1726 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTES
].func
);
1727 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTES
].func
)
1728 (hstmt
, icol
, fDescType
, rgbDesc
, cbDescMax
, pcbDesc
, pfDesc
);
1732 /*************************************************************************
1733 * SQLColumnPrivileges [ODBC32.056]
1735 SQLRETURN WINAPI
SQLColumnPrivileges(
1737 SQLCHAR
*szCatalogName
,
1738 SQLSMALLINT cbCatalogName
,
1739 SQLCHAR
*szSchemaName
,
1740 SQLSMALLINT cbSchemaName
,
1741 SQLCHAR
*szTableName
,
1742 SQLSMALLINT cbTableName
,
1743 SQLCHAR
*szColumnName
,
1744 SQLSMALLINT cbColumnName
)
1750 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNPRIVILEGES
].func
);
1751 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNPRIVILEGES
].func
)
1752 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
1753 szTableName
, cbTableName
, szColumnName
, cbColumnName
);
1757 /*************************************************************************
1758 * SQLDescribeParam [ODBC32.058]
1760 SQLRETURN WINAPI
SQLDescribeParam(
1763 SQLSMALLINT
*pfSqlType
,
1764 SQLUINTEGER
*pcbParamDef
,
1765 SQLSMALLINT
*pibScale
,
1766 SQLSMALLINT
*pfNullable
)
1772 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBEPARAM
].func
);
1773 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBEPARAM
].func
)
1774 (hstmt
, ipar
, pfSqlType
, pcbParamDef
, pibScale
, pfNullable
);
1778 /*************************************************************************
1779 * SQLExtendedFetch [ODBC32.059]
1781 SQLRETURN WINAPI
SQLExtendedFetch(
1783 SQLUSMALLINT fFetchType
,
1786 SQLUSMALLINT
*rgfRowStatus
)
1792 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXTENDEDFETCH
].func
);
1793 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXTENDEDFETCH
].func
)
1794 (hstmt
, fFetchType
, irow
, pcrow
, rgfRowStatus
);
1798 /*************************************************************************
1799 * SQLForeignKeys [ODBC32.060]
1801 SQLRETURN WINAPI
SQLForeignKeys(
1803 SQLCHAR
*szPkCatalogName
,
1804 SQLSMALLINT cbPkCatalogName
,
1805 SQLCHAR
*szPkSchemaName
,
1806 SQLSMALLINT cbPkSchemaName
,
1807 SQLCHAR
*szPkTableName
,
1808 SQLSMALLINT cbPkTableName
,
1809 SQLCHAR
*szFkCatalogName
,
1810 SQLSMALLINT cbFkCatalogName
,
1811 SQLCHAR
*szFkSchemaName
,
1812 SQLSMALLINT cbFkSchemaName
,
1813 SQLCHAR
*szFkTableName
,
1814 SQLSMALLINT cbFkTableName
)
1820 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFOREIGNKEYS
].func
);
1821 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFOREIGNKEYS
].func
)
1822 (hstmt
, szPkCatalogName
, cbPkCatalogName
, szPkSchemaName
, cbPkSchemaName
,
1823 szPkTableName
, cbPkTableName
, szFkCatalogName
, cbFkCatalogName
, szFkSchemaName
,
1824 cbFkSchemaName
, szFkTableName
, cbFkTableName
);
1828 /*************************************************************************
1829 * SQLMoreResults [ODBC32.061]
1831 SQLRETURN WINAPI
SQLMoreResults(SQLHSTMT hstmt
)
1837 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLMORERESULTS
].func
);
1838 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLMORERESULTS
].func
) (hstmt
);
1842 /*************************************************************************
1843 * SQLNativeSql [ODBC32.062]
1845 SQLRETURN WINAPI
SQLNativeSql(
1847 SQLCHAR
*szSqlStrIn
,
1848 SQLINTEGER cbSqlStrIn
,
1850 SQLINTEGER cbSqlStrMax
,
1851 SQLINTEGER
*pcbSqlStr
)
1857 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNATIVESQL
].func
);
1858 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNATIVESQL
].func
)
1859 (hdbc
, szSqlStrIn
, cbSqlStrIn
, szSqlStr
, cbSqlStrMax
, pcbSqlStr
);
1863 /*************************************************************************
1864 * SQLNumParams [ODBC32.063]
1866 SQLRETURN WINAPI
SQLNumParams(
1874 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNUMPARAMS
].func
);
1875 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNUMPARAMS
].func
) (hstmt
, pcpar
);
1879 /*************************************************************************
1880 * SQLParamOptions [ODBC32.064]
1882 SQLRETURN WINAPI
SQLParamOptions(
1891 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPARAMOPTIONS
].func
);
1892 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPARAMOPTIONS
].func
) (hstmt
, crow
, pirow
);
1896 /*************************************************************************
1897 * SQLPrimaryKeys [ODBC32.065]
1899 SQLRETURN WINAPI
SQLPrimaryKeys(
1901 SQLCHAR
*szCatalogName
,
1902 SQLSMALLINT cbCatalogName
,
1903 SQLCHAR
*szSchemaName
,
1904 SQLSMALLINT cbSchemaName
,
1905 SQLCHAR
*szTableName
,
1906 SQLSMALLINT cbTableName
)
1912 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPRIMARYKEYS
].func
);
1913 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPRIMARYKEYS
].func
)
1914 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
1915 szTableName
, cbTableName
);
1919 /*************************************************************************
1920 * SQLProcedureColumns [ODBC32.066]
1922 SQLRETURN WINAPI
SQLProcedureColumns(
1924 SQLCHAR
*szCatalogName
,
1925 SQLSMALLINT cbCatalogName
,
1926 SQLCHAR
*szSchemaName
,
1927 SQLSMALLINT cbSchemaName
,
1928 SQLCHAR
*szProcName
,
1929 SQLSMALLINT cbProcName
,
1930 SQLCHAR
*szColumnName
,
1931 SQLSMALLINT cbColumnName
)
1937 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURECOLUMNS
].func
);
1938 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURECOLUMNS
].func
)
1939 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
1940 szProcName
, cbProcName
, szColumnName
, cbColumnName
);
1944 /*************************************************************************
1945 * SQLProcedures [ODBC32.067]
1947 SQLRETURN WINAPI
SQLProcedures(
1949 SQLCHAR
*szCatalogName
,
1950 SQLSMALLINT cbCatalogName
,
1951 SQLCHAR
*szSchemaName
,
1952 SQLSMALLINT cbSchemaName
,
1953 SQLCHAR
*szProcName
,
1954 SQLSMALLINT cbProcName
)
1960 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURES
].func
);
1961 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURES
].func
)
1962 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
1963 szProcName
, cbProcName
);
1967 /*************************************************************************
1968 * SQLSetPos [ODBC32.068]
1970 SQLRETURN WINAPI
SQLSetPos(
1973 SQLUSMALLINT fOption
,
1980 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETPOS
].func
);
1981 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETPOS
].func
)
1982 (hstmt
, irow
, fOption
, fLock
);
1986 /*************************************************************************
1987 * SQLTablePrivileges [ODBC32.070]
1989 SQLRETURN WINAPI
SQLTablePrivileges(
1991 SQLCHAR
*szCatalogName
,
1992 SQLSMALLINT cbCatalogName
,
1993 SQLCHAR
*szSchemaName
,
1994 SQLSMALLINT cbSchemaName
,
1995 SQLCHAR
*szTableName
,
1996 SQLSMALLINT cbTableName
)
2002 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLEPRIVILEGES
].func
);
2003 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLEPRIVILEGES
].func
)
2004 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2005 szTableName
, cbTableName
);
2009 /*************************************************************************
2010 * SQLDrivers [ODBC32.071]
2012 SQLRETURN WINAPI
SQLDrivers(
2014 SQLUSMALLINT fDirection
,
2015 SQLCHAR
*szDriverDesc
,
2016 SQLSMALLINT cbDriverDescMax
,
2017 SQLSMALLINT
*pcbDriverDesc
,
2018 SQLCHAR
*szDriverAttributes
,
2019 SQLSMALLINT cbDriverAttrMax
,
2020 SQLSMALLINT
*pcbDriverAttr
)
2026 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERS
].func
);
2027 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERS
].func
)
2028 (henv
, fDirection
, szDriverDesc
, cbDriverDescMax
, pcbDriverDesc
,
2029 szDriverAttributes
, cbDriverAttrMax
, pcbDriverAttr
);
2033 /*************************************************************************
2034 * SQLBindParameter [ODBC32.072]
2036 SQLRETURN WINAPI
SQLBindParameter(
2039 SQLSMALLINT fParamType
,
2041 SQLSMALLINT fSqlType
,
2042 SQLUINTEGER cbColDef
,
2043 SQLSMALLINT ibScale
,
2044 SQLPOINTER rgbValue
,
2045 SQLINTEGER cbValueMax
,
2046 SQLINTEGER
*pcbValue
)
2052 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDPARAMETER
].func
);
2053 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBINDPARAMETER
].func
)
2054 (hstmt
, ipar
, fParamType
, fCType
, fSqlType
, cbColDef
, ibScale
,
2055 rgbValue
, cbValueMax
, pcbValue
);
2059 /*************************************************************************
2060 * SQLDriverConnect [ODBC32.041]
2062 SQLRETURN WINAPI
SQLDriverConnect(
2065 SQLCHAR
*conn_str_in
,
2066 SQLSMALLINT len_conn_str_in
,
2067 SQLCHAR
*conn_str_out
,
2068 SQLSMALLINT conn_str_out_max
,
2069 SQLSMALLINT
*ptr_conn_str_out
,
2070 SQLUSMALLINT driver_completion
)
2076 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERCONNECT
].func
);
2077 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERCONNECT
].func
)
2078 (hdbc
, hwnd
, conn_str_in
, len_conn_str_in
, conn_str_out
,
2079 conn_str_out_max
, ptr_conn_str_out
, driver_completion
);
2083 /*************************************************************************
2084 * SQLSetScrollOptions [ODBC32.069]
2086 SQLRETURN WINAPI
SQLSetScrollOptions(
2087 SQLHSTMT statement_handle
,
2088 SQLUSMALLINT f_concurrency
,
2089 SQLINTEGER crow_keyset
,
2090 SQLUSMALLINT crow_rowset
)
2096 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSCROLLOPTIONS
].func
);
2097 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSCROLLOPTIONS
].func
)
2098 (statement_handle
, f_concurrency
, crow_keyset
, crow_rowset
);
2101 static int SQLColAttributes_KnownStringAttribute(SQLUSMALLINT fDescType
)
2103 static const SQLUSMALLINT attrList
[] =
2105 SQL_COLUMN_OWNER_NAME
,
2106 SQL_COLUMN_QUALIFIER_NAME
,
2109 SQL_COLUMN_TABLE_NAME
,
2110 SQL_COLUMN_TYPE_NAME
,
2111 SQL_DESC_BASE_COLUMN_NAME
,
2112 SQL_DESC_BASE_TABLE_NAME
,
2113 SQL_DESC_CATALOG_NAME
,
2115 SQL_DESC_LITERAL_PREFIX
,
2116 SQL_DESC_LITERAL_SUFFIX
,
2117 SQL_DESC_LOCAL_TYPE_NAME
,
2119 SQL_DESC_SCHEMA_NAME
,
2120 SQL_DESC_TABLE_NAME
,
2125 for (i
= 0; i
< sizeof(attrList
) / sizeof(SQLUSMALLINT
); i
++) {
2126 if (attrList
[i
] == fDescType
) return 1;
2131 /*************************************************************************
2132 * SQLColAttributesW [ODBC32.106]
2134 SQLRETURN WINAPI
SQLColAttributesW(
2137 SQLUSMALLINT fDescType
,
2139 SQLSMALLINT cbDescMax
,
2140 SQLSMALLINT
*pcbDesc
,
2145 TRACE("hstmt=0x%08lx icol=%d fDescType=%d rgbDesc=%p cbDescMax=%d pcbDesc=%p pfDesc=%p\n",
2146 hstmt
, icol
, fDescType
, rgbDesc
, cbDescMax
, pcbDesc
, pfDesc
);
2149 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTES
].funcW
);
2150 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTES
].funcW
)
2151 (hstmt
, icol
, fDescType
, rgbDesc
, cbDescMax
, pcbDesc
, pfDesc
);
2152 if (iResult
== SQL_SUCCESS
&& rgbDesc
!= NULL
&& SQLColAttributes_KnownStringAttribute(fDescType
)) {
2154 TRACE("Dumping values fetched via SQLColAttributesW:\n");
2155 TRACE(" Attribute name : %s\n", debugstr_w(rgbDesc));
2156 TRACE(" Declared length: %d\n", *pcbDesc);
2158 if (*pcbDesc
!= lstrlenW(rgbDesc
) * 2) {
2159 TRACE("CHEAT: resetting name length for ADO\n");
2160 *pcbDesc
= lstrlenW(rgbDesc
) * 2;
2166 /*************************************************************************
2167 * SQLConnectW [ODBC32.107]
2169 SQLRETURN WINAPI
SQLConnectW(SQLHDBC ConnectionHandle
,
2170 WCHAR
*ServerName
, SQLSMALLINT NameLength1
,
2171 WCHAR
*UserName
, SQLSMALLINT NameLength2
,
2172 WCHAR
*Authentication
, SQLSMALLINT NameLength3
)
2175 TRACE("(Server=%.*s)\n",NameLength1
+3, debugstr_w(ServerName
));
2177 CHECK_READY_AND_dmHandle();
2179 WideCharToMultiByte(
2181 ServerName
, NameLength1
,
2182 gProxyHandle
.ServerName
, sizeof(gProxyHandle
.ServerName
),
2184 WideCharToMultiByte(
2186 UserName
, NameLength2
,
2187 gProxyHandle
.UserName
, sizeof(gProxyHandle
.UserName
),
2190 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCONNECT
].funcW
);
2191 ret
=(gProxyHandle
.functions
[SQLAPI_INDEX_SQLCONNECT
].funcW
)
2192 (ConnectionHandle
, ServerName
, NameLength1
,
2193 UserName
, NameLength2
, Authentication
, NameLength3
);
2195 TRACE("returns %d\n",ret
);
2199 /*************************************************************************
2200 * SQLDescribeColW [ODBC32.108]
2202 SQLRETURN WINAPI
SQLDescribeColW(SQLHSTMT StatementHandle
,
2203 SQLUSMALLINT ColumnNumber
, WCHAR
*ColumnName
,
2204 SQLSMALLINT BufferLength
, SQLSMALLINT
*NameLength
,
2205 SQLSMALLINT
*DataType
, SQLUINTEGER
*ColumnSize
,
2206 SQLSMALLINT
*DecimalDigits
, SQLSMALLINT
*Nullable
)
2211 CHECK_READY_AND_dmHandle();
2213 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBECOL
].funcW
);
2214 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDESCRIBECOL
].funcW
)
2215 (StatementHandle
, ColumnNumber
, ColumnName
,
2216 BufferLength
, NameLength
, DataType
, ColumnSize
, DecimalDigits
, Nullable
);
2218 TRACE("Successfully recovered the following column information:\n");
2219 TRACE("\tRequested column index: %d\n", ColumnNumber
);
2220 TRACE("\tAvailable length for column name: %d\n", BufferLength
);
2221 if (NameLength
!= NULL
)
2222 TRACE("\tActual length for column name: %d\n", *NameLength
);
2223 else TRACE("\tActual length for column name: (null)\n");
2224 TRACE("\tReturned column name: %s\n", debugstr_w(ColumnName
));
2229 /*************************************************************************
2230 * SQLErrorW [ODBC32.110]
2232 SQLRETURN WINAPI
SQLErrorW(SQLHENV EnvironmentHandle
,
2233 SQLHDBC ConnectionHandle
, SQLHSTMT StatementHandle
,
2234 WCHAR
*Sqlstate
, SQLINTEGER
*NativeError
,
2235 WCHAR
*MessageText
, SQLSMALLINT BufferLength
,
2236 SQLSMALLINT
*TextLength
)
2240 CHECK_READY_AND_dmHandle();
2242 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLERROR
].funcW
);
2243 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLERROR
].funcW
)
2244 (EnvironmentHandle
, ConnectionHandle
, StatementHandle
,
2245 Sqlstate
, NativeError
, MessageText
, BufferLength
, TextLength
);
2248 /*************************************************************************
2249 * SQLExecDirectW [ODBC32.111]
2251 SQLRETURN WINAPI
SQLExecDirectW(SQLHSTMT StatementHandle
,
2252 WCHAR
*StatementText
, SQLINTEGER TextLength
)
2256 CHECK_READY_AND_dmHandle();
2258 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECDIRECT
].funcW
);
2259 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLEXECDIRECT
].funcW
)
2260 (StatementHandle
, StatementText
, TextLength
);
2263 /*************************************************************************
2264 * SQLGetCursorNameW [ODBC32.117]
2266 SQLRETURN WINAPI
SQLGetCursorNameW(SQLHSTMT StatementHandle
,
2267 WCHAR
*CursorName
, SQLSMALLINT BufferLength
,
2268 SQLSMALLINT
*NameLength
)
2274 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCURSORNAME
].funcW
);
2275 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCURSORNAME
].funcW
)
2276 (StatementHandle
, CursorName
, BufferLength
, NameLength
);
2279 /*************************************************************************
2280 * SQLPrepareW [ODBC32.119]
2282 SQLRETURN WINAPI
SQLPrepareW(SQLHSTMT StatementHandle
,
2283 WCHAR
*StatementText
, SQLINTEGER TextLength
)
2289 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPREPARE
].funcW
);
2290 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPREPARE
].funcW
)
2291 (StatementHandle
, StatementText
, TextLength
);
2294 /*************************************************************************
2295 * SQLSetCursorNameW [ODBC32.121]
2297 SQLRETURN WINAPI
SQLSetCursorNameW(SQLHSTMT StatementHandle
, WCHAR
*CursorName
, SQLSMALLINT NameLength
)
2303 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCURSORNAME
].funcW
);
2304 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCURSORNAME
].funcW
)
2305 (StatementHandle
, CursorName
, NameLength
);
2308 /*************************************************************************
2309 * SQLColAttributeW [ODBC32.127]
2311 SQLRETURN WINAPI
SQLColAttributeW (SQLHSTMT StatementHandle
,
2312 SQLUSMALLINT ColumnNumber
, SQLUSMALLINT FieldIdentifier
,
2313 SQLPOINTER CharacterAttribute
, SQLSMALLINT BufferLength
,
2314 SQLSMALLINT
*StringLength
, SQLPOINTER NumericAttribute
)
2318 TRACE("StatementHandle=0x%08lx ColumnNumber=%d FieldIdentifier=%d CharacterAttribute=%p BufferLength=%d StringLength=%p NumericAttribute=%p\n",
2319 StatementHandle
, ColumnNumber
, FieldIdentifier
,
2320 CharacterAttribute
, BufferLength
, StringLength
, NumericAttribute
);
2322 CHECK_READY_AND_dmHandle();
2324 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTE
].funcW
);
2325 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLATTRIBUTE
].funcW
)
2326 (StatementHandle
, ColumnNumber
, FieldIdentifier
,
2327 CharacterAttribute
, BufferLength
, StringLength
, NumericAttribute
);
2328 if (iResult
== SQL_SUCCESS
&& CharacterAttribute
!= NULL
&& SQLColAttributes_KnownStringAttribute(FieldIdentifier
)) {
2330 TRACE("Dumping values fetched via SQLColAttributeW:\n");
2331 TRACE(" Attribute name : %s\n", debugstr_w(rgbDesc));
2332 TRACE(" Declared length: %d\n", *pcbDesc);
2334 if (*StringLength
!= lstrlenW(CharacterAttribute
) * 2) {
2335 TRACE("CHEAT: resetting name length for ADO\n");
2336 *StringLength
= lstrlenW(CharacterAttribute
) * 2;
2342 /*************************************************************************
2343 * SQLGetConnectAttrW [ODBC32.132]
2345 SQLRETURN WINAPI
SQLGetConnectAttrW(SQLHDBC ConnectionHandle
,
2346 SQLINTEGER Attribute
, SQLPOINTER Value
,
2347 SQLINTEGER BufferLength
, SQLINTEGER
*StringLength
)
2353 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTATTR
].funcW
);
2354 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTATTR
].funcW
)
2355 (ConnectionHandle
, Attribute
, Value
,
2356 BufferLength
, StringLength
);
2359 /*************************************************************************
2360 * SQLGetDescFieldW [ODBC32.133]
2362 SQLRETURN WINAPI
SQLGetDescFieldW(SQLHDESC DescriptorHandle
,
2363 SQLSMALLINT RecNumber
, SQLSMALLINT FieldIdentifier
,
2364 SQLPOINTER Value
, SQLINTEGER BufferLength
,
2365 SQLINTEGER
*StringLength
)
2371 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCFIELD
].funcW
);
2372 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCFIELD
].funcW
)
2373 (DescriptorHandle
, RecNumber
, FieldIdentifier
,
2374 Value
, BufferLength
, StringLength
);
2377 /*************************************************************************
2378 * SQLGetDescRecW [ODBC32.134]
2380 SQLRETURN WINAPI
SQLGetDescRecW(SQLHDESC DescriptorHandle
,
2381 SQLSMALLINT RecNumber
, WCHAR
*Name
,
2382 SQLSMALLINT BufferLength
, SQLSMALLINT
*StringLength
,
2383 SQLSMALLINT
*Type
, SQLSMALLINT
*SubType
,
2384 SQLINTEGER
*Length
, SQLSMALLINT
*Precision
,
2385 SQLSMALLINT
*Scale
, SQLSMALLINT
*Nullable
)
2391 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCREC
].funcW
);
2392 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDESCREC
].funcW
)
2393 (DescriptorHandle
, RecNumber
, Name
, BufferLength
,
2394 StringLength
, Type
, SubType
, Length
, Precision
, Scale
, Nullable
);
2397 /*************************************************************************
2398 * SQLGetDiagFieldW [ODBC32.135]
2400 SQLRETURN WINAPI
SQLGetDiagFieldW(SQLSMALLINT HandleType
, SQLHANDLE Handle
,
2401 SQLSMALLINT RecNumber
, SQLSMALLINT DiagIdentifier
,
2402 SQLPOINTER DiagInfo
, SQLSMALLINT BufferLength
,
2403 SQLSMALLINT
*StringLength
)
2409 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGFIELD
].funcW
);
2410 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGFIELD
].funcW
)
2411 (HandleType
, Handle
, RecNumber
, DiagIdentifier
,
2412 DiagInfo
, BufferLength
, StringLength
);
2415 /*************************************************************************
2416 * SQLGetDiagRecW [ODBC32.136]
2418 SQLRETURN WINAPI
SQLGetDiagRecW(SQLSMALLINT HandleType
, SQLHANDLE Handle
,
2419 SQLSMALLINT RecNumber
, WCHAR
*Sqlstate
,
2420 SQLINTEGER
*NativeError
, WCHAR
*MessageText
,
2421 SQLSMALLINT BufferLength
, SQLSMALLINT
*TextLength
)
2427 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGREC
].funcW
);
2428 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETDIAGREC
].funcW
)
2429 (HandleType
, Handle
, RecNumber
, Sqlstate
, NativeError
,
2430 MessageText
, BufferLength
, TextLength
);
2433 /*************************************************************************
2434 * SQLGetStmtAttrW [ODBC32.138]
2436 SQLRETURN WINAPI
SQLGetStmtAttrW(SQLHSTMT StatementHandle
,
2437 SQLINTEGER Attribute
, SQLPOINTER Value
,
2438 SQLINTEGER BufferLength
, SQLINTEGER
*StringLength
)
2442 TRACE("Attribute = (%02ld) Value = %p BufferLength = (%ld) StringLength = %p\n",
2443 Attribute
, Value
, BufferLength
, StringLength
);
2445 if (Value
== NULL
) {
2446 WARN("Unexpected NULL in Value return address\n");
2447 iResult
= SQL_ERROR
;
2449 } else if (StringLength == NULL) {
2450 WARN("Unexpected NULL in StringLength return address\n");
2451 iResult = SQL_ERROR;
2456 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTATTR
].funcW
);
2457 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETSTMTATTR
].funcW
)
2458 (StatementHandle
, Attribute
, Value
, BufferLength
, StringLength
);
2459 TRACE("returning %d...\n", iResult
);
2464 /*************************************************************************
2465 * SQLSetConnectAttrW [ODBC32.139]
2467 SQLRETURN WINAPI
SQLSetConnectAttrW(SQLHDBC ConnectionHandle
, SQLINTEGER Attribute
,
2468 SQLPOINTER Value
, SQLINTEGER StringLength
)
2474 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTATTR
].funcW
);
2475 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTATTR
].funcW
)
2476 (ConnectionHandle
, Attribute
, Value
, StringLength
);
2479 /*************************************************************************
2480 * SQLColumnsW [ODBC32.140]
2482 SQLRETURN WINAPI
SQLColumnsW(SQLHSTMT StatementHandle
,
2483 WCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
2484 WCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
2485 WCHAR
*TableName
, SQLSMALLINT NameLength3
,
2486 WCHAR
*ColumnName
, SQLSMALLINT NameLength4
)
2490 CHECK_READY_AND_dmHandle();
2492 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNS
].funcW
);
2493 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNS
].funcW
)
2494 (StatementHandle
, CatalogName
, NameLength1
,
2495 SchemaName
, NameLength2
, TableName
, NameLength3
, ColumnName
, NameLength4
);
2498 /*************************************************************************
2499 * SQLDriverConnectW [ODBC32.141]
2501 SQLRETURN WINAPI
SQLDriverConnectW(
2505 SQLSMALLINT len_conn_str_in
,
2506 WCHAR
*conn_str_out
,
2507 SQLSMALLINT conn_str_out_max
,
2508 SQLSMALLINT
*ptr_conn_str_out
,
2509 SQLUSMALLINT driver_completion
)
2511 TRACE("ConnStrIn (%d bytes) --> %s\n", len_conn_str_in
, debugstr_w(conn_str_in
));
2515 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERCONNECT
].funcW
);
2516 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERCONNECT
].funcW
)
2517 (hdbc
, hwnd
, conn_str_in
, len_conn_str_in
, conn_str_out
,
2518 conn_str_out_max
, ptr_conn_str_out
, driver_completion
);
2521 /*************************************************************************
2522 * SQLGetConnectOptionW [ODBC32.142]
2524 SQLRETURN WINAPI
SQLGetConnectOptionW(SQLHDBC ConnectionHandle
, SQLUSMALLINT Option
, SQLPOINTER Value
)
2530 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTOPTION
].funcW
);
2531 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETCONNECTOPTION
].funcW
)
2532 (ConnectionHandle
, Option
, Value
);
2535 /*************************************************************************
2536 * SQLGetInfoW [ODBC32.145]
2538 SQLRETURN WINAPI
SQLGetInfoW(SQLHDBC ConnectionHandle
,
2539 SQLUSMALLINT InfoType
, SQLPOINTER InfoValue
,
2540 SQLSMALLINT BufferLength
, SQLSMALLINT
*StringLength
)
2544 TRACE("InfoType = (%02u), InfoValue = %p, BufferLength = %d bytes\n", InfoType
, InfoValue
, BufferLength
);
2545 if (InfoValue
== NULL
) {
2546 WARN("Unexpected NULL in InfoValue address\n");
2547 iResult
= SQL_ERROR
;
2551 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETINFO
].funcW
);
2552 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETINFO
].funcW
)
2553 (ConnectionHandle
, InfoType
, InfoValue
, BufferLength
, StringLength
);
2554 TRACE("returning %d...\n", iResult
);
2559 /*************************************************************************
2560 * SQLGetTypeInfoW [ODBC32.147]
2562 SQLRETURN WINAPI
SQLGetTypeInfoW(SQLHSTMT StatementHandle
, SQLSMALLINT DataType
)
2568 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETTYPEINFO
].funcW
);
2569 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLGETTYPEINFO
].funcW
)
2570 (StatementHandle
, DataType
);
2573 /*************************************************************************
2574 * SQLSetConnectOptionW [ODBC32.150]
2576 SQLRETURN WINAPI
SQLSetConnectOptionW(SQLHDBC ConnectionHandle
, SQLUSMALLINT Option
, SQLUINTEGER Value
)
2582 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTOPTION
].funcW
);
2583 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETCONNECTOPTION
].funcW
)
2584 (ConnectionHandle
, Option
, Value
);
2587 /*************************************************************************
2588 * SQLSpecialColumnsW [ODBC32.152]
2590 SQLRETURN WINAPI
SQLSpecialColumnsW(SQLHSTMT StatementHandle
,
2591 SQLUSMALLINT IdentifierType
, SQLCHAR
*CatalogName
,
2592 SQLSMALLINT NameLength1
, SQLCHAR
*SchemaName
,
2593 SQLSMALLINT NameLength2
, SQLCHAR
*TableName
,
2594 SQLSMALLINT NameLength3
, SQLUSMALLINT Scope
,
2595 SQLUSMALLINT Nullable
)
2600 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSPECIALCOLUMNS
].funcW
);
2601 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSPECIALCOLUMNS
].funcW
)
2602 (StatementHandle
, IdentifierType
, CatalogName
, NameLength1
, SchemaName
,
2603 NameLength2
, TableName
, NameLength3
, Scope
, Nullable
);
2606 /*************************************************************************
2607 * SQLStatisticsW [ODBC32.153]
2609 SQLRETURN WINAPI
SQLStatisticsW(SQLHSTMT StatementHandle
,
2610 SQLCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
2611 SQLCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
2612 SQLCHAR
*TableName
, SQLSMALLINT NameLength3
,
2613 SQLUSMALLINT Unique
, SQLUSMALLINT Reserved
)
2619 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSTATISTICS
].funcW
);
2620 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSTATISTICS
].funcW
)
2621 (StatementHandle
, CatalogName
, NameLength1
, SchemaName
, NameLength2
,
2622 TableName
, NameLength3
, Unique
, Reserved
);
2625 /*************************************************************************
2626 * SQLTablesW [ODBC32.154]
2628 SQLRETURN WINAPI
SQLTablesW(SQLHSTMT StatementHandle
,
2629 SQLCHAR
*CatalogName
, SQLSMALLINT NameLength1
,
2630 SQLCHAR
*SchemaName
, SQLSMALLINT NameLength2
,
2631 SQLCHAR
*TableName
, SQLSMALLINT NameLength3
,
2632 SQLCHAR
*TableType
, SQLSMALLINT NameLength4
)
2638 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLES
].funcW
);
2639 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLES
].funcW
)
2640 (StatementHandle
, CatalogName
, NameLength1
,
2641 SchemaName
, NameLength2
, TableName
, NameLength3
, TableType
, NameLength4
);
2644 /*************************************************************************
2645 * SQLBrowseConnectW [ODBC32.155]
2647 SQLRETURN WINAPI
SQLBrowseConnectW(
2649 SQLCHAR
*szConnStrIn
,
2650 SQLSMALLINT cbConnStrIn
,
2651 SQLCHAR
*szConnStrOut
,
2652 SQLSMALLINT cbConnStrOutMax
,
2653 SQLSMALLINT
*pcbConnStrOut
)
2659 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBROWSECONNECT
].funcW
);
2660 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLBROWSECONNECT
].funcW
)
2661 (hdbc
, szConnStrIn
, cbConnStrIn
, szConnStrOut
, cbConnStrOutMax
, pcbConnStrOut
);
2664 /*************************************************************************
2665 * SQLColumnPrivilegesW [ODBC32.156]
2667 SQLRETURN WINAPI
SQLColumnPrivilegesW(
2669 SQLCHAR
*szCatalogName
,
2670 SQLSMALLINT cbCatalogName
,
2671 SQLCHAR
*szSchemaName
,
2672 SQLSMALLINT cbSchemaName
,
2673 SQLCHAR
*szTableName
,
2674 SQLSMALLINT cbTableName
,
2675 SQLCHAR
*szColumnName
,
2676 SQLSMALLINT cbColumnName
)
2682 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNPRIVILEGES
].funcW
);
2683 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLCOLUMNPRIVILEGES
].funcW
)
2684 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2685 szTableName
, cbTableName
, szColumnName
, cbColumnName
);
2688 /*************************************************************************
2689 * SQLDataSourcesW [ODBC32.157]
2691 SQLRETURN WINAPI
SQLDataSourcesW(SQLHENV EnvironmentHandle
,
2692 SQLUSMALLINT Direction
, WCHAR
*ServerName
,
2693 SQLSMALLINT BufferLength1
, SQLSMALLINT
*NameLength1
,
2694 WCHAR
*Description
, SQLSMALLINT BufferLength2
,
2695 SQLSMALLINT
*NameLength2
)
2699 TRACE("EnvironmentHandle = %p\n", (LPVOID
)EnvironmentHandle
);
2701 if (!gProxyHandle
.bFunctionReady
|| gProxyHandle
.dmHandle
== NULL
)
2703 ERR("Error: empty dm handle (gProxyHandle.dmHandle == NULL)\n");
2707 assert(gProxyHandle
.functions
[SQLAPI_INDEX_SQLDATASOURCES
].funcW
);
2708 ret
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDATASOURCES
].funcW
)
2709 (EnvironmentHandle
, Direction
, ServerName
,
2710 BufferLength1
, NameLength1
, Description
, BufferLength2
, NameLength2
);
2714 TRACE("returns: %d \t", ret
);
2715 if (*NameLength1
> 0)
2716 TRACE("DataSource = %s,", debugstr_w(ServerName
));
2717 if (*NameLength2
> 0)
2718 TRACE(" Description = %s", debugstr_w(Description
));
2725 /*************************************************************************
2726 * SQLForeignKeysW [ODBC32.160]
2728 SQLRETURN WINAPI
SQLForeignKeysW(
2730 SQLCHAR
*szPkCatalogName
,
2731 SQLSMALLINT cbPkCatalogName
,
2732 SQLCHAR
*szPkSchemaName
,
2733 SQLSMALLINT cbPkSchemaName
,
2734 SQLCHAR
*szPkTableName
,
2735 SQLSMALLINT cbPkTableName
,
2736 SQLCHAR
*szFkCatalogName
,
2737 SQLSMALLINT cbFkCatalogName
,
2738 SQLCHAR
*szFkSchemaName
,
2739 SQLSMALLINT cbFkSchemaName
,
2740 SQLCHAR
*szFkTableName
,
2741 SQLSMALLINT cbFkTableName
)
2747 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFOREIGNKEYS
].funcW
);
2748 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLFOREIGNKEYS
].funcW
)
2749 (hstmt
, szPkCatalogName
, cbPkCatalogName
, szPkSchemaName
, cbPkSchemaName
,
2750 szPkTableName
, cbPkTableName
, szFkCatalogName
, cbFkCatalogName
, szFkSchemaName
,
2751 cbFkSchemaName
, szFkTableName
, cbFkTableName
);
2754 /*************************************************************************
2755 * SQLNativeSqlW [ODBC32.162]
2757 SQLRETURN WINAPI
SQLNativeSqlW(
2759 SQLCHAR
*szSqlStrIn
,
2760 SQLINTEGER cbSqlStrIn
,
2762 SQLINTEGER cbSqlStrMax
,
2763 SQLINTEGER
*pcbSqlStr
)
2769 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNATIVESQL
].funcW
);
2770 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLNATIVESQL
].funcW
)
2771 (hdbc
, szSqlStrIn
, cbSqlStrIn
, szSqlStr
, cbSqlStrMax
, pcbSqlStr
);
2774 /*************************************************************************
2775 * SQLPrimaryKeysW [ODBC32.165]
2777 SQLRETURN WINAPI
SQLPrimaryKeysW(
2779 SQLCHAR
*szCatalogName
,
2780 SQLSMALLINT cbCatalogName
,
2781 SQLCHAR
*szSchemaName
,
2782 SQLSMALLINT cbSchemaName
,
2783 SQLCHAR
*szTableName
,
2784 SQLSMALLINT cbTableName
)
2790 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPRIMARYKEYS
].funcW
);
2791 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPRIMARYKEYS
].funcW
)
2792 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2793 szTableName
, cbTableName
);
2796 /*************************************************************************
2797 * SQLProcedureColumnsW [ODBC32.166]
2799 SQLRETURN WINAPI
SQLProcedureColumnsW(
2801 SQLCHAR
*szCatalogName
,
2802 SQLSMALLINT cbCatalogName
,
2803 SQLCHAR
*szSchemaName
,
2804 SQLSMALLINT cbSchemaName
,
2805 SQLCHAR
*szProcName
,
2806 SQLSMALLINT cbProcName
,
2807 SQLCHAR
*szColumnName
,
2808 SQLSMALLINT cbColumnName
)
2814 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURECOLUMNS
].funcW
);
2815 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURECOLUMNS
].funcW
)
2816 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2817 szProcName
, cbProcName
, szColumnName
, cbColumnName
);
2820 /*************************************************************************
2821 * SQLProceduresW [ODBC32.167]
2823 SQLRETURN WINAPI
SQLProceduresW(
2825 SQLCHAR
*szCatalogName
,
2826 SQLSMALLINT cbCatalogName
,
2827 SQLCHAR
*szSchemaName
,
2828 SQLSMALLINT cbSchemaName
,
2829 SQLCHAR
*szProcName
,
2830 SQLSMALLINT cbProcName
)
2836 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURES
].funcW
);
2837 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLPROCEDURES
].funcW
)
2838 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2839 szProcName
, cbProcName
);
2842 /*************************************************************************
2843 * SQLTablePrivilegesW [ODBC32.170]
2845 SQLRETURN WINAPI
SQLTablePrivilegesW(
2847 SQLCHAR
*szCatalogName
,
2848 SQLSMALLINT cbCatalogName
,
2849 SQLCHAR
*szSchemaName
,
2850 SQLSMALLINT cbSchemaName
,
2851 SQLCHAR
*szTableName
,
2852 SQLSMALLINT cbTableName
)
2858 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLEPRIVILEGES
].funcW
);
2859 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLTABLEPRIVILEGES
].funcW
)
2860 (hstmt
, szCatalogName
, cbCatalogName
, szSchemaName
, cbSchemaName
,
2861 szTableName
, cbTableName
);
2864 /*************************************************************************
2865 * SQLDriversW [ODBC32.171]
2867 SQLRETURN WINAPI
SQLDriversW(
2869 SQLUSMALLINT fDirection
,
2870 SQLCHAR
*szDriverDesc
,
2871 SQLSMALLINT cbDriverDescMax
,
2872 SQLSMALLINT
*pcbDriverDesc
,
2873 SQLCHAR
*szDriverAttributes
,
2874 SQLSMALLINT cbDriverAttrMax
,
2875 SQLSMALLINT
*pcbDriverAttr
)
2881 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERS
].funcW
);
2882 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLDRIVERS
].funcW
)
2883 (henv
, fDirection
, szDriverDesc
, cbDriverDescMax
, pcbDriverDesc
,
2884 szDriverAttributes
, cbDriverAttrMax
, pcbDriverAttr
);
2887 /*************************************************************************
2888 * SQLSetDescFieldW [ODBC32.173]
2890 SQLRETURN WINAPI
SQLSetDescFieldW(SQLHDESC DescriptorHandle
,
2891 SQLSMALLINT RecNumber
, SQLSMALLINT FieldIdentifier
,
2892 SQLPOINTER Value
, SQLINTEGER BufferLength
)
2898 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCFIELD
].funcW
);
2899 return (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETDESCFIELD
].funcW
)
2900 (DescriptorHandle
, RecNumber
, FieldIdentifier
, Value
, BufferLength
);
2903 /*************************************************************************
2904 * SQLSetStmtAttrW [ODBC32.176]
2906 SQLRETURN WINAPI
SQLSetStmtAttrW(SQLHSTMT StatementHandle
,
2907 SQLINTEGER Attribute
, SQLPOINTER Value
,
2908 SQLINTEGER StringLength
)
2911 TRACE("Attribute = (%02ld) Value = %p StringLength = (%ld)\n",
2912 Attribute
, Value
, StringLength
);
2916 assert (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTATTR
].funcW
);
2917 iResult
= (gProxyHandle
.functions
[SQLAPI_INDEX_SQLSETSTMTATTR
].funcW
)
2918 (StatementHandle
, Attribute
, Value
, StringLength
);
2919 if (iResult
== SQL_ERROR
&& (Attribute
== SQL_ROWSET_SIZE
|| Attribute
== SQL_ATTR_ROW_ARRAY_SIZE
)) {
2920 TRACE("CHEAT: returning SQL_SUCCESS to ADO...\n");
2921 iResult
= SQL_SUCCESS
;
2923 TRACE("returning %d...\n", iResult
);