diff options
Diffstat (limited to 'Src/pcm')
-rw-r--r-- | Src/pcm/api.h | 5 | ||||
-rw-r--r-- | Src/pcm/avi_alaw_decoder.cpp | 95 | ||||
-rw-r--r-- | Src/pcm/avi_alaw_decoder.h | 21 | ||||
-rw-r--r-- | Src/pcm/avi_pcm_decoder.cpp | 88 | ||||
-rw-r--r-- | Src/pcm/avi_pcm_decoder.h | 36 | ||||
-rw-r--r-- | Src/pcm/avi_ulaw_decoder.cpp | 95 | ||||
-rw-r--r-- | Src/pcm/avi_ulaw_decoder.h | 21 | ||||
-rw-r--r-- | Src/pcm/main.cpp | 78 | ||||
-rw-r--r-- | Src/pcm/mp4_ulaw_decoder.cpp | 98 | ||||
-rw-r--r-- | Src/pcm/mp4_ulaw_decoder.h | 26 | ||||
-rw-r--r-- | Src/pcm/pcm.rc | 76 | ||||
-rw-r--r-- | Src/pcm/pcm.sln | 31 | ||||
-rw-r--r-- | Src/pcm/pcm.vcxproj | 251 | ||||
-rw-r--r-- | Src/pcm/pcm.vcxproj.filters | 56 | ||||
-rw-r--r-- | Src/pcm/resource.h | 14 | ||||
-rw-r--r-- | Src/pcm/version.rc2 | 39 |
16 files changed, 1030 insertions, 0 deletions
diff --git a/Src/pcm/api.h b/Src/pcm/api.h new file mode 100644 index 00000000..6555c035 --- /dev/null +++ b/Src/pcm/api.h @@ -0,0 +1,5 @@ +#pragma once + +#include <api/service/api_service.h> +extern api_service *serviceManager; +#define WASABI_API_SVC serviceManager diff --git a/Src/pcm/avi_alaw_decoder.cpp b/Src/pcm/avi_alaw_decoder.cpp new file mode 100644 index 00000000..51b8771d --- /dev/null +++ b/Src/pcm/avi_alaw_decoder.cpp @@ -0,0 +1,95 @@ +#include "avi_alaw_decoder.h" + +static int16_t ALawDecompressTable[256] = +{ + -5504, -5248, -6016, -5760, -4480, -4224, -4992, -4736, + -7552, -7296, -8064, -7808, -6528, -6272, -7040, -6784, + -2752, -2624, -3008, -2880, -2240, -2112, -2496, -2368, + -3776, -3648, -4032, -3904, -3264, -3136, -3520, -3392, + -22016,-20992,-24064,-23040,-17920,-16896,-19968,-18944, + -30208,-29184,-32256,-31232,-26112,-25088,-28160,-27136, + -11008,-10496,-12032,-11520,-8960, -8448, -9984, -9472, + -15104,-14592,-16128,-15616,-13056,-12544,-14080,-13568, + -344, -328, -376, -360, -280, -264, -312, -296, + -472, -456, -504, -488, -408, -392, -440, -424, + -88, -72, -120, -104, -24, -8, -56, -40, + -216, -200, -248, -232, -152, -136, -184, -168, + -1376, -1312, -1504, -1440, -1120, -1056, -1248, -1184, + -1888, -1824, -2016, -1952, -1632, -1568, -1760, -1696, + -688, -656, -752, -720, -560, -528, -624, -592, + -944, -912, -1008, -976, -816, -784, -880, -848, + 5504, 5248, 6016, 5760, 4480, 4224, 4992, 4736, + 7552, 7296, 8064, 7808, 6528, 6272, 7040, 6784, + 2752, 2624, 3008, 2880, 2240, 2112, 2496, 2368, + 3776, 3648, 4032, 3904, 3264, 3136, 3520, 3392, + 22016, 20992, 24064, 23040, 17920, 16896, 19968, 18944, + 30208, 29184, 32256, 31232, 26112, 25088, 28160, 27136, + 11008, 10496, 12032, 11520, 8960, 8448, 9984, 9472, + 15104, 14592, 16128, 15616, 13056, 12544, 14080, 13568, + 344, 328, 376, 360, 280, 264, 312, 296, + 472, 456, 504, 488, 408, 392, 440, 424, + 88, 72, 120, 104, 24, 8, 56, 40, + 216, 200, 248, 232, 152, 136, 184, 168, + 1376, 1312, 1504, 1440, 1120, 1056, 1248, 1184, + 1888, 1824, 2016, 1952, 1632, 1568, 1760, 1696, + 688, 656, 752, 720, 560, 528, 624, 592, + 944, 912, 1008, 976, 816, 784, 880, 848 +}; + +AVIALawDecoder::AVIALawDecoder(const nsavi::audio_format *waveformat) : waveformat(waveformat) +{ +} + +int AVIALawDecoder::OutputFrameSize(size_t *frame_size) +{ + *frame_size = waveformat->block_align; // TODO + return AVI_SUCCESS; +} + +int AVIALawDecoder::GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat) +{ + if (waveformat) + { + *sampleRate = waveformat->sample_rate; + *channels = waveformat->channels; + *bitsPerSample = 16; + *isFloat = false; // TODO + return AVI_SUCCESS; + } + else + { + return AVI_FAILURE; + } +} + +int AVIALawDecoder::DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes) +{ +size_t num_samples = min(*inputBufferBytes, *outputBufferBytes / 2); + const uint8_t *in = (const uint8_t *)*inputBuffer; + + int16_t *out = (int16_t *)outputBuffer; + for (size_t i=0;i!=num_samples;i++) + { + out[i] = ALawDecompressTable[in[i]]; + } + + *outputBufferBytes = num_samples * 2; + *inputBufferBytes -= num_samples; + *inputBuffer = (uint8_t *)inputBuffer + num_samples; + + return AVI_SUCCESS; +} + +void AVIALawDecoder::Close() +{ + delete this; +} + +#define CBCLASS AVIALawDecoder +START_DISPATCH; +CB(OUTPUT_FRAME_SIZE, OutputFrameSize) +CB(GET_OUTPUT_PROPERTIES, GetOutputProperties) +CB(DECODE_CHUNK, DecodeChunk) +VCB(CLOSE, Close) +END_DISPATCH; +#undef CBCLASS
\ No newline at end of file diff --git a/Src/pcm/avi_alaw_decoder.h b/Src/pcm/avi_alaw_decoder.h new file mode 100644 index 00000000..38ad23f4 --- /dev/null +++ b/Src/pcm/avi_alaw_decoder.h @@ -0,0 +1,21 @@ +#pragma once +#include "../nsavi/avi_header.h" +#include "../Plugins/Input/in_avi/ifc_aviaudiodecoder.h" + +class AVIALawDecoder : public ifc_aviaudiodecoder +{ +public: + AVIALawDecoder(const nsavi::audio_format *waveformat); + +protected: + RECVS_DISPATCH; +private: + /* ifc_aviaudiodecoder implementation */ + int OutputFrameSize(size_t *frame_size); + int GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat); + int DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes); + void Close(); + +private: + const nsavi::audio_format *waveformat; +};
\ No newline at end of file diff --git a/Src/pcm/avi_pcm_decoder.cpp b/Src/pcm/avi_pcm_decoder.cpp new file mode 100644 index 00000000..d3e4ba73 --- /dev/null +++ b/Src/pcm/avi_pcm_decoder.cpp @@ -0,0 +1,88 @@ +#include "avi_pcm_decoder.h" +#include "avi_alaw_decoder.h" +#include "avi_ulaw_decoder.h" + +int AVIDecoder::CreateAudioDecoder(const nsavi::AVIH *avi_header, + const nsavi::STRH *stream_header, const nsavi::STRF *stream_format, const nsavi::STRD *stream_data, + unsigned int preferred_bits, unsigned int max_channels, bool floating_point, + ifc_aviaudiodecoder **decoder) +{ + nsavi::audio_format *waveformat = (nsavi::audio_format *)stream_format; + + if (waveformat->format == nsavi::audio_format_pcm || waveformat->format == nsavi::audio_format_extensible) + { + *decoder = new AVIPCMDecoder(waveformat); + return CREATEDECODER_SUCCESS; + } + else if (waveformat->format == nsavi::audio_format_alaw) + { + *decoder = new AVIALawDecoder(waveformat); + return CREATEDECODER_SUCCESS; + } + else if (waveformat->format == nsavi::audio_format_ulaw) + { + *decoder = new AVIULawDecoder(waveformat); + return CREATEDECODER_SUCCESS; + } + + return CREATEDECODER_NOT_MINE; + +} + +#define CBCLASS AVIDecoder +START_DISPATCH; +CB(CREATE_AUDIO_DECODER, CreateAudioDecoder) +END_DISPATCH; +#undef CBCLASS + +AVIPCMDecoder::AVIPCMDecoder(const nsavi::audio_format *waveformat) : waveformat(waveformat) +{ +} + +int AVIPCMDecoder::OutputFrameSize(size_t *frame_size) +{ + *frame_size = waveformat->block_align; // TODO + return AVI_SUCCESS; +} + +int AVIPCMDecoder::GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat) +{ + if (waveformat) + { + *sampleRate = waveformat->sample_rate; + *channels = waveformat->channels; + *bitsPerSample = waveformat->bits_per_sample; + *isFloat = false; // TODO + return AVI_SUCCESS; + } + else + { + return AVI_FAILURE; + } +} + +int AVIPCMDecoder::DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes) +{ + size_t copy_size = min(*inputBufferBytes, *outputBufferBytes); + int remainder = copy_size % waveformat->block_align; + copy_size -= remainder; + memcpy(outputBuffer, *inputBuffer, copy_size); + *inputBuffer = (uint8_t *)(*inputBuffer) + copy_size; + *inputBufferBytes = *inputBufferBytes - copy_size; + *outputBufferBytes = copy_size; + return AVI_SUCCESS; +} + +void AVIPCMDecoder::Close() +{ + delete this; +} + +#define CBCLASS AVIPCMDecoder +START_DISPATCH; +CB(OUTPUT_FRAME_SIZE, OutputFrameSize) +CB(GET_OUTPUT_PROPERTIES, GetOutputProperties) +CB(DECODE_CHUNK, DecodeChunk) +VCB(CLOSE, Close) +END_DISPATCH; +#undef CBCLASS
\ No newline at end of file diff --git a/Src/pcm/avi_pcm_decoder.h b/Src/pcm/avi_pcm_decoder.h new file mode 100644 index 00000000..3e598f07 --- /dev/null +++ b/Src/pcm/avi_pcm_decoder.h @@ -0,0 +1,36 @@ +#pragma once +#include "../Plugins/Input/in_avi/svc_avidecoder.h" +#include "../Plugins/Input/in_avi/ifc_aviaudiodecoder.h" + +// {739A9D4E-2235-4298-AA4F-2E9F1B5DE8EC} +static const GUID avi_pcm_guid = +{ 0x739a9d4e, 0x2235, 0x4298, { 0xaa, 0x4f, 0x2e, 0x9f, 0x1b, 0x5d, 0xe8, 0xec } }; + + +class AVIDecoder : public svc_avidecoder +{ +public: + static const char *getServiceName() { return "PCM AVI Decoder"; } + static GUID getServiceGuid() { return avi_pcm_guid; } + int CreateAudioDecoder(const nsavi::AVIH *avi_header, const nsavi::STRH *stream_header, const nsavi::STRF *stream_format, const nsavi::STRD *stream_data, unsigned int preferred_bits, unsigned int max_channels, bool floating_point, ifc_aviaudiodecoder **decoder); +protected: + RECVS_DISPATCH; +}; + +class AVIPCMDecoder : public ifc_aviaudiodecoder +{ +public: + AVIPCMDecoder(const nsavi::audio_format *waveformat); + +protected: + RECVS_DISPATCH; +private: + /* ifc_aviaudiodecoder implementation */ + int OutputFrameSize(size_t *frame_size); + int GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat); + int DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes); + void Close(); + +private: + const nsavi::audio_format *waveformat; +};
\ No newline at end of file diff --git a/Src/pcm/avi_ulaw_decoder.cpp b/Src/pcm/avi_ulaw_decoder.cpp new file mode 100644 index 00000000..1fe04159 --- /dev/null +++ b/Src/pcm/avi_ulaw_decoder.cpp @@ -0,0 +1,95 @@ +#include "avi_ulaw_decoder.h" + +static int16_t MuLawDecompressTable[256] = +{ + -32124,-31100,-30076,-29052,-28028,-27004,-25980,-24956, + -23932,-22908,-21884,-20860,-19836,-18812,-17788,-16764, + -15996,-15484,-14972,-14460,-13948,-13436,-12924,-12412, + -11900,-11388,-10876,-10364, -9852, -9340, -8828, -8316, + -7932, -7676, -7420, -7164, -6908, -6652, -6396, -6140, + -5884, -5628, -5372, -5116, -4860, -4604, -4348, -4092, + -3900, -3772, -3644, -3516, -3388, -3260, -3132, -3004, + -2876, -2748, -2620, -2492, -2364, -2236, -2108, -1980, + -1884, -1820, -1756, -1692, -1628, -1564, -1500, -1436, + -1372, -1308, -1244, -1180, -1116, -1052, -988, -924, + -876, -844, -812, -780, -748, -716, -684, -652, + -620, -588, -556, -524, -492, -460, -428, -396, + -372, -356, -340, -324, -308, -292, -276, -260, + -244, -228, -212, -196, -180, -164, -148, -132, + -120, -112, -104, -96, -88, -80, -72, -64, + -56, -48, -40, -32, -24, -16, -8, 0, + 32124, 31100, 30076, 29052, 28028, 27004, 25980, 24956, + 23932, 22908, 21884, 20860, 19836, 18812, 17788, 16764, + 15996, 15484, 14972, 14460, 13948, 13436, 12924, 12412, + 11900, 11388, 10876, 10364, 9852, 9340, 8828, 8316, + 7932, 7676, 7420, 7164, 6908, 6652, 6396, 6140, + 5884, 5628, 5372, 5116, 4860, 4604, 4348, 4092, + 3900, 3772, 3644, 3516, 3388, 3260, 3132, 3004, + 2876, 2748, 2620, 2492, 2364, 2236, 2108, 1980, + 1884, 1820, 1756, 1692, 1628, 1564, 1500, 1436, + 1372, 1308, 1244, 1180, 1116, 1052, 988, 924, + 876, 844, 812, 780, 748, 716, 684, 652, + 620, 588, 556, 524, 492, 460, 428, 396, + 372, 356, 340, 324, 308, 292, 276, 260, + 244, 228, 212, 196, 180, 164, 148, 132, + 120, 112, 104, 96, 88, 80, 72, 64, + 56, 48, 40, 32, 24, 16, 8, 0 +}; + +AVIULawDecoder::AVIULawDecoder(const nsavi::audio_format *waveformat) : waveformat(waveformat) +{ +} + +int AVIULawDecoder::OutputFrameSize(size_t *frame_size) +{ + *frame_size = waveformat->block_align; // TODO + return AVI_SUCCESS; +} + +int AVIULawDecoder::GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat) +{ + if (waveformat) + { + *sampleRate = waveformat->sample_rate; + *channels = waveformat->channels; + *bitsPerSample = 16; + *isFloat = false; // TODO + return AVI_SUCCESS; + } + else + { + return AVI_FAILURE; + } +} + +int AVIULawDecoder::DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes) +{ +size_t num_samples = min(*inputBufferBytes, *outputBufferBytes / 2); + const uint8_t *in = (const uint8_t *)*inputBuffer; + + int16_t *out = (int16_t *)outputBuffer; + for (size_t i=0;i!=num_samples;i++) + { + out[i] = MuLawDecompressTable[in[i]]; + } + + *outputBufferBytes = num_samples * 2; + *inputBufferBytes -= num_samples; + *inputBuffer = (uint8_t *)inputBuffer + num_samples; + + return AVI_SUCCESS; +} + +void AVIULawDecoder::Close() +{ + delete this; +} + +#define CBCLASS AVIULawDecoder +START_DISPATCH; +CB(OUTPUT_FRAME_SIZE, OutputFrameSize) +CB(GET_OUTPUT_PROPERTIES, GetOutputProperties) +CB(DECODE_CHUNK, DecodeChunk) +VCB(CLOSE, Close) +END_DISPATCH; +#undef CBCLASS
\ No newline at end of file diff --git a/Src/pcm/avi_ulaw_decoder.h b/Src/pcm/avi_ulaw_decoder.h new file mode 100644 index 00000000..a88ef70f --- /dev/null +++ b/Src/pcm/avi_ulaw_decoder.h @@ -0,0 +1,21 @@ +#pragma once +#include "../nsavi/avi_header.h" +#include "../Plugins/Input/in_avi/ifc_aviaudiodecoder.h" + +class AVIULawDecoder : public ifc_aviaudiodecoder +{ +public: + AVIULawDecoder(const nsavi::audio_format *waveformat); + +protected: + RECVS_DISPATCH; +private: + /* ifc_aviaudiodecoder implementation */ + int OutputFrameSize(size_t *frame_size); + int GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample, bool *isFloat); + int DecodeChunk(uint16_t type, void **inputBuffer, size_t *inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes); + void Close(); + +private: + const nsavi::audio_format *waveformat; +};
\ No newline at end of file diff --git a/Src/pcm/main.cpp b/Src/pcm/main.cpp new file mode 100644 index 00000000..985c1ef4 --- /dev/null +++ b/Src/pcm/main.cpp @@ -0,0 +1,78 @@ +#define WIN32_LEAN_AND_MEAN +#include "mp4_ulaw_decoder.h" +#include "api.h" +#include <bfc/platform/export.h> +#include "../Agave/Component/ifc_wa5component.h" +#include "../nu/Singleton.h" +#include "../nu/factoryt.h" +#include "avi_pcm_decoder.h" + +api_service *WASABI_API_SVC=0; +class PCMComponent : public ifc_wa5component +{ +public: + void RegisterServices(api_service *service); + int RegisterServicesSafeModeOk(); + void DeregisterServices(api_service *service); +protected: + RECVS_DISPATCH; +}; + +template <class api_T> +void ServiceBuild(api_T *&api_t, GUID factoryGUID_t) +{ + if (WASABI_API_SVC) + { + waServiceFactory *factory = WASABI_API_SVC->service_getServiceByGuid(factoryGUID_t); + if (factory) + api_t = reinterpret_cast<api_T *>( factory->getInterface() ); + } +} + +template <class api_T> +void ServiceRelease(api_T *api_t, GUID factoryGUID_t) +{ + if (WASABI_API_SVC && api_t) + { + waServiceFactory *factory = WASABI_API_SVC->service_getServiceByGuid(factoryGUID_t); + if (factory) + factory->releaseInterface(api_t); + } + api_t = NULL; +} + +static ServiceFactoryT<MP4AudioDecoder, MP4ulawDecoder> mp4Factory; +static SingletonServiceFactory<svc_avidecoder, AVIDecoder> avi_factory; +static AVIDecoder avi_decoder; + +void PCMComponent::RegisterServices(api_service *service) +{ + WASABI_API_SVC = service; + mp4Factory.Register(WASABI_API_SVC); + avi_factory.Register(WASABI_API_SVC, &avi_decoder); +} + +int PCMComponent::RegisterServicesSafeModeOk() +{ + return 1; +} + +void PCMComponent::DeregisterServices(api_service *service) +{ + mp4Factory.Deregister(WASABI_API_SVC); + avi_factory.Deregister(WASABI_API_SVC); +} + +static PCMComponent component; +extern "C" DLLEXPORT ifc_wa5component *GetWinamp5SystemComponent() +{ + return &component; +} + +#define CBCLASS PCMComponent +START_DISPATCH; +VCB(API_WA5COMPONENT_REGISTERSERVICES, RegisterServices) +CB(15, RegisterServicesSafeModeOk) +VCB(API_WA5COMPONENT_DEREEGISTERSERVICES, DeregisterServices) +END_DISPATCH; +#undef CBCLASS
\ No newline at end of file diff --git a/Src/pcm/mp4_ulaw_decoder.cpp b/Src/pcm/mp4_ulaw_decoder.cpp new file mode 100644 index 00000000..12c2272b --- /dev/null +++ b/Src/pcm/mp4_ulaw_decoder.cpp @@ -0,0 +1,98 @@ +#include "mp4_ulaw_decoder.h" + +static int16_t MuLawDecompressTable[256] = +{ + -32124,-31100,-30076,-29052,-28028,-27004,-25980,-24956, + -23932,-22908,-21884,-20860,-19836,-18812,-17788,-16764, + -15996,-15484,-14972,-14460,-13948,-13436,-12924,-12412, + -11900,-11388,-10876,-10364, -9852, -9340, -8828, -8316, + -7932, -7676, -7420, -7164, -6908, -6652, -6396, -6140, + -5884, -5628, -5372, -5116, -4860, -4604, -4348, -4092, + -3900, -3772, -3644, -3516, -3388, -3260, -3132, -3004, + -2876, -2748, -2620, -2492, -2364, -2236, -2108, -1980, + -1884, -1820, -1756, -1692, -1628, -1564, -1500, -1436, + -1372, -1308, -1244, -1180, -1116, -1052, -988, -924, + -876, -844, -812, -780, -748, -716, -684, -652, + -620, -588, -556, -524, -492, -460, -428, -396, + -372, -356, -340, -324, -308, -292, -276, -260, + -244, -228, -212, -196, -180, -164, -148, -132, + -120, -112, -104, -96, -88, -80, -72, -64, + -56, -48, -40, -32, -24, -16, -8, 0, + 32124, 31100, 30076, 29052, 28028, 27004, 25980, 24956, + 23932, 22908, 21884, 20860, 19836, 18812, 17788, 16764, + 15996, 15484, 14972, 14460, 13948, 13436, 12924, 12412, + 11900, 11388, 10876, 10364, 9852, 9340, 8828, 8316, + 7932, 7676, 7420, 7164, 6908, 6652, 6396, 6140, + 5884, 5628, 5372, 5116, 4860, 4604, 4348, 4092, + 3900, 3772, 3644, 3516, 3388, 3260, 3132, 3004, + 2876, 2748, 2620, 2492, 2364, 2236, 2108, 1980, + 1884, 1820, 1756, 1692, 1628, 1564, 1500, 1436, + 1372, 1308, 1244, 1180, 1116, 1052, 988, 924, + 876, 844, 812, 780, 748, 716, 684, 652, + 620, 588, 556, 524, 492, 460, 428, 396, + 372, 356, 340, 324, 308, 292, 276, 260, + 244, 228, 212, 196, 180, 164, 148, 132, + 120, 112, 104, 96, 88, 80, 72, 64, + 56, 48, 40, 32, 24, 16, 8, 0 +}; + +MP4ulawDecoder::MP4ulawDecoder() +{ +} +int MP4ulawDecoder::Open() +{ + return MP4_SUCCESS; +} +void MP4ulawDecoder::Close() +{ +} +int MP4ulawDecoder::GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample) +{ + // TODO + *channels = 1; + *bitsPerSample = 16; + return MP4_SUCCESS; +} + +int MP4ulawDecoder::DecodeSample(void *inputBuffer, size_t inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes) +{ + const uint8_t *in = (const uint8_t *)inputBuffer; + *outputBufferBytes=0; + int16_t *out = (int16_t *)outputBuffer; + while (inputBufferBytes--) + { + *outputBufferBytes = *outputBufferBytes + 2; + *out++ = MuLawDecompressTable[*in++]; + } + return MP4_SUCCESS; +} + +int MP4ulawDecoder::CanHandleCodec(const char *codecName) +{ + return !strcmp(codecName, "ulaw"); +} + +int MP4ulawDecoder::RequireChunks() +{ + return 1; +} + +#define CBCLASS MP4ulawDecoder +START_DISPATCH; +CB(MPEG4_AUDIO_OPEN, Open) +//CB(MPEG4_AUDIO_OPEN_EX, OpenEx) +//CB(MPEG4_AUDIO_ASC, AudioSpecificConfiguration) +//CB(MPEG4_AUDIO_BITRATE, GetCurrentBitrate) +//CB(MPEG4_AUDIO_FRAMESIZE, OutputFrameSize) +CB(MPEG4_AUDIO_OUTPUTINFO, GetOutputProperties) +//CB(MPEG4_AUDIO_OUTPUTINFO_EX, GetOutputPropertiesEx) +CB(MPEG4_AUDIO_DECODE, DecodeSample) +//VCB(MPEG4_AUDIO_FLUSH, Flush) +VCB(MPEG4_AUDIO_CLOSE, Close) +CB(MPEG4_AUDIO_HANDLES_CODEC, CanHandleCodec) +//CB(MPEG4_AUDIO_HANDLES_TYPE, CanHandleType) +//CB(MPEG4_AUDIO_HANDLES_MPEG4_TYPE, CanHandleMPEG4Type) +//CB(MPEG4_AUDIO_SET_GAIN, SetGain) +CB(MPEG4_AUDIO_REQUIRE_CHUNKS, RequireChunks) +END_DISPATCH; +#undef CBCLASS
\ No newline at end of file diff --git a/Src/pcm/mp4_ulaw_decoder.h b/Src/pcm/mp4_ulaw_decoder.h new file mode 100644 index 00000000..1c6f2480 --- /dev/null +++ b/Src/pcm/mp4_ulaw_decoder.h @@ -0,0 +1,26 @@ +#pragma once + +#include "../Plugins/Input/in_mp4/mpeg4audio.h" + +// {F05D2AAA-6F21-4970-AE9C-8D9FFB497957} +static const GUID mp4_ulaw_guid = +{ 0xf05d2aaa, 0x6f21, 0x4970, { 0xae, 0x9c, 0x8d, 0x9f, 0xfb, 0x49, 0x79, 0x57 } }; + + +class MP4ulawDecoder : public MP4AudioDecoder +{ +public: + static const char *getServiceName() { return "ulaw MP4 Decoder"; } + static GUID getServiceGuid() { return mp4_ulaw_guid; } + MP4ulawDecoder(); + int Open(); + void Close(); + int GetOutputProperties(unsigned int *sampleRate, unsigned int *channels, unsigned int *bitsPerSample); + int DecodeSample(void *inputBuffer, size_t inputBufferBytes, void *outputBuffer, size_t *outputBufferBytes); + int CanHandleCodec(const char *codecName); + //int SetGain(float _gain) { gain=_gain; return MP4_SUCCESS; } + int RequireChunks(); // return 1 if your decoder wants to read whole chunks rather than samples + +protected: + RECVS_DISPATCH; +};
\ No newline at end of file diff --git a/Src/pcm/pcm.rc b/Src/pcm/pcm.rc new file mode 100644 index 00000000..fcff7711 --- /dev/null +++ b/Src/pcm/pcm.rc @@ -0,0 +1,76 @@ +// Microsoft Visual C++ generated resource script. +// +#include "resource.h" + +#define APSTUDIO_READONLY_SYMBOLS +///////////////////////////////////////////////////////////////////////////// +// +// Generated from the TEXTINCLUDE 2 resource. +// +#include "afxres.h" + +///////////////////////////////////////////////////////////////////////////// +#undef APSTUDIO_READONLY_SYMBOLS + +///////////////////////////////////////////////////////////////////////////// +// English (U.S.) resources + +#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENU) +#ifdef _WIN32 +LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_US +#pragma code_page(1252) +#endif //_WIN32 + +#endif // English (U.S.) resources +///////////////////////////////////////////////////////////////////////////// + + +///////////////////////////////////////////////////////////////////////////// +// English (U.K.) resources + +#if !defined(AFX_RESOURCE_DLL) || defined(AFX_TARG_ENG) +#ifdef _WIN32 +LANGUAGE LANG_ENGLISH, SUBLANG_ENGLISH_UK +#pragma code_page(1252) +#endif //_WIN32 + +#ifdef APSTUDIO_INVOKED +///////////////////////////////////////////////////////////////////////////// +// +// TEXTINCLUDE +// + +1 TEXTINCLUDE +BEGIN + "resource.h\0" +END + +2 TEXTINCLUDE +BEGIN + "#include ""afxres.h""\r\n" + "\0" +END + +3 TEXTINCLUDE +BEGIN + "#include ""version.rc2""\r\n" + "\0" +END + +#endif // APSTUDIO_INVOKED + +#endif // English (U.K.) resources +///////////////////////////////////////////////////////////////////////////// + + + +#ifndef APSTUDIO_INVOKED +///////////////////////////////////////////////////////////////////////////// +// +// Generated from the TEXTINCLUDE 3 resource. +// +#include "version.rc2" + +///////////////////////////////////////////////////////////////////////////// +#endif // not APSTUDIO_INVOKED + diff --git a/Src/pcm/pcm.sln b/Src/pcm/pcm.sln new file mode 100644 index 00000000..7f58517e --- /dev/null +++ b/Src/pcm/pcm.sln @@ -0,0 +1,31 @@ + +Microsoft Visual Studio Solution File, Format Version 12.00 +# Visual Studio Version 16 +VisualStudioVersion = 16.0.29424.173 +MinimumVisualStudioVersion = 10.0.40219.1 +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "pcm", "pcm.vcxproj", "{0D820ED8-768A-4E89-A017-5F583EC708E3}" +EndProject +Global + GlobalSection(SolutionConfigurationPlatforms) = preSolution + Debug|Win32 = Debug|Win32 + Debug|x64 = Debug|x64 + Release|Win32 = Release|Win32 + Release|x64 = Release|x64 + EndGlobalSection + GlobalSection(ProjectConfigurationPlatforms) = postSolution + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Debug|Win32.ActiveCfg = Debug|Win32 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Debug|Win32.Build.0 = Debug|Win32 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Debug|x64.ActiveCfg = Debug|x64 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Debug|x64.Build.0 = Debug|x64 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Release|Win32.ActiveCfg = Release|Win32 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Release|Win32.Build.0 = Release|Win32 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Release|x64.ActiveCfg = Release|x64 + {0D820ED8-768A-4E89-A017-5F583EC708E3}.Release|x64.Build.0 = Release|x64 + EndGlobalSection + GlobalSection(SolutionProperties) = preSolution + HideSolutionNode = FALSE + EndGlobalSection + GlobalSection(ExtensibilityGlobals) = postSolution + SolutionGuid = {B9E4B6F6-DD8E-4C53-82C0-D2E1C9EDB6F9} + EndGlobalSection +EndGlobal diff --git a/Src/pcm/pcm.vcxproj b/Src/pcm/pcm.vcxproj new file mode 100644 index 00000000..19478105 --- /dev/null +++ b/Src/pcm/pcm.vcxproj @@ -0,0 +1,251 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup Label="ProjectConfigurations"> + <ProjectConfiguration Include="Debug|Win32"> + <Configuration>Debug</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + <ProjectConfiguration Include="Debug|x64"> + <Configuration>Debug</Configuration> + <Platform>x64</Platform> + </ProjectConfiguration> + <ProjectConfiguration Include="Release|Win32"> + <Configuration>Release</Configuration> + <Platform>Win32</Platform> + </ProjectConfiguration> + <ProjectConfiguration Include="Release|x64"> + <Configuration>Release</Configuration> + <Platform>x64</Platform> + </ProjectConfiguration> + </ItemGroup> + <PropertyGroup Label="Globals"> + <ProjectGuid>{0D820ED8-768A-4E89-A017-5F583EC708E3}</ProjectGuid> + <RootNamespace>pcm</RootNamespace> + <WindowsTargetPlatformVersion>10.0.19041.0</WindowsTargetPlatformVersion> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" /> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <PlatformToolset>v142</PlatformToolset> + <CharacterSet>Unicode</CharacterSet> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <PlatformToolset>v142</PlatformToolset> + <CharacterSet>Unicode</CharacterSet> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <PlatformToolset>v142</PlatformToolset> + <CharacterSet>Unicode</CharacterSet> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration"> + <ConfigurationType>DynamicLibrary</ConfigurationType> + <PlatformToolset>v142</PlatformToolset> + <CharacterSet>Unicode</CharacterSet> + </PropertyGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" /> + <ImportGroup Label="ExtensionSettings"> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets"> + <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" /> + </ImportGroup> + <PropertyGroup Label="UserMacros" /> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> + <LinkIncremental>false</LinkIncremental> + <OutDir>$(PlatformShortName)_$(Configuration)\</OutDir> + <IntDir>$(PlatformShortName)_$(Configuration)\</IntDir> + <TargetExt>.w5s</TargetExt> + <IncludePath>$(IncludePath)</IncludePath> + <LibraryPath>$(LibraryPath)</LibraryPath> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> + <LinkIncremental>false</LinkIncremental> + <OutDir>$(PlatformShortName)_$(Configuration)\</OutDir> + <IntDir>$(PlatformShortName)_$(Configuration)\</IntDir> + <TargetExt>.w5s</TargetExt> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> + <LinkIncremental>false</LinkIncremental> + <OutDir>$(PlatformShortName)_$(Configuration)\</OutDir> + <IntDir>$(PlatformShortName)_$(Configuration)\</IntDir> + <TargetExt>.w5s</TargetExt> + <IncludePath>$(IncludePath)</IncludePath> + <LibraryPath>$(LibraryPath)</LibraryPath> + </PropertyGroup> + <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> + <LinkIncremental>false</LinkIncremental> + <OutDir>$(PlatformShortName)_$(Configuration)\</OutDir> + <IntDir>$(PlatformShortName)_$(Configuration)\</IntDir> + <TargetExt>.w5s</TargetExt> + </PropertyGroup> + <PropertyGroup Label="Vcpkg" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> + <VcpkgTriplet>x86-windows-static-md</VcpkgTriplet> + </PropertyGroup> + <PropertyGroup Label="Vcpkg" Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> + <VcpkgTriplet>x86-windows-static-md</VcpkgTriplet> + </PropertyGroup> + <PropertyGroup Label="Vcpkg" Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> + <VcpkgTriplet>x86-windows-static-md</VcpkgTriplet> + </PropertyGroup> + <PropertyGroup Label="Vcpkg" Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> + <VcpkgTriplet>x86-windows-static-md</VcpkgTriplet> + </PropertyGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'"> + <ClCompile> + <Optimization>Disabled</Optimization> + <AdditionalIncludeDirectories>../Wasabi;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN32;_DEBUG;_WINDOWS;_USRDLL;PCM_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <MinimalRebuild>false</MinimalRebuild> + <MultiProcessorCompilation>true</MultiProcessorCompilation> + <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> + <WarningLevel>Level3</WarningLevel> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <ProgramDataBaseFileName>$(IntDir)$(TargetName).pdb</ProgramDataBaseFileName> + </ClCompile> + <Link> + <OutputFile>$(OutDir)$(TargetName)$(TargetExt)</OutputFile> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>$(IntDir)$(TargetName).pdb</ProgramDatabaseFile> + <SubSystem>Windows</SubSystem> + <ImportLibrary>$(ProjectDir)x86_Debug\$(ProjectName).lib</ImportLibrary> + <TargetMachine>MachineX86</TargetMachine> + <ImageHasSafeExceptionHandlers>false</ImageHasSafeExceptionHandlers> + <AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> + </Link> + <PostBuildEvent> + <Command>xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ +xcopy /Y /D $(IntDir)$(TargetName).pdb ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ </Command> + <Message>Post build event: 'xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\'</Message> + </PostBuildEvent> + </ItemDefinitionGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'"> + <ClCompile> + <Optimization>Disabled</Optimization> + <AdditionalIncludeDirectories>../Wasabi;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN64;_DEBUG;_WINDOWS;_USRDLL;PCM_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <MinimalRebuild>false</MinimalRebuild> + <MultiProcessorCompilation>true</MultiProcessorCompilation> + <BasicRuntimeChecks>EnableFastChecks</BasicRuntimeChecks> + <RuntimeLibrary>MultiThreadedDebugDLL</RuntimeLibrary> + <WarningLevel>Level3</WarningLevel> + <DebugInformationFormat>ProgramDatabase</DebugInformationFormat> + <ProgramDataBaseFileName>$(IntDir)$(TargetName).pdb</ProgramDataBaseFileName> + </ClCompile> + <Link> + <OutputFile>$(OutDir)$(TargetName)$(TargetExt)</OutputFile> + <GenerateDebugInformation>true</GenerateDebugInformation> + <ProgramDatabaseFile>$(IntDir)$(TargetName).pdb</ProgramDatabaseFile> + <SubSystem>Windows</SubSystem> + <ImportLibrary>$(ProjectDir)x64_Debug\$(ProjectName).lib</ImportLibrary> + <ImageHasSafeExceptionHandlers>false</ImageHasSafeExceptionHandlers> + <AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> + </Link> + <PostBuildEvent> + <Command>xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ +xcopy /Y /D $(IntDir)$(TargetName).pdb ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ </Command> + <Message>Post build event: 'xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\'</Message> + </PostBuildEvent> + </ItemDefinitionGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'"> + <ClCompile> + <Optimization>MinSpace</Optimization> + <IntrinsicFunctions>true</IntrinsicFunctions> + <FavorSizeOrSpeed>Size</FavorSizeOrSpeed> + <AdditionalIncludeDirectories>../Wasabi;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN32;NDEBUG;_WINDOWS;_USRDLL;PCM_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <StringPooling>true</StringPooling> + <MultiProcessorCompilation>true</MultiProcessorCompilation> + <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> + <BufferSecurityCheck>true</BufferSecurityCheck> + <WarningLevel>Level3</WarningLevel> + <DebugInformationFormat>None</DebugInformationFormat> + <ProgramDataBaseFileName>$(IntDir)$(TargetName).pdb</ProgramDataBaseFileName> + </ClCompile> + <Link> + <OutputFile>$(OutDir)$(TargetName)$(TargetExt)</OutputFile> + <GenerateDebugInformation>false</GenerateDebugInformation> + <ProgramDatabaseFile>$(IntDir)$(TargetName).pdb</ProgramDatabaseFile> + <SubSystem>Windows</SubSystem> + <OptimizeReferences>true</OptimizeReferences> + <EnableCOMDATFolding>true</EnableCOMDATFolding> + <RandomizedBaseAddress>false</RandomizedBaseAddress> + <ImportLibrary>$(ProjectDir)x86_Release\$(ProjectName).lib</ImportLibrary> + <TargetMachine>MachineX86</TargetMachine> + <ImageHasSafeExceptionHandlers>false</ImageHasSafeExceptionHandlers> + <AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> + </Link> + <PostBuildEvent> + <Command>xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ </Command> + <Message>Post build event: 'xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\'</Message> + </PostBuildEvent> + </ItemDefinitionGroup> + <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'"> + <ClCompile> + <Optimization>MinSpace</Optimization> + <IntrinsicFunctions>true</IntrinsicFunctions> + <FavorSizeOrSpeed>Size</FavorSizeOrSpeed> + <AdditionalIncludeDirectories>../Wasabi;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories> + <PreprocessorDefinitions>WIN64;NDEBUG;_WINDOWS;_USRDLL;PCM_EXPORTS;%(PreprocessorDefinitions)</PreprocessorDefinitions> + <StringPooling>true</StringPooling> + <MultiProcessorCompilation>true</MultiProcessorCompilation> + <RuntimeLibrary>MultiThreadedDLL</RuntimeLibrary> + <BufferSecurityCheck>true</BufferSecurityCheck> + <WarningLevel>Level3</WarningLevel> + <DebugInformationFormat>None</DebugInformationFormat> + <ProgramDataBaseFileName>$(IntDir)$(TargetName).pdb</ProgramDataBaseFileName> + </ClCompile> + <Link> + <OutputFile>$(OutDir)$(TargetName)$(TargetExt)</OutputFile> + <GenerateDebugInformation>false</GenerateDebugInformation> + <ProgramDatabaseFile>$(IntDir)$(TargetName).pdb</ProgramDatabaseFile> + <SubSystem>Windows</SubSystem> + <OptimizeReferences>true</OptimizeReferences> + <EnableCOMDATFolding>true</EnableCOMDATFolding> + <RandomizedBaseAddress>false</RandomizedBaseAddress> + <ImportLibrary>$(ProjectDir)x64_Release\$(ProjectName).lib</ImportLibrary> + <ImageHasSafeExceptionHandlers>false</ImageHasSafeExceptionHandlers> + <AdditionalLibraryDirectories>%(AdditionalLibraryDirectories)</AdditionalLibraryDirectories> + </Link> + <PostBuildEvent> + <Command>xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\ </Command> + <Message>Post build event: 'xcopy /Y /D $(OutDir)$(TargetName)$(TargetExt) ..\..\Build\Winamp_$(PlatformShortName)_$(Configuration)\System\'</Message> + </PostBuildEvent> + </ItemDefinitionGroup> + <ItemGroup> + <ClInclude Include="api.h" /> + <ClInclude Include="avi_alaw_decoder.h" /> + <ClInclude Include="avi_pcm_decoder.h" /> + <ClInclude Include="avi_ulaw_decoder.h" /> + <ClInclude Include="mp4_ulaw_decoder.h" /> + <ClInclude Include="resource.h" /> + </ItemGroup> + <ItemGroup> + <ClCompile Include="avi_alaw_decoder.cpp" /> + <ClCompile Include="avi_pcm_decoder.cpp" /> + <ClCompile Include="avi_ulaw_decoder.cpp" /> + <ClCompile Include="main.cpp" /> + <ClCompile Include="mp4_ulaw_decoder.cpp" /> + </ItemGroup> + <ItemGroup> + <ResourceCompile Include="pcm.rc" /> + </ItemGroup> + <ItemGroup> + <ProjectReference Include="..\Wasabi\Wasabi.vcxproj"> + <Project>{3e0bfa8a-b86a-42e9-a33f-ec294f823f7f}</Project> + </ProjectReference> + </ItemGroup> + <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> + <ImportGroup Label="ExtensionTargets"> + </ImportGroup> +</Project>
\ No newline at end of file diff --git a/Src/pcm/pcm.vcxproj.filters b/Src/pcm/pcm.vcxproj.filters new file mode 100644 index 00000000..a1b8ff66 --- /dev/null +++ b/Src/pcm/pcm.vcxproj.filters @@ -0,0 +1,56 @@ +<?xml version="1.0" encoding="utf-8"?> +<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> + <ItemGroup> + <ClCompile Include="mp4_ulaw_decoder.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + <ClCompile Include="main.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + <ClCompile Include="avi_ulaw_decoder.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + <ClCompile Include="avi_pcm_decoder.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + <ClCompile Include="avi_alaw_decoder.cpp"> + <Filter>Source Files</Filter> + </ClCompile> + </ItemGroup> + <ItemGroup> + <ClInclude Include="api.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="avi_alaw_decoder.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="avi_pcm_decoder.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="avi_ulaw_decoder.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="mp4_ulaw_decoder.h"> + <Filter>Header Files</Filter> + </ClInclude> + <ClInclude Include="resource.h"> + <Filter>Header Files</Filter> + </ClInclude> + </ItemGroup> + <ItemGroup> + <Filter Include="Header Files"> + <UniqueIdentifier>{1b5ce836-a837-4b4b-9fe4-50f0fbabacdb}</UniqueIdentifier> + </Filter> + <Filter Include="Ressource Files"> + <UniqueIdentifier>{3498ccdf-ab98-4530-9041-b6485d738553}</UniqueIdentifier> + </Filter> + <Filter Include="Source Files"> + <UniqueIdentifier>{ff9dbc76-28ce-4fd2-a695-d166e6faecb5}</UniqueIdentifier> + </Filter> + </ItemGroup> + <ItemGroup> + <ResourceCompile Include="pcm.rc"> + <Filter>Ressource Files</Filter> + </ResourceCompile> + </ItemGroup> +</Project>
\ No newline at end of file diff --git a/Src/pcm/resource.h b/Src/pcm/resource.h new file mode 100644 index 00000000..ef8870c2 --- /dev/null +++ b/Src/pcm/resource.h @@ -0,0 +1,14 @@ +//{{NO_DEPENDENCIES}} +// Microsoft Visual C++ generated include file. +// Used by pcm.rc + +// Next default values for new objects +// +#ifdef APSTUDIO_INVOKED +#ifndef APSTUDIO_READONLY_SYMBOLS +#define _APS_NEXT_RESOURCE_VALUE 101 +#define _APS_NEXT_COMMAND_VALUE 40001 +#define _APS_NEXT_CONTROL_VALUE 1001 +#define _APS_NEXT_SYMED_VALUE 101 +#endif +#endif diff --git a/Src/pcm/version.rc2 b/Src/pcm/version.rc2 new file mode 100644 index 00000000..efef3567 --- /dev/null +++ b/Src/pcm/version.rc2 @@ -0,0 +1,39 @@ + +///////////////////////////////////////////////////////////////////////////// +// +// Version +// +#include "../Winamp/buildType.h" +VS_VERSION_INFO VERSIONINFO + FILEVERSION WINAMP_PRODUCTVER + PRODUCTVERSION WINAMP_PRODUCTVER + FILEFLAGSMASK 0x17L +#ifdef _DEBUG + FILEFLAGS 0x1L +#else + FILEFLAGS 0x0L +#endif + FILEOS 0x4L + FILETYPE 0x2L + FILESUBTYPE 0x0L +BEGIN + BLOCK "StringFileInfo" + BEGIN + BLOCK "040904b0" + BEGIN + VALUE "CompanyName", "Winamp SA" + VALUE "FileDescription", "Winamp 5.x System Component" + VALUE "FileVersion", STR_WINAMP_PRODUCTVER + VALUE "InternalName", "pcm.w5s" + VALUE "LegalCopyright", "Copyright © 2005-2023 Winamp SA" + VALUE "LegalTrademarks", "Nullsoft and Winamp are trademarks of Winamp SA" + VALUE "OriginalFilename", "pcm.w5s" + VALUE "ProductName", "Winamp PCM Decoder Service" + VALUE "ProductVersion", STR_WINAMP_PRODUCTVER + END + END + BLOCK "VarFileInfo" + BEGIN + VALUE "Translation", 0x409, 1200 + END +END |