2020-09-30 16:53:55 +02:00

102 lines
4.2 KiB
C++

//
// dmstrm.h
//
// Copyright (c) 1995-1998 Microsoft Corporation. All rights reserved.
//
#ifndef DMSTRM_H
#define DMSTRM_H
DEFINE_GUID(IID_IDMStream, 0x1894c260, 0xaa21, 0x11d1, 0x86, 0xbc, 0x0, 0xc0, 0x4f, 0xbf, 0x8f, 0xef);
DECLARE_INTERFACE_(IDMStream, IUnknown)
{
// IUnknown
STDMETHOD(QueryInterface) (THIS_ REFIID, LPVOID FAR *) PURE;
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
STDMETHOD_(ULONG,Release) (THIS) PURE;
// IDMStream
STDMETHOD(Init) (THIS_ IStream* pStream) PURE;
STDMETHOD(Descend) (THIS_ LPMMCKINFO lpck, LPMMCKINFO lpckParent, UINT wFlags) PURE;
STDMETHOD(Ascend) (THIS_ LPMMCKINFO lpck, UINT wFlags) PURE;
STDMETHOD(CreateChunk) (THIS_ LPMMCKINFO lpck, UINT wFlags) PURE;
STDMETHOD(SetStream) (THIS_ IStream* pIStream) PURE;
STDMETHOD_(IStream*, GetStream) (THIS) PURE;
};
STDAPI AllocDirectMusicStream(IStream* pIStream, IDMStream** ppIDMStream);
class CDirectMusicStream : public IDMStream
{
public:
CDirectMusicStream();
~CDirectMusicStream();
STDMETHODIMP Init(IStream* pStream);
// IUnknown
STDMETHODIMP QueryInterface(REFIID riid, LPVOID *ppvObj);
STDMETHODIMP_(ULONG) AddRef();
STDMETHODIMP_(ULONG) Release();
// IDMStream
STDMETHODIMP Descend(LPMMCKINFO lpck, LPMMCKINFO lpckParent, UINT wFlags);
STDMETHODIMP Ascend(LPMMCKINFO lpck, UINT wFlags);
STDMETHODIMP CreateChunk(LPMMCKINFO lpck, UINT wFlags);
STDMETHODIMP SetStream(IStream* pStream);
STDMETHODIMP_(IStream*) GetStream();
private:
long m_cRef; // object reference count
IStream* m_pStream; // stream to operate on
};
// Macro to round up an odd size to RIFF 16 bit boundary.
#define RIFF_ALIGN(dwSize) (dwSize + (dwSize & 1))
typedef struct _RIFFIO
{
FOURCC ckid; /* chunk ID */
long cksize; /* chunk size */
FOURCC fccType; /* form type or list type */
long lRead; /* How much of this chunk has been read so far. */
_RIFFIO * pParent; /* pointer to parent chunk */
LARGE_INTEGER liPosition; /* Filled in by MarkPosition() when handing stream to another component. */
} RIFFIO;
class CRiffParser
{
public:
CRiffParser(IStream *pStream);
void DebugOn() { m_fDebugOn = TRUE; } // Turns on tracing of parsing. Only available in debug builds.
BOOL NextChunk(HRESULT * pHr); // Does the work of LeaveChunk, MoreChunks, and EnterChunk in one call.
void EnterList(RIFFIO *pChunk); // Descend into a new list.
void LeaveList(); // Pop out of the current list.
BOOL MoreChunks(); // Returns true if there are more chunks to process in this LIST or RIFF.
HRESULT EnterChunk(); // Reads header of next chunk in this LIST or RIFF container.
HRESULT LeaveChunk(); // Move to the end of the current chunk in the LIST or RIFF.
void MarkPosition(); // Stores the absolute position of the start of the current chunk.
HRESULT SeekBack(); // Scan back to the beginning of the current chunk.
HRESULT SeekForward(); // Scan forward to the end of the current chunk.
HRESULT Read(void *pv,ULONG cb); // Reads data from stream.
HRESULT Skip(ULONG ulBytes); // Seeks forward ulBytes.
void EnteringComponent() { m_fInComponent = true; }
BOOL ComponentFailed() { return m_fComponentFailed; }
IStream * GetStream() { return m_pStream; }
private:
BOOL m_fDebugOn; // Set true to turn tracing of parsing on.
BOOL m_fFirstPass; // Used by NextChunk to understand whether this is the first time in the list.
IStream * m_pStream; // Stream to operate on.
RIFFIO * m_pChunk; // Current chunk that we are in.
RIFFIO * m_pParent; // Parent chunk of current chunk.
long m_lRead; // How far we've read in the current chunk.
BOOL m_fComponentFailed; // Set true if a component failed to load, yet the file is okay.
BOOL m_fInComponent; // Set to true when inside a component's chunk.
};
#endif // #ifndef DMSTRM_H