mirror of https://github.com/UMSKT/xpmgr.git
548 lines
15 KiB
C
548 lines
15 KiB
C
//-----------------------------------------------------------------------------
|
|
// File: odbcinst.h
|
|
//
|
|
// Copyright: Copyright (c) Microsoft Corporation
|
|
//
|
|
// Contents: Prototypes for ODBCCP32.DLL
|
|
//
|
|
// Comments:
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
|
|
#ifndef __ODBCINST_H
|
|
#define __ODBCINST_H
|
|
|
|
#ifndef __SQL
|
|
#include "sql.h"
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" { // Assume C declarations for C++
|
|
#endif // __cplusplus
|
|
|
|
#ifndef ODBCVER
|
|
#define ODBCVER 0x0380 // Default to ODBC 3.80
|
|
#endif
|
|
|
|
#ifndef WINVER
|
|
#define WINVER 0x0400 // Assume Windows 4.0
|
|
#endif
|
|
|
|
// Constants ---------------------------------------------------------------
|
|
// SQLConfigDataSource request flags
|
|
#define ODBC_ADD_DSN 1 // Add data source
|
|
#define ODBC_CONFIG_DSN 2 // Configure (edit) data source
|
|
#define ODBC_REMOVE_DSN 3 // Remove data source
|
|
|
|
#if (ODBCVER >= 0x0250)
|
|
#define ODBC_ADD_SYS_DSN 4 // add a system DSN
|
|
#define ODBC_CONFIG_SYS_DSN 5 // Configure a system DSN
|
|
#define ODBC_REMOVE_SYS_DSN 6 // remove a system DSN
|
|
#if (ODBCVER >= 0x0300)
|
|
#define ODBC_REMOVE_DEFAULT_DSN 7 // remove the default DSN
|
|
#endif /* ODBCVER >= 0x0300 */
|
|
|
|
// install request flags
|
|
#define ODBC_INSTALL_INQUIRY 1
|
|
#define ODBC_INSTALL_COMPLETE 2
|
|
|
|
// config driver flags
|
|
#define ODBC_INSTALL_DRIVER 1
|
|
#define ODBC_REMOVE_DRIVER 2
|
|
#define ODBC_CONFIG_DRIVER 3
|
|
#define ODBC_CONFIG_DRIVER_MAX 100
|
|
#endif
|
|
|
|
// SQLGetConfigMode and SQLSetConfigMode flags
|
|
#if (ODBCVER >= 0x0300)
|
|
#define ODBC_BOTH_DSN 0
|
|
#define ODBC_USER_DSN 1
|
|
#define ODBC_SYSTEM_DSN 2
|
|
#endif /* ODBCVER >= 0x0300 */
|
|
|
|
// SQLInstallerError code
|
|
#if (ODBCVER >= 0x0300)
|
|
#define ODBC_ERROR_GENERAL_ERR 1
|
|
#define ODBC_ERROR_INVALID_BUFF_LEN 2
|
|
#define ODBC_ERROR_INVALID_HWND 3
|
|
#define ODBC_ERROR_INVALID_STR 4
|
|
#define ODBC_ERROR_INVALID_REQUEST_TYPE 5
|
|
#define ODBC_ERROR_COMPONENT_NOT_FOUND 6
|
|
#define ODBC_ERROR_INVALID_NAME 7
|
|
#define ODBC_ERROR_INVALID_KEYWORD_VALUE 8
|
|
#define ODBC_ERROR_INVALID_DSN 9
|
|
#define ODBC_ERROR_INVALID_INF 10
|
|
#define ODBC_ERROR_REQUEST_FAILED 11
|
|
#define ODBC_ERROR_INVALID_PATH 12
|
|
#define ODBC_ERROR_LOAD_LIB_FAILED 13
|
|
#define ODBC_ERROR_INVALID_PARAM_SEQUENCE 14
|
|
#define ODBC_ERROR_INVALID_LOG_FILE 15
|
|
#define ODBC_ERROR_USER_CANCELED 16
|
|
#define ODBC_ERROR_USAGE_UPDATE_FAILED 17
|
|
#define ODBC_ERROR_CREATE_DSN_FAILED 18
|
|
#define ODBC_ERROR_WRITING_SYSINFO_FAILED 19
|
|
#define ODBC_ERROR_REMOVE_DSN_FAILED 20
|
|
#define ODBC_ERROR_OUT_OF_MEM 21
|
|
#define ODBC_ERROR_OUTPUT_STRING_TRUNCATED 22
|
|
#define ODBC_ERROR_NOTRANINFO 23
|
|
|
|
#define ODBC_ERROR_MAX ODBC_ERROR_NOTRANINFO // update this when we add new error message
|
|
#endif /* ODBCVER >= 0x0300 */
|
|
|
|
#ifndef EXPORT
|
|
#define EXPORT
|
|
#endif
|
|
|
|
#ifndef RC_INVOKED
|
|
// Prototypes --------------------------------------------------------------
|
|
#define INSTAPI __stdcall
|
|
|
|
// High level APIs
|
|
BOOL INSTAPI SQLInstallODBC (HWND hwndParent,
|
|
LPCSTR lpszInfFile,
|
|
LPCSTR lpszSrcPath,
|
|
LPCSTR lpszDrivers);
|
|
BOOL INSTAPI SQLManageDataSources (HWND hwndParent);
|
|
BOOL INSTAPI SQLCreateDataSource (HWND hwndParent,
|
|
LPCSTR lpszDSN);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetTranslator
|
|
(
|
|
HWND hwnd,
|
|
__inout_ecount(cchNameMax) LPSTR lpszName,
|
|
WORD cchNameMax,
|
|
WORD* pcchNameOut,
|
|
__out_ecount(cchPathMax) LPSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut,
|
|
DWORD* pvOption
|
|
);
|
|
|
|
// Low level APIs
|
|
// NOTE: The high-level APIs should always be used. These APIs
|
|
// have been left for compatibility.
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallDriver
|
|
(
|
|
LPCSTR lpszInfFile,
|
|
LPCSTR lpszDriver,
|
|
__out_ecount_opt(cchPathMax) LPSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut
|
|
);
|
|
|
|
BOOL INSTAPI SQLInstallDriverManager
|
|
(
|
|
__inout_ecount(cchPathMax) LPSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetInstalledDrivers
|
|
(
|
|
__out_ecount(cchBufMax) LPSTR lpszBuf,
|
|
WORD cchBufMax,
|
|
WORD* pcchBufOut
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetAvailableDrivers
|
|
(
|
|
LPCSTR lpszInfFile,
|
|
__out_ecount(cchBufMax) LPSTR lpszBuf,
|
|
WORD cchBufMax,
|
|
WORD* pcchBufOut
|
|
);
|
|
|
|
BOOL INSTAPI SQLConfigDataSource (HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCSTR lpszDriver,
|
|
LPCSTR lpszAttributes);
|
|
BOOL INSTAPI SQLRemoveDefaultDataSource(void);
|
|
BOOL INSTAPI SQLWriteDSNToIni (LPCSTR lpszDSN,
|
|
LPCSTR lpszDriver);
|
|
BOOL INSTAPI SQLRemoveDSNFromIni (LPCSTR lpszDSN);
|
|
BOOL INSTAPI SQLValidDSN (LPCSTR lpszDSN);
|
|
|
|
BOOL INSTAPI SQLWritePrivateProfileString(LPCSTR lpszSection,
|
|
LPCSTR lpszEntry,
|
|
LPCSTR lpszString,
|
|
LPCSTR lpszFilename);
|
|
|
|
__success(return != 0)
|
|
int INSTAPI SQLGetPrivateProfileString
|
|
(
|
|
LPCSTR lpszSection,
|
|
LPCSTR lpszEntry,
|
|
LPCSTR lpszDefault,
|
|
__out_ecount_opt(cchRetBuffer) LPSTR lpszRetBuffer,
|
|
int cchRetBuffer,
|
|
LPCSTR lpszFilename
|
|
);
|
|
|
|
#if (ODBCVER >= 0x0250)
|
|
BOOL INSTAPI SQLRemoveDriverManager(LPDWORD lpdwUsageCount);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallTranslator
|
|
(
|
|
LPCSTR lpszInfFile,
|
|
LPCSTR lpszTranslator,
|
|
LPCSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
BOOL INSTAPI SQLRemoveTranslator(LPCSTR lpszTranslator,
|
|
LPDWORD lpdwUsageCount);
|
|
BOOL INSTAPI SQLRemoveDriver(LPCSTR lpszDriver,
|
|
BOOL fRemoveDSN,
|
|
LPDWORD lpdwUsageCount);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLConfigDriver
|
|
(
|
|
HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCSTR lpszDriver,
|
|
LPCSTR lpszArgs,
|
|
__out_ecount(cchMsgMax) LPSTR lpszMsg,
|
|
WORD cchMsgMax,
|
|
WORD* pcchMsgOut
|
|
);
|
|
|
|
#endif
|
|
|
|
#if (ODBCVER >= 0x0300)
|
|
|
|
__success(return==0 ||return==1)
|
|
SQLRETURN INSTAPI SQLInstallerError
|
|
(
|
|
WORD iError,
|
|
DWORD* pfErrorCode,
|
|
__out_ecount_opt(cchErrorMsgMax) LPSTR lpszErrorMsg,
|
|
WORD cchErrorMsgMax,
|
|
WORD* pcchErrorMsg
|
|
);
|
|
|
|
SQLRETURN INSTAPI SQLPostInstallerError(DWORD dwErrorCode, LPCSTR lpszErrMsg);
|
|
|
|
BOOL INSTAPI SQLWriteFileDSN(LPCSTR lpszFileName,
|
|
LPCSTR lpszAppName,
|
|
LPCSTR lpszKeyName,
|
|
LPCSTR lpszString);
|
|
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLReadFileDSN
|
|
(
|
|
LPCSTR lpszFileName,
|
|
LPCSTR lpszAppName,
|
|
LPCSTR lpszKeyName,
|
|
__out_ecount(cchString) LPSTR lpszString,
|
|
WORD cchString,
|
|
WORD* pcchString
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallDriverEx
|
|
(
|
|
LPCSTR lpszDriver,
|
|
LPCSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallTranslatorEx
|
|
(
|
|
LPCSTR lpszTranslator,
|
|
LPCSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
BOOL INSTAPI SQLGetConfigMode(UWORD *pwConfigMode);
|
|
BOOL INSTAPI SQLSetConfigMode(UWORD wConfigMode);
|
|
#endif /* ODBCVER >= 0x0300 */
|
|
|
|
// Driver specific Setup APIs called by installer
|
|
|
|
BOOL INSTAPI ConfigDSN (HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCSTR lpszDriver,
|
|
LPCSTR lpszAttributes);
|
|
|
|
BOOL INSTAPI ConfigTranslator ( HWND hwndParent,
|
|
DWORD *pvOption);
|
|
|
|
#if (ODBCVER >= 0x0250)
|
|
|
|
BOOL INSTAPI ConfigDriver
|
|
(
|
|
HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCSTR lpszDriver,
|
|
LPCSTR lpszArgs,
|
|
__out_ecount(cchMsgMax) LPSTR lpszMsg,
|
|
WORD cchMsgMax,
|
|
WORD* pcchMsgOut
|
|
);
|
|
|
|
#endif
|
|
|
|
|
|
// UNICODE APIs
|
|
|
|
// High level APIs
|
|
BOOL INSTAPI SQLInstallODBCW (HWND hwndParent,
|
|
LPCWSTR lpszInfFile,
|
|
LPCWSTR lpszSrcPath,
|
|
LPCWSTR lpszDrivers);
|
|
BOOL INSTAPI SQLCreateDataSourceW (HWND hwndParent,
|
|
LPCWSTR lpszDSN);
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetTranslatorW
|
|
(
|
|
HWND hwnd,
|
|
__out_ecount(cchNameMax) LPWSTR lpszName,
|
|
WORD cchNameMax,
|
|
WORD* pcchNameOut,
|
|
__out_ecount(cchPathMax) LPWSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut,
|
|
DWORD* pvOption
|
|
);
|
|
|
|
// Low level APIs
|
|
// NOTE: The high-level APIs should always be used. These APIs
|
|
// have been left for compatibility.
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallDriverW
|
|
(
|
|
LPCWSTR lpszInfFile,
|
|
LPCWSTR lpszDriver,
|
|
__out_ecount(cchPathMax) LPWSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut
|
|
);
|
|
|
|
BOOL INSTAPI SQLInstallDriverManagerW
|
|
(
|
|
__inout_ecount(cchPathMax) LPWSTR lpszPath,
|
|
WORD cchPathMax,
|
|
WORD* pcchPathOut
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetInstalledDriversW
|
|
(
|
|
__out_ecount(cchBufMax) LPWSTR lpszBuf,
|
|
WORD cchBufMax,
|
|
WORD* pcchBufOut
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLGetAvailableDriversW
|
|
(
|
|
LPCWSTR lpszInfFile,
|
|
__out_ecount_opt(cchBufMax) LPWSTR lpszBuf,
|
|
WORD cchBufMax,
|
|
WORD* pcchBufOut
|
|
);
|
|
|
|
|
|
BOOL INSTAPI SQLConfigDataSourceW (HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCWSTR lpszDriver,
|
|
LPCWSTR lpszAttributes);
|
|
BOOL INSTAPI SQLWriteDSNToIniW (LPCWSTR lpszDSN,
|
|
LPCWSTR lpszDriver);
|
|
BOOL INSTAPI SQLRemoveDSNFromIniW (LPCWSTR lpszDSN);
|
|
BOOL INSTAPI SQLValidDSNW (LPCWSTR lpszDSN);
|
|
|
|
BOOL INSTAPI SQLWritePrivateProfileStringW(LPCWSTR lpszSection,
|
|
LPCWSTR lpszEntry,
|
|
LPCWSTR lpszString,
|
|
LPCWSTR lpszFilename);
|
|
|
|
__success(return != 0)
|
|
int INSTAPI SQLGetPrivateProfileStringW
|
|
(
|
|
LPCWSTR lpszSection,
|
|
LPCWSTR lpszEntry,
|
|
LPCWSTR lpszDefault,
|
|
__out_ecount_opt(cchRetBuffer) LPWSTR lpszRetBuffer,
|
|
int cchRetBuffer,
|
|
LPCWSTR lpszFilename
|
|
);
|
|
|
|
#if (ODBCVER >= 0x0250)
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallTranslatorW
|
|
(
|
|
LPCWSTR lpszInfFile,
|
|
LPCWSTR lpszTranslator,
|
|
LPCWSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPWSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
BOOL INSTAPI SQLRemoveTranslatorW(LPCWSTR lpszTranslator,
|
|
LPDWORD lpdwUsageCount);
|
|
BOOL INSTAPI SQLRemoveDriverW(LPCWSTR lpszDriver,
|
|
BOOL fRemoveDSN,
|
|
LPDWORD lpdwUsageCount);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLConfigDriverW
|
|
(
|
|
HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCWSTR lpszDriver,
|
|
LPCWSTR lpszArgs,
|
|
__out_ecount(cchMsgMax) LPWSTR lpszMsg,
|
|
WORD cchMsgMax,
|
|
WORD* pcchMsgOut
|
|
);
|
|
|
|
#endif
|
|
|
|
#if (ODBCVER >= 0x0300)
|
|
|
|
__success(return==0 ||return==1)
|
|
SQLRETURN INSTAPI SQLInstallerErrorW
|
|
(
|
|
WORD iError,
|
|
DWORD* pfErrorCode,
|
|
__out_ecount_opt(cchErrorMsgMax) LPWSTR lpszErrorMsg,
|
|
WORD cchErrorMsgMax,
|
|
WORD* pcchErrorMsg
|
|
);
|
|
|
|
SQLRETURN INSTAPI SQLPostInstallerErrorW(DWORD dwErrorCode,
|
|
LPCWSTR lpszErrorMsg);
|
|
|
|
BOOL INSTAPI SQLWriteFileDSNW(LPCWSTR lpszFileName,
|
|
LPCWSTR lpszAppName,
|
|
LPCWSTR lpszKeyName,
|
|
LPCWSTR lpszString);
|
|
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLReadFileDSNW
|
|
(
|
|
LPCWSTR lpszFileName,
|
|
LPCWSTR lpszAppName,
|
|
LPCWSTR lpszKeyName,
|
|
__out_ecount(cchString) LPWSTR lpszString,
|
|
WORD cchString,
|
|
WORD* pcchString
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallDriverExW
|
|
(
|
|
LPCWSTR lpszDriver,
|
|
LPCWSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPWSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
__success(return)
|
|
BOOL INSTAPI SQLInstallTranslatorExW
|
|
(
|
|
LPCWSTR lpszTranslator,
|
|
LPCWSTR lpszPathIn,
|
|
__out_ecount(cchPathOutMax) LPWSTR lpszPathOut,
|
|
WORD cchPathOutMax,
|
|
WORD* pcchPathOut,
|
|
WORD fRequest,
|
|
LPDWORD lpdwUsageCount
|
|
);
|
|
|
|
#endif /* ODBCVER >= 0x0300 */
|
|
|
|
// Driver specific Setup APIs called by installer
|
|
|
|
BOOL INSTAPI ConfigDSNW (HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCWSTR lpszDriver,
|
|
LPCWSTR lpszAttributes);
|
|
|
|
|
|
#if (ODBCVER >= 0x0250)
|
|
|
|
|
|
BOOL INSTAPI ConfigDriverW
|
|
(
|
|
HWND hwndParent,
|
|
WORD fRequest,
|
|
LPCWSTR lpszDriver,
|
|
LPCWSTR lpszArgs,
|
|
__out_ecount(cchMsgMax) LPWSTR lpszMsg,
|
|
WORD cchMsgMax,
|
|
WORD* pcchMsgOut
|
|
);
|
|
|
|
#endif
|
|
|
|
#ifndef SQL_NOUNICODEMAP // define this to disable the mapping
|
|
#ifdef UNICODE
|
|
|
|
|
|
#define SQLInstallODBC SQLInstallODBCW
|
|
#define SQLCreateDataSource SQLCreateDataSourceW
|
|
#define SQLGetTranslator SQLGetTranslatorW
|
|
#define SQLInstallDriver SQLInstallDriverW
|
|
#define SQLInstallDriverManager SQLInstallDriverManagerW
|
|
#define SQLGetInstalledDrivers SQLGetInstalledDriversW
|
|
#define SQLGetAvailableDrivers SQLGetAvailableDriversW
|
|
#define SQLConfigDataSource SQLConfigDataSourceW
|
|
#define SQLWriteDSNToIni SQLWriteDSNToIniW
|
|
#define SQLRemoveDSNFromIni SQLRemoveDSNFromIniW
|
|
#define SQLValidDSN SQLValidDSNW
|
|
#define SQLWritePrivateProfileString SQLWritePrivateProfileStringW
|
|
#define SQLGetPrivateProfileString SQLGetPrivateProfileStringW
|
|
#define SQLInstallTranslator SQLInstallTranslatorW
|
|
#define SQLRemoveTranslator SQLRemoveTranslatorW
|
|
#define SQLRemoveDriver SQLRemoveDriverW
|
|
#define SQLConfigDriver SQLConfigDriverW
|
|
#define SQLInstallerError SQLInstallerErrorW
|
|
#define SQLPostInstallerError SQLPostInstallerErrorW
|
|
#define SQLReadFileDSN SQLReadFileDSNW
|
|
#define SQLWriteFileDSN SQLWriteFileDSNW
|
|
#define SQLInstallDriverEx SQLInstallDriverExW
|
|
#define SQLInstallTranslatorEx SQLInstallTranslatorExW
|
|
|
|
#endif // UNICODE
|
|
#endif // SQL_NOUNICODEMAP
|
|
|
|
#endif // RC_INVOKED
|
|
|
|
#ifdef __cplusplus
|
|
} // End of extern "C" {
|
|
#endif // __cplusplus
|
|
|
|
#endif // __ODBCINST_H
|
|
|