diff options
author | Jean-Francois Mauguit <jfmauguit@mac.com> | 2024-09-24 09:03:25 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-24 09:03:25 -0400 |
commit | bab614c421ed7ae329d26bf028c4a3b1d2450f5a (patch) | |
tree | 12f17f78986871dd2cfb0a56e5e93b545c1ae0d0 /Src/Plugins/Input/in_wmvdrm/RawReader.h | |
parent | 4bde6044fddf053f31795b9eaccdd2a5a527d21f (diff) | |
parent | 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d (diff) | |
download | winamp-bab614c421ed7ae329d26bf028c4a3b1d2450f5a.tar.gz |
Merge pull request #5 from WinampDesktop/community
Merge to main
Diffstat (limited to 'Src/Plugins/Input/in_wmvdrm/RawReader.h')
-rw-r--r-- | Src/Plugins/Input/in_wmvdrm/RawReader.h | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/Src/Plugins/Input/in_wmvdrm/RawReader.h b/Src/Plugins/Input/in_wmvdrm/RawReader.h new file mode 100644 index 00000000..f7d2e80b --- /dev/null +++ b/Src/Plugins/Input/in_wmvdrm/RawReader.h @@ -0,0 +1,40 @@ +#pragma once +#include "../Agave/DecodeFile/svc_raw_media_reader.h" +#include "../Agave/DecodeFile/ifc_raw_media_reader.h" +#include <mmreg.h> +#include <wmsdk.h> + +// {9AF5FD89-DC41-4F2A-A156-8D1399FDE57B} +static const GUID wm_raw_reader_guid = +{ 0x9af5fd89, 0xdc41, 0x4f2a, { 0xa1, 0x56, 0x8d, 0x13, 0x99, 0xfd, 0xe5, 0x7b } }; + +class RawMediaReaderService : public svc_raw_media_reader +{ +public: + static const char *getServiceName() { return "Windows Media Audio Raw Reader"; } + static GUID getServiceGuid() { return wm_raw_reader_guid; } + int CreateRawMediaReader(const wchar_t *filename, ifc_raw_media_reader **reader); +protected: + RECVS_DISPATCH; +}; + +class RawMediaReader : public ifc_raw_media_reader +{ +public: + RawMediaReader(); + ~RawMediaReader(); + int Initialize(IWMSyncReader *reader); + int Read(void *buffer, size_t buffer_size, size_t *bytes_read); + size_t Release(); +protected: + RECVS_DISPATCH; +private: + IWMSyncReader *reader; + WORD stream_num; + + INSSBuffer *buffer; + size_t buffer_used; + bool end_of_file; + QWORD length; + DWORD next_output; +}; |