403 lines
9.2 KiB
C++
403 lines
9.2 KiB
C++
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Microsoft Windows
|
||
|
// Copyright (C) Microsoft Corporation, 1992 - 1996
|
||
|
//
|
||
|
// File: handle.hxx
|
||
|
//
|
||
|
// Contents: Defines CHandle
|
||
|
//
|
||
|
// Classes: CHandle
|
||
|
// CStgHandle
|
||
|
// CStmHandle
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
#ifndef __HANDLE_HXX__
|
||
|
#define __HANDLE_HXX__
|
||
|
|
||
|
#include "msf.hxx"
|
||
|
#include "msffunc.hxx"
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Class: CHandle (h)
|
||
|
//
|
||
|
// Purpose: An opaque handle to a directory entry-based object
|
||
|
//
|
||
|
// Interface: See below
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
class CStgHandle;
|
||
|
class CStmHandle;
|
||
|
|
||
|
class CHandle
|
||
|
{
|
||
|
public:
|
||
|
inline CHandle(void);
|
||
|
|
||
|
inline void Init(CMStream *pms,
|
||
|
SID sid);
|
||
|
|
||
|
inline BOOL IsRoot(void) const;
|
||
|
inline BOOL IsValid(void) const;
|
||
|
|
||
|
inline SCODE GetTime(WHICHTIME wt, TIME_T *ptm);
|
||
|
inline SCODE SetTime(WHICHTIME wt, TIME_T tm);
|
||
|
|
||
|
inline SCODE DestroyEntry(CDfName const *pdfn);
|
||
|
|
||
|
|
||
|
inline CMStream *GetMS(void) const;
|
||
|
inline SID GetSid(void) const;
|
||
|
|
||
|
private:
|
||
|
friend class CStgHandle;
|
||
|
friend class CStmHandle;
|
||
|
|
||
|
CMStream *_pms;
|
||
|
SID _sid;
|
||
|
};
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::CHandle, public
|
||
|
//
|
||
|
// Synopsis: NULL constructor
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline CHandle::CHandle(void)
|
||
|
{
|
||
|
_pms = NULL;
|
||
|
_sid = NOSTREAM;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::Init, public
|
||
|
//
|
||
|
// Synopsis: Sets internal data members
|
||
|
//
|
||
|
// Arguments: [pms] - Multistream
|
||
|
// [sid] - SID
|
||
|
//
|
||
|
// Returns: Appropriate status code
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline void CHandle::Init(CMStream *pms,
|
||
|
SID sid)
|
||
|
{
|
||
|
_pms = pms;
|
||
|
_sid = sid;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::IsRoot, public
|
||
|
//
|
||
|
// Synopsis: Whether this is a root handle or not
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline BOOL CHandle::IsRoot(void) const
|
||
|
{
|
||
|
return _sid == SIDROOT;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::IsValid, public
|
||
|
//
|
||
|
// Synopsis: Whether this handle has been initialized
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline BOOL CHandle::IsValid(void) const
|
||
|
{
|
||
|
return _pms != NULL;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::GetTime, public
|
||
|
//
|
||
|
// Synopsis: Returns the time
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CHandle::GetTime(WHICHTIME wt, TIME_T *ptm)
|
||
|
{
|
||
|
return _pms->GetTime(_sid, wt, ptm);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::SetTime, public
|
||
|
//
|
||
|
// Synopsis: Sets the time
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CHandle::SetTime(WHICHTIME wt, TIME_T tm)
|
||
|
{
|
||
|
return _pms->SetTime(_sid, wt, tm);
|
||
|
}
|
||
|
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::DestroyEntry, public
|
||
|
//
|
||
|
// Synopsis: Destroys this entry
|
||
|
//
|
||
|
// Returns: Appropriate status code
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CHandle::DestroyEntry(CDfName const *pdfn)
|
||
|
{
|
||
|
return _pms->DestroyEntry(_sid, pdfn);
|
||
|
}
|
||
|
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::GetMS, public
|
||
|
//
|
||
|
// Synopsis: Returns the multistream
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline CMStream *CHandle::GetMS(void) const
|
||
|
{
|
||
|
return _pms;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CHandle::GetSid, public
|
||
|
//
|
||
|
// Synopsis: Returns the sid
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SID CHandle::GetSid(void) const
|
||
|
{
|
||
|
return _sid;
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Class: CStgHandle, (stgh)
|
||
|
//
|
||
|
// Purpose: An opaque handle for Multistream directories
|
||
|
//
|
||
|
// Interface: See below
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
class CMSFIterator;
|
||
|
|
||
|
class CStgHandle : public CHandle
|
||
|
{
|
||
|
public:
|
||
|
inline SCODE CreateEntry(CDfName const *pdfnName,
|
||
|
MSENTRYFLAGS const mefFlags,
|
||
|
CHandle *ph);
|
||
|
inline SCODE GetEntry(CDfName const *pdfnName,
|
||
|
MSENTRYFLAGS const mefFlags,
|
||
|
CHandle *ph);
|
||
|
inline SCODE RenameEntry(CDfName const *pdfnName,
|
||
|
CDfName const *pdfnNewName);
|
||
|
inline SCODE IsEntry(CDfName const *pdfnName,
|
||
|
SEntryBuffer *peb);
|
||
|
inline SCODE GetIterator(CMSFIterator **ppi);
|
||
|
inline SCODE GetClass(CLSID *pclsid);
|
||
|
inline SCODE SetClass(REFCLSID clsid);
|
||
|
inline SCODE GetStateBits(DWORD *pgrfStateBits);
|
||
|
inline SCODE SetStateBits(DWORD grfStateBits, DWORD grfMask);
|
||
|
};
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::CreateEntry, public
|
||
|
//
|
||
|
// Synopsis: Creates an entry
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
|
||
|
inline SCODE CStgHandle::CreateEntry(CDfName const *pdfnName,
|
||
|
MSENTRYFLAGS const mefFlags,
|
||
|
CHandle *ph)
|
||
|
{
|
||
|
ph->_pms = _pms;
|
||
|
return _pms->CreateEntry(_sid, pdfnName, mefFlags, &ph->_sid);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::GetEntry, public
|
||
|
//
|
||
|
// Synopsis: Gets an entry
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
|
||
|
inline SCODE CStgHandle::GetEntry(CDfName const *pdfnName,
|
||
|
MSENTRYFLAGS const mefFlags,
|
||
|
CHandle *ph)
|
||
|
{
|
||
|
SCODE sc;
|
||
|
SEntryBuffer eb;
|
||
|
|
||
|
ph->_pms = _pms;
|
||
|
|
||
|
sc = _pms->IsEntry(_sid, pdfnName, &eb);
|
||
|
if (SUCCEEDED(sc))
|
||
|
{
|
||
|
msfAssert(eb.sid != NOSTREAM);
|
||
|
// entry exists but it may be the wrong type
|
||
|
|
||
|
if ((mefFlags != MEF_ANY) && (mefFlags != eb.dwType))
|
||
|
{
|
||
|
sc = STG_E_FILENOTFOUND;
|
||
|
}
|
||
|
else
|
||
|
ph->_sid = eb.sid;
|
||
|
}
|
||
|
return(sc);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::RenameEntry, public
|
||
|
//
|
||
|
// Synopsis: Renames an entry
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
|
||
|
inline SCODE CStgHandle::RenameEntry(CDfName const *pdfnName,
|
||
|
CDfName const *pdfnNewName)
|
||
|
{
|
||
|
return _pms->RenameEntry(_sid, pdfnName, pdfnNewName);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::IsEntry, public
|
||
|
//
|
||
|
// Synopsis: Gets entry info and checks for existence
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::IsEntry(CDfName const *pdfnName,
|
||
|
SEntryBuffer *peb)
|
||
|
{
|
||
|
return _pms->IsEntry(_sid, pdfnName, peb);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::GetIterator, public
|
||
|
//
|
||
|
// Synopsis: Gets an iterator
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::GetIterator(CMSFIterator **ppi)
|
||
|
{
|
||
|
return _pms->GetIterator(_sid, ppi);
|
||
|
}
|
||
|
|
||
|
//+---------------------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::GetClass, public
|
||
|
//
|
||
|
// Synopsis: Gets the class ID
|
||
|
//
|
||
|
//----------------------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::GetClass(CLSID *pclsid)
|
||
|
{
|
||
|
return _pms->GetClass(_sid, pclsid);
|
||
|
|
||
|
}
|
||
|
|
||
|
//+---------------------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::SetClass, public
|
||
|
//
|
||
|
// Synopsis: Sets the class ID
|
||
|
//
|
||
|
//----------------------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::SetClass(REFCLSID clsid)
|
||
|
{
|
||
|
return _pms->SetClass(_sid, clsid);
|
||
|
}
|
||
|
|
||
|
//+---------------------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::GetStateBits, public
|
||
|
//
|
||
|
// Synopsis: Gets state bits
|
||
|
//
|
||
|
//----------------------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::GetStateBits(DWORD *pgrfStateBits)
|
||
|
{
|
||
|
return _pms->GetStateBits(_sid, pgrfStateBits);
|
||
|
}
|
||
|
|
||
|
//+---------------------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStgHandle::SetStateBits, public
|
||
|
//
|
||
|
// Synopsis: Sets state bits
|
||
|
//
|
||
|
//----------------------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStgHandle::SetStateBits(DWORD grfStateBits, DWORD grfMask)
|
||
|
{
|
||
|
return _pms->SetStateBits(_sid, grfStateBits, grfMask);
|
||
|
}
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Class: CStmHandle, (stmh)
|
||
|
//
|
||
|
// Purpose: An opaque handle for Multistream streams
|
||
|
//
|
||
|
// Interface: See below
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
class CDirectStream;
|
||
|
|
||
|
class CStmHandle : public CHandle
|
||
|
{
|
||
|
public:
|
||
|
inline SCODE GetSize(ULONG *pcbSize);
|
||
|
};
|
||
|
|
||
|
//+--------------------------------------------------------------
|
||
|
//
|
||
|
// Member: CStmHandle::GetSize, public
|
||
|
//
|
||
|
// Synopsis: Gets the stream size
|
||
|
//
|
||
|
//---------------------------------------------------------------
|
||
|
|
||
|
inline SCODE CStmHandle::GetSize(ULONG *pcbSize)
|
||
|
{
|
||
|
return _pms->GetEntrySize(_sid, pcbSize);
|
||
|
}
|
||
|
|
||
|
#endif // #ifndef __HANDLE_HXX__
|
||
|
|