/** * This file has no copyright assigned and is placed in the Public Domain. * This file is part of the mingw-w64 runtime package. * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ #ifndef __DBDAO_H_ #define __DBDAO_H_ #ifndef __cplusplus #error This file can be used only in C++ #else class COleVariant; class CdbBookmark; class CdbException; class CdbOleObject; class CdbObject; class CdbError; class CdbProperty; class CdbDBEngine; class CdbWorkspace; class CdbDatabase; class CdbConnection; class CdbRecordset; class CdbGetRowsEx; class CdbQueryDef; class CdbTableDef; class CdbField; class CdbRelation; class CdbIndex; class CdbUser; class CdbGroup; class CdbDocument; class CdbContainer; class CdbParameter; class CdbCollection; class CdbErrors; class CdbProperties; class CdbWorkspaces; class CdbDatabases; class CdbConnections; class CdbRecordsets; class CdbQueryDefs; class CdbTableDefs; class CdbFields; class CdbRelations; class CdbIndexes; class CdbUsers; class CdbGroups; class CdbDocuments; class CdbContainers; class CdbParameters; class CdbBStr; const char szKEY[] = "mbmabptebkjcdlgtjmskjwtsdhjbmkmwtrak"; #define DAO_MAXSEEKFIELDS 13 class DLLEXPORT CdbBSTR { public: CONSTRUCTOR CdbBSTR(BSTR=NULL); DESTRUCTOR ~CdbBSTR(VOID); operator BSTR *(VOID); operator LPCTSTR(VOID); private: BSTR m_bstr; }; class CdbVariant : public COleVariant { public: CONSTRUCTOR CdbVariant(LONG l); CONSTRUCTOR CdbVariant(VOID); CONSTRUCTOR CdbVariant(LPCTSTR pstr); CONSTRUCTOR CdbVariant(SHORT s,WINBOOL bIsBool = FALSE); CONSTRUCTOR CdbVariant(LPVARIANT pv); CONSTRUCTOR CdbVariant(LPSAFEARRAY psa); VOID operator =(LPVARIANT pv); VOID operator =(LPCTSTR pstr); VOID operator =(SHORT s); VOID operator =(const int i); VOID operator =(LONG l); }; inline CONSTRUCTOR CdbVariant::CdbVariant(VOID) : COleVariant() { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } inline CdbVariant::CdbVariant(LONG l) { if(l==-1) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { vt = VT_I4; lVal = l; } } inline CONSTRUCTOR CdbVariant::CdbVariant(LPCTSTR pstr): COleVariant(pstr,VT_BSTRT) { if(!pstr) { VariantClear(this); vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } } inline CONSTRUCTOR CdbVariant::CdbVariant(SHORT s,WINBOOL bIsBool) : COleVariant(s) { if(bIsBool) { vt = VT_BOOL; boolVal = s; } else if(s==-1) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } } inline CONSTRUCTOR CdbVariant::CdbVariant(LPVARIANT pv) { if(!pv) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else VariantCopy(this,pv); } inline CONSTRUCTOR CdbVariant::CdbVariant(LPSAFEARRAY psa) { if(!psa) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { vt = VT_ARRAY|VT_UI1; parray = psa; } } inline VOID CdbVariant::operator =(LPVARIANT pv) { if(!pv) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else VariantCopy(this,pv); } inline VOID CdbVariant::operator =(LPCTSTR pstr) { if(!pstr) { VariantClear(this); vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { #if defined(UNICODE) bstrVal = SysAllocString(pstr); #else bstrVal = SysAllocStringByteLen(pstr,strlen(pstr)); #endif vt = VT_BSTR; } } inline VOID CdbVariant::operator =(SHORT s) { if(s==-1) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { vt = VT_I2; iVal = s; } } inline VOID CdbVariant::operator =(const int i) { if(i==-1) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { vt = VT_I2; iVal =(SHORT)i; } } inline VOID CdbVariant::operator =(LONG l) { if(l==-1) { vt = VT_ERROR; scode = DISP_E_PARAMNOTFOUND; } else { vt = VT_I4; lVal = l; } } HRESULT CdbWideFromAnsi(LPSTR,unsigned int,BSTR *); class CdbWide { public: CONSTRUCTOR CdbWide(LPSTR pstr,unsigned int cb=0) { CdbWideFromAnsi(pstr,(pstr ? (cb==0 ? strlen(pstr) : cb) : 0),&m_bstr); } DESTRUCTOR ~CdbWide() { SysFreeString(m_bstr); } operator LPWSTR() { return (LPWSTR)m_bstr; } operator LPSTR() { return (LPSTR)m_bstr; } ULONG cBytes() { return SysStringByteLen(m_bstr); } private: BSTR m_bstr; }; class DLLEXPORT CdbOleObject : public CObject { public: CONSTRUCTOR CdbOleObject(VOID); virtual DESTRUCTOR ~CdbOleObject(VOID); WINBOOL Exists(VOID); CdbOleObject &operator = (CdbOleObject &o); operator LPUNKNOWN(){ return GetInterface();} VOID SetInterface(LPUNKNOWN punk,WINBOOL bAddRef=FALSE); VOID SetInterface(REFIID riidClass,REFIID riidInterface); VOID SetInterfaceLic(REFIID riidClass,REFIID riidInterface); LPUNKNOWN GetInterface(WINBOOL bAddRef=FALSE,WINBOOL bThrowException=TRUE) const; virtual VOID OnInterfaceChange(VOID); VOID SetRichErrorInfo(LPOLESTR pstrSource,LPOLESTR pstrDescription,LPOLESTR pstrHelpFile,ULONG ulHelpID) const; protected: WINBOOL StartOLE(VOID); LPUNKNOWN m_punkInterface; }; class DLLEXPORT CdbCollection : public CdbOleObject { public: virtual CdbObject ObItem(LONG i) = 0; virtual CdbObject ObItem(LPCTSTR pstr) = 0; virtual LONG GetCount(VOID) = 0; virtual VOID ObAppend(CdbObject &obj) = 0; virtual VOID Delete(LPCTSTR pstr) = 0; virtual VOID Refresh(VOID) = 0; }; class DLLEXPORT CdbStaticCollection : public CdbCollection { public: CdbObject ObItem(LONG i); CdbObject ObItem(LPCTSTR pstr); LONG GetCount(VOID); VOID ObAppend(CdbObject &obj); VOID Delete(LPCTSTR pstr); VOID Refresh(VOID); }; class DLLEXPORT CdbDynamicCollection : public CdbCollection { public: CdbObject ObItem(LONG i); CdbObject ObItem(LPCTSTR pstr); LONG GetCount(VOID); VOID ObAppend(CdbObject &obj); VOID Delete(LPCTSTR pstr); VOID Refresh(VOID); }; #define DAOMFC_STATIC_COLLECTION_DECL(objColl,objSingle,intSingle) class DLLEXPORT objColl : public CdbStaticCollection { public: objSingle Item(LONG i); objSingle Item(LPCTSTR pstr); objSingle operator[](LONG i); objSingle operator[](LPCTSTR pstr); } #define DAOMFC_DYNAMIC_COLLECTION_DECL(objColl,objSingle,intSingle) class DLLEXPORT objColl : public CdbDynamicCollection { public: objSingle Item(LONG i); objSingle Item(LPCTSTR pstr); VOID Append(objSingle &o); objSingle operator[](LONG i); objSingle operator[](LPCTSTR pstr); } DAOMFC_STATIC_COLLECTION_DECL(CdbErrors,CdbError,DAOError); DAOMFC_STATIC_COLLECTION_DECL(CdbDatabases,CdbDatabase,DAODatabase); DAOMFC_STATIC_COLLECTION_DECL(CdbRecordsets,CdbRecordset,DAORecordset); DAOMFC_STATIC_COLLECTION_DECL(CdbParameters,CdbParameter,DAOParameter); DAOMFC_STATIC_COLLECTION_DECL(CdbDocuments,CdbDocument,DAODocument); DAOMFC_STATIC_COLLECTION_DECL(CdbContainers,CdbContainer,DAOContainer); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbProperties,CdbProperty,DAOProperty); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbFields,CdbField,DAOField); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbQueryDefs,CdbQueryDef,DAOQueryDef); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbTableDefs,CdbTableDef,DAOTableDef); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbIndexes,CdbIndex,DAOIndex); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbRelations,CdbRelation,DAORelation); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbUsers,CdbUser,DAOUser); DAOMFC_DYNAMIC_COLLECTION_DECL(CdbGroups,CdbGroup,DAOGroup); class DLLEXPORT CdbWorkspaces : public CdbDynamicCollection { friend CdbDBEngine; private: DAODBEngine *pDBEng; WINBOOL m_bDontStart; public: CONSTRUCTOR CdbWorkspaces(VOID){pDBEng = NULL;} CdbWorkspace Item(LONG i); CdbWorkspace Item(LPCTSTR pstr); VOID Append(CdbWorkspace &o); CdbWorkspace operator[](LONG i); CdbWorkspace operator[](LPCTSTR pstr); VOID SetDBEngine(DAODBEngine *peng){pDBEng = peng;} VOID GetDelayedInterface(); }; class DLLEXPORT CdbConnections : public CdbStaticCollection { public: CONSTRUCTOR CdbConnections(CdbConnections &Connections); CONSTRUCTOR CdbConnections() { pwrk = NULL; } CdbConnection Item(LONG i); CdbConnection Item(LPCTSTR pstr); CdbConnection operator[](LONG i); CdbConnection operator[](LPCTSTR pstr); CdbConnections &operator = (CdbConnections &o); LONG GetCount(VOID); VOID Refresh(VOID); VOID SetWorkspace(DAOWorkspace *pParent) { pwrk = pParent; } private: VOID CheckInterface(); DAOWorkspace *pwrk; }; class DLLEXPORT CdbObject : public CdbOleObject { public: CONSTRUCTOR CdbObject(VOID); CONSTRUCTOR CdbObject(LPUNKNOWN punk,WINBOOL bAddRef=FALSE); virtual CString GetName(VOID); virtual VOID SetName(LPCTSTR pstr); CdbProperties Properties; }; class DLLEXPORT CdbGetRowsEx : public CdbObject { public: CONSTRUCTOR CdbGetRowsEx(VOID); CONSTRUCTOR CdbGetRowsEx(ICDAORecordset *pGetRows,WINBOOL bAddRef=FALSE); CONSTRUCTOR CdbGetRowsEx(const CdbGetRowsEx &); CdbGetRowsEx &operator =(const CdbGetRowsEx &); VOID OnInterfaceChange(VOID); }; #define DAOVINIT(var) do { (var).vt = VT_ERROR; (var).scode = DISP_E_PARAMNOTFOUND; } while (0) #define STV(pstr) CdbVariant(pstr) #define STB(pstr) V_BSTR(((LPVARIANT)STV(pstr))) #define LTV(l) CdbVariant(l) #define OLTV(l) CdbVariant((l)) #define BTB(b) ((VARIANT_BOOL)(b?-1:0)) #define BTV(b) CdbVariant(BTB(b),TRUE) #define SHTV(s) CdbVariant((SHORT)s) #define VTV(pv) CdbVariant(pv) #define ATV(psa,var) do { if(!psa) { var.vt = VT_ERROR; var.scode = DISP_E_PARAMNOTFOUND; } else { var.vt = VT_ARRAY|VT_UI1; SafeArrayCopy(psa,&var.parray); } } while (0) #define DAOMFC_CALL(hr) do { HRESULT hresult = (hr); if(FAILED(hresult)) { TRACE0("\nDBDAO Call Failed.\n\t"); TRACE2("\nIn file %s on line %d\n",_T("DBDAO.CPP"),__LINE__); TRACE1("hResult = %X\n",hresult); if(GetScode(hresult)==E_OUTOFMEMORY) AfxThrowMemoryException(); else throw CdbException(hresult); } } while (0) #define LPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); LONG l = 0; DAOMFC_CALL(p->meth(&l)); return l; } while (0) #define LPROPSET(intDAO,meth,l) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(l)); } while(0) #define WPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); SHORT s = 0; DAOMFC_CALL(p->meth(&s)); return s; } while (0) #define WPROPSET(intDAO,meth,s) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(s)); } while(0) #define SPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); CdbBSTR bstr; DAOMFC_CALL(p->meth(bstr)); return bstr; } while (0) #define SPROPSET(intDAO,meth,s) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(STB(s))); } while(0) #define DPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); VARIANT Var; VariantInit(&Var); DAOMFC_CALL(p->meth(&Var)); return Var; } while (0) #define DPROPSET(intDAO,meth,pv) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(*pv)); } while(0) #define BPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); VARIANT_BOOL vb = 0; DAOMFC_CALL(p->meth(&vb)); return(WINBOOL)vb; } while (0) #define BPROPSET(intDAO,meth,b) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(BTB(b))); } while(0) #define VPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); COleVariant v; VariantInit(&v); DAOMFC_CALL(p->meth(&v)); return &v; } while (0) #define VPROPSET(intDAO,meth,pv) do { intDAO *p = (intDAO *)GetInterface(); DAOMFC_CALL(p->meth(*pv)); } while(0) #define DWPROPGET(intDAO,meth) do { intDAO *p = (intDAO *)GetInterface(); DWORD dw = 0; DAOMFC_CALL(p->meth(&dw)); return dw; } while (0) #define DAOMFC_STATIC_COLLECTION_IMPL(objColl,objSingle,intColl,intSingle) objSingle objColl::Item(LONG i) { return (intSingle *)(ObItem(i).GetInterface(TRUE)); } objSingle objColl::Item(LPCTSTR pstr) { return (intSingle *)(ObItem(pstr).GetInterface(TRUE)); } objSingle objColl::operator[](LONG i) { return (intSingle *)(Item(i).GetInterface(TRUE)); } objSingle objColl::operator[](LPCTSTR pstr) { return (intSingle *)(Item(pstr).GetInterface(TRUE)); } #define DAOMFC_DYNAMIC_COLLECTION_IMPL(objColl,objSingle,intColl,intSingle) objSingle objColl::Item(LONG i) { return (intSingle *)(ObItem(i).GetInterface(TRUE)); } objSingle objColl::Item(LPCTSTR pstr) { return (intSingle *)(ObItem(pstr).GetInterface(TRUE)); } VOID objColl::Append(objSingle &o) { ObAppend(o); } objSingle objColl::operator[](LONG i) { return (intSingle *)(Item(i).GetInterface(TRUE)); } objSingle objColl::operator[](LPCTSTR pstr) { return (intSingle *)(Item(pstr).GetInterface(TRUE)); } #undef INTERFACE #define INTERFACE DAOMFCSCollection DECLARE_INTERFACE_(DAOMFCSCollection,_DAOCollection) { #ifndef __cplusplus /* IUnknown methods */ STDMETHOD(QueryInterface)(THIS_ REFIID riid, void **ppvObject) PURE; STDMETHOD_(ULONG, AddRef)(THIS) PURE; STDMETHOD_(ULONG, Release)(THIS) PURE; /*** IDispatch methods ***/ STDMETHOD(GetTypeInfoCount)(THIS_ UINT *pctinfo); STDMETHOD(GetTypeInfo)(THIS_ UINT iTInfo, LCID lcid, ITypeInfo **ppTInfo); STDMETHOD(GetIDsOfNames)(THIS_ REFIID riid, LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId); STDMETHOD(Invoke)(THIS_ DISPID dispIdMember, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams, VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr); /*** _DAOCollection ***/ STDMETHOD(get_Count) (THIS_ short *c) PURE; STDMETHOD(_NewEnum) (THIS_ IUnknown **ppunk) PURE; STDMETHOD(Refresh) (THIS) PURE; #endif STDMETHOD(get_Item) (THIS_ VARIANT index,LPUNKNOWN *ppunk); }; #undef INTERFACE #define INTERFACE DAOMFCDCollection DECLARE_INTERFACE_(DAOMFCDCollection,_DAODynaCollection) { #ifndef __cplusplus /* IUnknown methods */ STDMETHOD(QueryInterface)(THIS_ REFIID riid, void **ppvObject) PURE; STDMETHOD_(ULONG, AddRef)(THIS) PURE; STDMETHOD_(ULONG, Release)(THIS) PURE; /*** IDispatch methods ***/ STDMETHOD(GetTypeInfoCount)(THIS_ UINT *pctinfo); STDMETHOD(GetTypeInfo)(THIS_ UINT iTInfo, LCID lcid, ITypeInfo **ppTInfo); STDMETHOD(GetIDsOfNames)(THIS_ REFIID riid, LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId); STDMETHOD(Invoke)(THIS_ DISPID dispIdMember, REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams, VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr); /*** _DAOCollection ***/ STDMETHOD(get_Count) (THIS_ short *c) PURE; STDMETHOD(_NewEnum) (THIS_ IUnknown **ppunk) PURE; STDMETHOD(Refresh) (THIS) PURE; /*** _DAODynaCollection ***/ STDMETHOD(Append) (THIS_ IDispatch *Object) PURE; STDMETHOD(Delete) (THIS_ BSTR Name) PURE; #endif STDMETHOD(get_Item) (THIS_ VARIANT index,LPUNKNOWN *ppunk); }; #endif /* __cplusplus */ #endif