HrIStorageFromStream

The HrIStorageFromStream function layers an IStorage interface onto an IStream object.

Quick Info

Header file: MAPIUTIL.H
Implemented by: MAPI
Called by: Client applications and service providers

HRESULT HrIStorageFromStream(
  LPUNKNOWN lpUnkIn,             
  PIID lpInterface,              
  ULONG ulFlags,                 
  LPSTORAGE FAR * lppStorageOut  
);
 

Parameters

lpUnkIn
[in] Pointer to the IUnknown object implementing IStream.
lpInterface
[in] Pointer to the interface identifier (IID) for the stream object. Any of the following values can be passed in the lpInterface parameter: NULL, IID_IStream, or IID_ILockBytes. Passing NULL in lpInterface is the same as passing IID_IStream.
ulFlags
[in] Bitmask of flags that controls how the storage object is to be created relative to the stream. The default setting is STGSTRM_RESET, which gives the storage object read-only access and starts it at position zero of the stream. The following flags can be set in any combination, except as noted:
STGSTRM_CREATE
Creates a new storage object for the stream object. This flag cannot be set if the STGSTRM_RESET flag is set.
STGSTRM_CURRENT
Starts storage at the current position of the stream. This flag cannot be set if the STGSTRM_RESET flag is set.
STGSTRM_MODIFY
Allows the calling service provider to write to the returned storage. This flag cannot be set if the STGSTRM_RESET flag is set.
STGSTRM_RESET
Starts storage at position zero. This flag cannot be set if any other flag is set.
lppStorageOut
[out] Pointer to a pointer to the returned IStorage object.

Return Values

S_OK
The call succeeded and has returned the expected value or values.

Remarks

Message store providers support the HrIStorageFromStream function using the IStorage interface for attachments. Store providers must implement the IStream interface. HrIStorageFromStream provides the IStorage interface for the IStream object. It is possible to pass either an ILockBytes or an IStream interface in lpUnkIn.

See Also

IStorage Functions