/**
* 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