2020-09-30 17:12:29 +02:00

89 lines
2.9 KiB
C++

//+-------------------------------------------------------------------
//
// File: idtable.hxx
//
// Contents: internal identity table definitions.
//
// Description:
// The table consists, logically, of two different
// keys which map to the same value. The two
// keys are the object identity (oid) and the
// controlling unknown (pUnkControl). The value
// is the pointer to the identity interface.
//
// Additionally, if the apartment model is in use,
// the thread forms an additional part of both keys.
//
// Presently this is implemented as an array of the
// three values and linear scans are used for lookup.
// Neither of the pointers are addref'd (as far as the
// table is concerned). Lookup does addref and return
// a pointer to the identity object. The pUnkControl
// is used solely for lookup.
//
// Possible changes: use two separate maps, one of
// which is keyed by the oid and the other keyed
// by pUnkControl. The value in the first map is
// the hKey of value in the second map. The id object
// would hold the hKey of the value in the first map
// to save on space. Using two maps increases the
// speed of lookup for large numbers of ids, but
// increases the cost per id from 40bytes to 48bytes.
// (40 = 2 GUIDS + 2 far pointers; 48 = 1 GUID +
// 3 hKeys/ptrs + 16 bytes overhead for two hash
// buckets)
//
// It is also possible to use one map (keyed by
// the oid) and trim the array by the GUID. The
// cost per id is 40bytes (1 GUID + 1 hKey + 3 ptr +
// 8 bytes overhead for one hash bucket).
//
//
// History: 1-Dec-93 CraigWi Created
//
//--------------------------------------------------------------------
#ifndef __IDTABLE__
#define __IDTABLE__
#include <olerem.h>
#include <stdid.hxx> // CStdIdentity
#include <sem.hxx> // CMutexSem
// flags passed in on LookupIDFromUnk.
typedef enum tagIDLFLAGS
{
IDLF_CREATE = 0x01, // create if not found
IDLF_STRONG = 0x02, // add a strong connection
IDLF_NOPING = 0x04 // object wont be pinged
} IDLFLAGS;
// entry in id array. the array is packed (no NULL holes)
// NOTE: when looking up for the apartment model, we pair the two fields
// m_oid/m_tid and m_tid/m_pUnkControl;
struct IDENTRY
{
MOID m_moid; // OID + MID
DWORD m_tid;
IUnknown *m_pUnkControl;// not addref'd directly
CStdIdentity *m_pStdID; // not addref'd directly
};
#include <array_id.h>
// other functions declared in olerem.h
INTERNAL LookupIDFromUnk(IUnknown *pUnk, DWORD dwFlags, CStdIdentity **ppStdId);
INTERNAL LookupIDFromID(REFMOID moid, BOOL fAddRef, CStdIdentity **ppStdId);
INTERNAL SetObjectID(REFMOID moid, IUnknown *pUnkControl, CStdIdentity *pStdID);
INTERNAL ClearObjectID(REFMOID moid, IUnknown *pUnkControl, CStdIdentity *pStdID);
INTERNAL_(void) IDTableThreadUninitialize(void);
INTERNAL_(void) IDTableProcessUninitialize(void);
INTERNAL GetStaticUnMarshaler(IMarshal **ppMarshal);
#endif // __IDTABLE__