Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//-----------------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995
//
// File: caccess.hxx
//
// Contents: Microsoft OleDB/OleDS Data Source Object for ADSI
//
// CImpIAccessor object implementing the IAccessor interface.
//
// History: 08-01-96 shanksh Created.
//
//----------------------------------------------------------------------------
#ifndef _CACCESS_HXX
#define _CACCESS_HXX
// ADSI accessor structure
typedef struct tagADSACCESSOR { DBACCESSORFLAGS dwFlags; // accessor flags
DBREFCOUNT cRef; // reference count of the accessor
DBLENGTH cbRowSize; // size of the row in the client's buffer
DBORDINAL *rgcol; // array of cols referenced by the accessor
DBCOUNTITEM cBindings; // # of bindings
DBBINDING rgBindings[1];// array of binding structs
} ADSACCESSOR;
typedef ADSACCESSOR *PADSACCESSOR;
//-----------------------------------------------------------------------------------
//
// class CImpIAccessor | Contained IAccessor class
//
//-----------------------------------------------------------------------------------
class CImpIAccessor : INHERIT_TRACKING, public IAccessor // public | IAccessor
{ // Immediate user objects are friends
friend class CCommandObject;
private: void *_pObj; LPUNKNOWN _pUnkOuter; ULONG _dwStatus; // status dword
LPEXTBUFF _pextbuffer; // array of accessor ptrs
ULONG _dwGetDataTypeBadHandle; // specifies bad handle accessor type
CRITICAL_SECTION _criticalsectionAccessor;// critical section for CreateAccessor calls
IDataConvert *_pIDC; IMalloc *_pIMalloc;
STDMETHODIMP_(void) DetermineTypes ( DBACCESSORFLAGS dwAccessorFlags, ULONG *pdwGetDataType, ULONG *pdwSetDataType );
STDMETHODIMP_(void) DeleteADsAccessor ( PADSACCESSOR pADsaccessor );
public: CImpIAccessor(void *, LPUNKNOWN); ~CImpIAccessor(void);
DECLARE_STD_REFCOUNTING
STDMETHOD(QueryInterface)(THIS_ REFIID riid, LPVOID FAR* ppvObj) ;
STDMETHODIMP FInit ( void );
STDMETHODIMP AddRefAccessor( HACCESSOR hAccessor, DBREFCOUNT *pcRefCounts );
STDMETHODIMP CreateAccessor( DBACCESSORFLAGS dwAccessorFlags, DBCOUNTITEM cBindings, const DBBINDING rgBindings[], DBLENGTH cbRowSize, HACCESSOR *phAccessor, DBBINDSTATUS rgStatus[] );
STDMETHODIMP GetBindings( HACCESSOR hAccessor, DBACCESSORFLAGS *pdwAccessorFlags, DBCOUNTITEM *pcBindings, DBBINDING **prgBindings );
STDMETHODIMP ReleaseAccessor( HACCESSOR hAccessor, DBREFCOUNT *pcRefCounts );
// Verifies that a DB type used in a binding is supported.
inline STDMETHODIMP_(BOOL) IsGoodBindingType( DBTYPE dbtype ) { switch ((dbtype & ~(DBTYPE_ARRAY|DBTYPE_BYREF|DBTYPE_VECTOR))) { case DBTYPE_I1: case DBTYPE_UI1: case DBTYPE_I2: case DBTYPE_UI2: case DBTYPE_I4: case DBTYPE_UI4: case DBTYPE_I8: case DBTYPE_UI8: case DBTYPE_R4: case DBTYPE_R8: case DBTYPE_CY: case DBTYPE_GUID: case DBTYPE_BOOL: case DBTYPE_VARIANT: case DBTYPE_DATE: case DBTYPE_DBDATE: case DBTYPE_DBTIME: case DBTYPE_DBTIMESTAMP: case DBTYPE_BSTR: case DBTYPE_STR: case DBTYPE_WSTR: case DBTYPE_BYTES: case DBTYPE_NUMERIC: case DBTYPE_IUNKNOWN: return TRUE; break;
default: return FALSE; } }
HRESULT CreateBadAccessor(void);
};
// Accessor status flags (_dwStatus)
//const UDWORD ACCESSORSTAT_UNDERROWSET =0x00000001L;// aggregated under Rowset object
const ULONG ACCESSORSTAT_VALIDATENOW =0x00000002L;// accessors totally validated on
const ULONG ACCESSORSTAT_CANACCESSBLOBS=0x00000004L;// can create accessors for BLOBS
//------ D E F I N E S, M A C R O S A N D I N L I N E F U N C T I O N S -------
// Internal accessor type classifications
// Common types
// Marks an incorrect accessor.
#define ACCESSORTYPE_INERROR 0
// Types used by GetData.
#define GD_ACCESSORTYPE_INERROR ACCESSORTYPE_INERROR
#define GD_ACCESSORTYPE_PARAM_ONLY 1
#define GD_ACCESSORTYPE_READ_BYREF 2
#define GD_ACCESSORTYPE_READ_COLS_BYREF 3
#define GD_ACCESSORTYPE_READ_OPTIMIZED 4
#define GD_ACCESSORTYPE_READ 5
// First good GetData type.
#define GD_ACCESSORTYPE_GOOD GD_ACCESSORTYPE_READ_BYREF
// Types used by SetData.
#define SD_ACCESSORTYPE_INERROR ACCESSORTYPE_INERROR
#define SD_ACCESSORTYPE_PARAM_ONLY 1
#define SD_ACCESSORTYPE_READ_ONLY 2
#define SD_ACCESSORTYPE_READWRITE 3
const ULONG DBACCESSOR_VALID_FLAGS = (DBACCESSOR_PASSBYREF|DBACCESSOR_ROWDATA| DBACCESSOR_PARAMETERDATA|DBACCESSOR_OPTIMIZED);
const DBTYPE TYPE_MODIFIERS = (DBTYPE_BYREF | DBTYPE_VECTOR | DBTYPE_ARRAY);
const ULONG INITIAL_NUM_PARAM =256;
// Zero element of the extbuffer of accessors always represents an invalid accessor.
const ULONG_PTR hAccessorBadHandle =0;
// Internal DBACCESSOR flag to mark accessors referencing BLOB columns.
const DBACCESSORFLAGS DBACCESSOR_REFERENCES_BLOB =0x8000;
#endif
|