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_wave/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_wave/RawReader.h')
-rw-r--r-- | Src/Plugins/Input/in_wave/RawReader.h | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/Src/Plugins/Input/in_wave/RawReader.h b/Src/Plugins/Input/in_wave/RawReader.h new file mode 100644 index 00000000..55697cf2 --- /dev/null +++ b/Src/Plugins/Input/in_wave/RawReader.h @@ -0,0 +1,39 @@ +#pragma once +#include "../Agave/DecodeFile/svc_raw_media_reader.h" +#include "../Agave/DecodeFile/ifc_raw_media_reader.h" +#include "main.h" + +// {4FB808DC-C327-4999-9822-BDDDE20F44B0} +static const GUID sndfile_raw_reader_guid = +{ 0x4fb808dc, 0xc327, 0x4999, { 0x98, 0x22, 0xbd, 0xdd, 0xe2, 0xf, 0x44, 0xb0 } }; + + +class RawMediaReaderService : public svc_raw_media_reader +{ +public: + static const char *getServiceName() { return "SndFile Raw Reader"; } + static GUID getServiceGuid() { return sndfile_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(const wchar_t *filename); + int Read(void *buffer, size_t buffer_size, size_t *bytes_read); + size_t Release(); + +protected: + RECVS_DISPATCH; + +private: + SNDFILE *soundFile = NULL; + SF_INFO info; +}; |