Ajout version Release/x64 avec les libraries x64 et tuning de la version Debug
This commit is contained in:
		
							
								
								
									
										42
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamLoaderMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamLoaderMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| // Copyright (C) 2002-2007 Nikolaus Gebhardt | ||||
| // This file is part of the "irrKlang" library. | ||||
| // For conditions of distribution and use, see copyright notice in irrKlang.h | ||||
|  | ||||
| #include "CIrrKlangAudioStreamLoaderMP3.h" | ||||
| #include "CIrrKlangAudioStreamMP3.h" | ||||
| #include <string.h> | ||||
|  | ||||
|  | ||||
| namespace irrklang | ||||
| { | ||||
|  | ||||
|  | ||||
| CIrrKlangAudioStreamLoaderMP3::CIrrKlangAudioStreamLoaderMP3() | ||||
| { | ||||
| } | ||||
|  | ||||
|  | ||||
| //! Returns true if the file maybe is able to be loaded by this class. | ||||
| bool CIrrKlangAudioStreamLoaderMP3::isALoadableFileExtension(const ik_c8* fileName) | ||||
| { | ||||
| 	return strstr(fileName, ".mp3") != 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| //! Creates an audio file input stream from a file | ||||
| IAudioStream* CIrrKlangAudioStreamLoaderMP3::createAudioStream(irrklang::IFileReader* file) | ||||
| { | ||||
| 	CIrrKlangAudioStreamMP3* stream = new CIrrKlangAudioStreamMP3(file); | ||||
|  | ||||
| 	if (stream && !stream->isOK()) | ||||
| 	{ | ||||
| 		stream->drop(); | ||||
| 		stream = 0; | ||||
| 	} | ||||
|  | ||||
| 	return stream; | ||||
| } | ||||
|  | ||||
|  | ||||
| } // end namespace irrklang | ||||
|  | ||||
							
								
								
									
										32
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamLoaderMP3.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamLoaderMP3.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| // Copyright (C) 2002-2007 Nikolaus Gebhardt | ||||
| // This file is part of the "irrKlang" library. | ||||
| // For conditions of distribution and use, see copyright notice in irrKlang.h | ||||
|  | ||||
| #ifndef __C_IRRKLANG_AUDIO_STREAM_LOADER_MP3_H_INCLUDED__ | ||||
| #define __C_IRRKLANG_AUDIO_STREAM_LOADER_MP3_H_INCLUDED__ | ||||
|  | ||||
| #include <ik_IAudioStreamLoader.h> | ||||
|  | ||||
| namespace irrklang | ||||
| { | ||||
| 	//!	Class which is able to create an audio file stream from a file. | ||||
| 	class CIrrKlangAudioStreamLoaderMP3 : public IAudioStreamLoader | ||||
| 	{ | ||||
| 	public: | ||||
|  | ||||
| 		CIrrKlangAudioStreamLoaderMP3(); | ||||
|  | ||||
| 		//! Returns true if the file maybe is able to be loaded by this class. | ||||
| 		/** This decision should be based only on the file extension (e.g. ".wav") */ | ||||
| 		virtual bool isALoadableFileExtension(const ik_c8* fileName); | ||||
|  | ||||
| 		//! Creates an audio file input stream from a file | ||||
| 		/** \return Pointer to the created audio stream. Returns 0 if loading failed. | ||||
| 		If you no longer need the stream, you should call IAudioFileStream::drop(). | ||||
| 		See IRefCounted::drop() for more information. */ | ||||
| 		virtual IAudioStream* createAudioStream(irrklang::IFileReader* file); | ||||
| 	}; | ||||
|  | ||||
| } // end namespace irrklang | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										397
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										397
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,397 @@ | ||||
| // Copyright (C) 2002-2007 Nikolaus Gebhardt | ||||
| // Part of the code for this plugin for irrKlang is based on: | ||||
| //  MP3 input for Audiere by Matt Campbell <mattcampbell@pobox.com>, based on | ||||
| //  libavcodec from ffmpeg (http://ffmpeg.sourceforge.net/). | ||||
| // See license.txt for license details of this plugin. | ||||
|  | ||||
| #include "CIrrKlangAudioStreamMP3.h" | ||||
| #include <memory.h> | ||||
| #include <stdlib.h> // free, malloc and realloc | ||||
| #include <string.h> | ||||
|  | ||||
| namespace irrklang | ||||
| { | ||||
|  | ||||
| CIrrKlangAudioStreamMP3::CIrrKlangAudioStreamMP3(IFileReader* file) | ||||
| : File(file), TheMPAuDecContext(0), InputPosition(0), InputLength(0), | ||||
| 	DecodeBuffer(0), FirstFrameRead(false), EndOfFileReached(0), | ||||
| 	FileBegin(0), Position(0) | ||||
| { | ||||
| 	if (File) | ||||
| 	{ | ||||
| 		File->grab(); | ||||
|  | ||||
| 		TheMPAuDecContext = new MPAuDecContext(); | ||||
|  | ||||
| 		if (!TheMPAuDecContext || mpaudec_init(TheMPAuDecContext) < 0) | ||||
| 		{ | ||||
| 			File->drop(); | ||||
| 			File = 0; | ||||
| 			delete TheMPAuDecContext; | ||||
| 			TheMPAuDecContext = 0; | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		// init, get format | ||||
|  | ||||
| 		DecodeBuffer = new ik_u8[MPAUDEC_MAX_AUDIO_FRAME_SIZE]; | ||||
|  | ||||
| 		if (File->getSize()>0) | ||||
| 		{ | ||||
| 			// seekable file, now parse file to get size | ||||
| 			// (needed to make it possible for the engine to loop a stream correctly) | ||||
|  | ||||
| 			skipID3IfNecessary(); | ||||
|  | ||||
| 			TheMPAuDecContext->parse_only = 1; | ||||
| 			Format.FrameCount = 0; | ||||
|  | ||||
| 			while(!EndOfFileReached) | ||||
| 			{ | ||||
| 				if (!decodeFrame()) | ||||
| 					break; | ||||
|  | ||||
| 				Format.FrameCount += TheMPAuDecContext->frame_size; | ||||
|  | ||||
| 				if (!EndOfFileReached /*&& File->isSeekable()*/ ) | ||||
| 				{ | ||||
| 					// to be able to seek in the stream, store offsets and sizes | ||||
|  | ||||
| 					SFramePositionData data; | ||||
| 					data.size = TheMPAuDecContext->frame_size; | ||||
| 					data.offset = File->getPos() - (InputLength - InputPosition) - TheMPAuDecContext->coded_frame_size; | ||||
|  | ||||
| 					FramePositionData.push_back(data); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			TheMPAuDecContext->parse_only = 0; | ||||
| 			setPosition(0); | ||||
| 		} | ||||
| 		else | ||||
| 			decodeFrame(); // decode first frame to read audio format | ||||
|  | ||||
| 		if (!TheMPAuDecContext->channels || | ||||
| 			!TheMPAuDecContext->sample_rate ) | ||||
| 		{ | ||||
| 			File->drop(); | ||||
| 			File = 0; | ||||
| 			delete TheMPAuDecContext; | ||||
| 			TheMPAuDecContext = 0; | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| CIrrKlangAudioStreamMP3::~CIrrKlangAudioStreamMP3() | ||||
| { | ||||
| 	if (File) | ||||
| 		File->drop(); | ||||
|  | ||||
| 	if (TheMPAuDecContext) | ||||
| 	{ | ||||
| 		mpaudec_clear(TheMPAuDecContext); | ||||
| 		delete TheMPAuDecContext; | ||||
| 	} | ||||
|  | ||||
| 	delete [] DecodeBuffer; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| //! returns format of the audio stream | ||||
| SAudioStreamFormat CIrrKlangAudioStreamMP3::getFormat() | ||||
| { | ||||
| 	return Format; | ||||
| } | ||||
|  | ||||
|  | ||||
| //! tells the audio stream to read n audio frames into the specified buffer | ||||
| ik_s32 CIrrKlangAudioStreamMP3::readFrames(void* target, ik_s32 frameCountToRead) | ||||
| { | ||||
| 	const int frameSize = Format.getFrameSize(); | ||||
|  | ||||
| 	int framesRead = 0; | ||||
| 	ik_u8* out = (ik_u8*)target; | ||||
|  | ||||
| 	while (framesRead < frameCountToRead) | ||||
| 	{ | ||||
| 		// no more samples?  ask the MP3 for more | ||||
| 		if (DecodedQueue.getSize() < frameSize) | ||||
| 		{ | ||||
| 			if (!decodeFrame() || EndOfFileReached) | ||||
| 				return framesRead; | ||||
|  | ||||
| 			// if the buffer is still empty, we are done | ||||
| 			if (DecodedQueue.getSize() < frameSize) | ||||
| 				return framesRead; | ||||
| 		} | ||||
|  | ||||
| 		const int framesLeft = frameCountToRead - framesRead; | ||||
| 		const int dequeSize = DecodedQueue.getSize() / frameSize; | ||||
| 		const int framesToRead = framesLeft < dequeSize ? framesLeft : dequeSize; | ||||
|  | ||||
| 		DecodedQueue.read(out, framesToRead * frameSize); | ||||
|  | ||||
| 		out += framesToRead * frameSize; | ||||
| 		framesRead += framesToRead; | ||||
| 		Position += framesToRead; | ||||
| 	} | ||||
|  | ||||
| 	return framesRead; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| bool CIrrKlangAudioStreamMP3::decodeFrame() | ||||
| { | ||||
|     int outputSize = 0; | ||||
|  | ||||
| 	while (!outputSize) | ||||
| 	{ | ||||
| 		if (InputPosition == InputLength) | ||||
| 		{ | ||||
| 			InputPosition = 0; | ||||
| 			InputLength = File->read(InputBuffer, IKP_MP3_INPUT_BUFFER_SIZE); | ||||
|  | ||||
| 			if (InputLength == 0) | ||||
| 			{ | ||||
| 				EndOfFileReached = true; | ||||
| 				return true; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		int rv = mpaudec_decode_frame( TheMPAuDecContext, (ik_s16*)DecodeBuffer, | ||||
| 									   &outputSize, | ||||
| 									   (ik_u8*)InputBuffer + InputPosition, | ||||
| 									   InputLength - InputPosition); | ||||
|  | ||||
| 		if (rv < 0) | ||||
| 			return false; | ||||
|  | ||||
| 		InputPosition += rv; | ||||
| 	} // end while | ||||
|  | ||||
| 	if (!FirstFrameRead) | ||||
| 	{ | ||||
| 		Format.ChannelCount = TheMPAuDecContext->channels; | ||||
| 		Format.SampleRate = TheMPAuDecContext->sample_rate; | ||||
| 		Format.SampleFormat = ESF_S16; | ||||
| 		Format.FrameCount = -1; // unknown lenght | ||||
|  | ||||
| 		FirstFrameRead = true; | ||||
| 	} | ||||
| 	else | ||||
| 	if (TheMPAuDecContext->channels != Format.ChannelCount || | ||||
| 		TheMPAuDecContext->sample_rate != Format.SampleRate) | ||||
| 	{ | ||||
| 		// Can't handle format changes mid-stream. | ||||
| 		return false; | ||||
|     } | ||||
|  | ||||
| 	if (!TheMPAuDecContext->parse_only) | ||||
| 	{ | ||||
| 		if (outputSize < 0) | ||||
| 		{ | ||||
| 			// Couldn't decode this frame.  Too bad, already lost it. | ||||
| 			// This should only happen when seeking. | ||||
|  | ||||
| 			outputSize = TheMPAuDecContext->frame_size; | ||||
| 			memset(DecodeBuffer, 0, outputSize * Format.getFrameSize()); | ||||
| 		} | ||||
|  | ||||
| 		DecodedQueue.write(DecodeBuffer, outputSize); | ||||
| 	} | ||||
|  | ||||
|     return true; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| //! sets the position of the audio stream. | ||||
| /** For example to let the stream be read from the beginning of the file again, | ||||
| setPosition(0) would be called. This is usually done be the sound engine to | ||||
| loop a stream after if has reached the end. Return true if sucessful and 0 if not. */ | ||||
| bool CIrrKlangAudioStreamMP3::setPosition(ik_s32 pos) | ||||
| { | ||||
| 	if (!File || !TheMPAuDecContext) | ||||
| 		return false; | ||||
|  | ||||
| 	if (pos == 0) | ||||
| 	{ | ||||
| 		// usually done for looping, just reset to start | ||||
|  | ||||
| 		File->seek(FileBegin); // skip possible ID3 header | ||||
|  | ||||
| 		EndOfFileReached = false; | ||||
|  | ||||
| 		DecodedQueue.clear(); | ||||
|  | ||||
| 		MPAuDecContext oldContext = *TheMPAuDecContext; | ||||
|  | ||||
| 		mpaudec_clear(TheMPAuDecContext); | ||||
| 		mpaudec_init(TheMPAuDecContext); | ||||
|  | ||||
| 		TheMPAuDecContext->bit_rate = oldContext.bit_rate; | ||||
| 		TheMPAuDecContext->channels = oldContext.channels; | ||||
| 		TheMPAuDecContext->frame_size = oldContext.frame_size; | ||||
| 		TheMPAuDecContext->sample_rate = oldContext.sample_rate; | ||||
|  | ||||
| 		InputPosition = 0; | ||||
| 		InputLength = 0; | ||||
| 		Position = 0; | ||||
| 		CurrentFramePosition = 0; | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
| 	else | ||||
| 	{ | ||||
| 		// user wants to seek in the stream, so do this here | ||||
|  | ||||
| 		int scan_position = 0; | ||||
| 		int target_frame = 0; | ||||
| 		int frame_count = (int)FramePositionData.size(); | ||||
|  | ||||
| 		while (target_frame < frame_count) | ||||
| 		{ | ||||
| 			int frame_size = FramePositionData[target_frame].size; | ||||
|  | ||||
| 			if (pos <= scan_position + frame_size) | ||||
| 				break; | ||||
| 			else | ||||
| 			{ | ||||
| 				scan_position += frame_size; | ||||
| 				target_frame++; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
|  | ||||
| 		const int MAX_FRAME_DEPENDENCY = 10; | ||||
| 		target_frame = std::max(0, target_frame - MAX_FRAME_DEPENDENCY); | ||||
| 		setPosition(0); | ||||
|  | ||||
| 		File->seek(FramePositionData[target_frame].offset, false); | ||||
|  | ||||
| 		int i; | ||||
| 		for (i = 0; i < target_frame; i++) | ||||
| 		{ | ||||
| 			if (i>=(int)FramePositionData.size()) | ||||
| 			{ | ||||
| 				// internal error | ||||
| 				setPosition(0); | ||||
| 				return false; | ||||
| 			} | ||||
|  | ||||
| 			Position += FramePositionData[i].size; | ||||
| 		} | ||||
|  | ||||
| 		if (!decodeFrame() || EndOfFileReached) | ||||
| 		{ | ||||
| 			setPosition(0); | ||||
| 			return false; | ||||
| 		} | ||||
|  | ||||
| 		int frames_to_consume = pos - Position; // PCM frames now | ||||
| 		if (frames_to_consume > 0) | ||||
| 		{ | ||||
| 			ik_u8 *buf = new ik_u8[frames_to_consume * Format.getFrameSize()]; | ||||
| 			readFrames(buf, frames_to_consume); | ||||
| 			delete[] buf; | ||||
| 		} | ||||
|  | ||||
|       	return true; | ||||
| 	} | ||||
|  | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
|  | ||||
| CIrrKlangAudioStreamMP3::QueueBuffer::QueueBuffer() | ||||
| { | ||||
| 	Capacity = 256; | ||||
| 	Size = 0; | ||||
|  | ||||
| 	Buffer = (ik_u8*)malloc(Capacity); | ||||
| } | ||||
|  | ||||
|  | ||||
| CIrrKlangAudioStreamMP3::QueueBuffer::~QueueBuffer() | ||||
| { | ||||
| 	free(Buffer); | ||||
| } | ||||
|  | ||||
| int CIrrKlangAudioStreamMP3::QueueBuffer::getSize() | ||||
| { | ||||
| 	return Size; | ||||
| } | ||||
|  | ||||
| void CIrrKlangAudioStreamMP3::QueueBuffer::write(const void* buffer, int size) | ||||
| { | ||||
| 	bool needRealloc = false; | ||||
|  | ||||
| 	while (size + Size > Capacity) | ||||
| 	{ | ||||
| 		Capacity *= 2; | ||||
| 		needRealloc = true; | ||||
| 	} | ||||
|  | ||||
|     if (needRealloc) | ||||
| 	{ | ||||
|         Buffer = (ik_u8*)realloc(Buffer, Capacity); | ||||
|     } | ||||
|  | ||||
| 	memcpy(Buffer + Size, buffer, size); | ||||
| 	Size += size; | ||||
| } | ||||
|  | ||||
|  | ||||
| int CIrrKlangAudioStreamMP3::QueueBuffer::read(void* buffer, int size) | ||||
| { | ||||
| 	int toRead = size < Size ? size : Size; | ||||
|  | ||||
| 	memcpy(buffer, Buffer, toRead); | ||||
| 	memmove(Buffer, Buffer + toRead, Size - toRead); | ||||
|  | ||||
| 	Size -= toRead; | ||||
| 	return toRead; | ||||
| } | ||||
|  | ||||
|  | ||||
| void CIrrKlangAudioStreamMP3::QueueBuffer::clear() | ||||
| { | ||||
| 	Size = 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void CIrrKlangAudioStreamMP3::skipID3IfNecessary() | ||||
| { | ||||
| 	char header[10]; | ||||
| 	int read = File->read(&header, 10); | ||||
|  | ||||
| 	if (read == 10 && | ||||
| 		header[0] == 'I' && header[1] == 'D' && header[2] == '3') | ||||
| 	{ | ||||
| 		int versionMajor = header[3]; | ||||
| 		int versionMinor = header[4]; | ||||
| 		int flags = header[5]; | ||||
|  | ||||
| 		// IDv2 size looks like the following: ID3v2 size  4 * %0xxxxxxx. | ||||
| 		// Sick, but that's how it works. | ||||
|  | ||||
| 		int size = 0; | ||||
| 		size  = (header[6] & 0x7f) << (3*7); | ||||
| 		size |= (header[7] & 0x7f) << (2*7); | ||||
| 		size |= (header[8] & 0x7f) << (1*7); | ||||
| 		size |= (header[9] & 0x7f) ; | ||||
|  | ||||
| 		size += 10; // header size | ||||
|  | ||||
| 		FileBegin = size; | ||||
| 		File->seek(FileBegin); | ||||
| 	} | ||||
| 	else | ||||
| 		File->seek(0); | ||||
| } | ||||
|  | ||||
|  | ||||
| } // end namespace irrklang | ||||
							
								
								
									
										106
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamMP3.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/CIrrKlangAudioStreamMP3.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,106 @@ | ||||
| // Copyright (C) 2002-2007 Nikolaus Gebhardt | ||||
| // Part of the code for this plugin for irrKlang is based on: | ||||
| //  MP3 input for Audiere by Matt Campbell <mattcampbell@pobox.com>, based on | ||||
| //  libavcodec from ffmpeg (http://ffmpeg.sourceforge.net/). | ||||
| // See license.txt for license details of this plugin. | ||||
|  | ||||
| #ifndef __C_IRRKLANG_AUDIO_STREAM_MP3_H_INCLUDED__ | ||||
| #define __C_IRRKLANG_AUDIO_STREAM_MP3_H_INCLUDED__ | ||||
|  | ||||
| #include <ik_IAudioStream.h> | ||||
| #include <ik_IFileReader.h> | ||||
| #include <vector> | ||||
| #include "decoder/mpaudec.h" | ||||
|  | ||||
| namespace irrklang | ||||
| { | ||||
| 	const int IKP_MP3_INPUT_BUFFER_SIZE = 4096; | ||||
|  | ||||
| 	//!	Reads and decodes audio data into an usable audio stream for the ISoundEngine | ||||
| 	/** To extend irrKlang with new audio format decoders, the only thing needed to do | ||||
| 	is implementing the IAudioStream interface. All the code available in this class is only for | ||||
| 	mp3 decoding and may make this class look a bit more complicated then it actually is. */ | ||||
| 	class CIrrKlangAudioStreamMP3 : public IAudioStream | ||||
| 	{ | ||||
| 	public: | ||||
|  | ||||
| 		CIrrKlangAudioStreamMP3(IFileReader* file); | ||||
| 		~CIrrKlangAudioStreamMP3(); | ||||
|  | ||||
| 		//! returns format of the audio stream | ||||
| 		virtual SAudioStreamFormat getFormat(); | ||||
|  | ||||
| 		//! tells the audio stream to read n audio frames into the specified buffer | ||||
| 		/** \param target: Target data buffer to the method will write the read frames into. The | ||||
| 		specified buffer will be getFormat().getFrameSize()*frameCount big. | ||||
| 		\param frameCount: amount of frames to be read. | ||||
| 		\returns Returns amount of frames really read. Should be frameCountToRead in most cases. */ | ||||
| 		virtual ik_s32 readFrames(void* target, ik_s32 frameCountToRead); | ||||
|  | ||||
| 		//! sets the position of the audio stream. | ||||
| 		/** For example to let the stream be read from the beginning of the file again, | ||||
| 		setPosition(0) would be called. This is usually done be the sound engine to | ||||
| 		loop a stream after if has reached the end. Return true if sucessful and 0 if not. */ | ||||
| 		virtual bool setPosition(ik_s32 pos); | ||||
|  | ||||
| 		// just for the CIrrKlangAudioStreamLoaderMP3 to let him know if loading worked | ||||
| 		bool isOK() { return File != 0; } | ||||
|  | ||||
| 	protected: | ||||
|  | ||||
| 		ik_s32 readFrameForMP3(void* target, ik_s32 frameCountToRead, bool parseOnly=false); | ||||
| 		bool decodeFrame(); | ||||
| 		void skipID3IfNecessary(); | ||||
|  | ||||
| 		irrklang::IFileReader* File; | ||||
| 		SAudioStreamFormat Format; | ||||
|  | ||||
| 		// mpaudec specific | ||||
| 		MPAuDecContext* TheMPAuDecContext; | ||||
|  | ||||
| 		ik_u8 InputBuffer[IKP_MP3_INPUT_BUFFER_SIZE]; | ||||
|  | ||||
| 		int InputPosition; | ||||
| 		int InputLength; | ||||
| 		int Position; | ||||
| 		ik_u8* DecodeBuffer; | ||||
| 		ik_s32 FileBegin; | ||||
| 		ik_u32 CurrentFramePosition; | ||||
|  | ||||
| 		bool FirstFrameRead; | ||||
| 		bool EndOfFileReached; | ||||
|  | ||||
| 		// helper class for managing the streaming decoded audio data | ||||
| 		class QueueBuffer | ||||
| 		{ | ||||
| 		public:	 | ||||
|  | ||||
| 			QueueBuffer(); | ||||
| 			~QueueBuffer(); | ||||
|  | ||||
| 			int getSize(); | ||||
| 			void write(const void* buffer, int size); | ||||
| 			int read(void* buffer, int size); | ||||
| 			void clear(); | ||||
|  | ||||
| 		private: | ||||
|  | ||||
| 			ik_u8* Buffer; | ||||
| 			int Capacity; | ||||
| 			int Size; | ||||
| 		}; | ||||
|  | ||||
| 		struct SFramePositionData | ||||
| 		{ | ||||
| 			int offset; | ||||
| 			int size; | ||||
| 		}; | ||||
|  | ||||
| 		std::vector<SFramePositionData> FramePositionData; | ||||
| 		QueueBuffer DecodedQueue; | ||||
| 	}; | ||||
|  | ||||
|  | ||||
| } // end namespace irrklang | ||||
|  | ||||
| #endif | ||||
							
								
								
									
										273
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/bits.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										273
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/bits.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,273 @@ | ||||
| /* | ||||
|  * Common bit i/o utils | ||||
|  * Copyright (c) 2000, 2001 Fabrice Bellard. | ||||
|  * | ||||
|  * This library is free software; you can redistribute it and/or | ||||
|  * modify it under the terms of the GNU Lesser General Public | ||||
|  * License as published by the Free Software Foundation; either | ||||
|  * version 2 of the License, or (at your option) any later version. | ||||
|  * | ||||
|  * This library is distributed in the hope that it will be useful, | ||||
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  * Lesser General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU Lesser General Public | ||||
|  * License along with this library; if not, write to the Free Software | ||||
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | ||||
|  * | ||||
|  * Modified by Matt Campbell <mattcampbell@pobox.com> for the stand-alone | ||||
|  * mpaudec library.  Based on common.c from libavcodec. | ||||
|  */ | ||||
|  | ||||
| #include "internal.h" | ||||
|  | ||||
| /** | ||||
|  * init GetBitContext. | ||||
|  * @param buffer bitstream buffer | ||||
|  * @param bit_size the size of the buffer in bits | ||||
|  */ | ||||
| void init_get_bits(GetBitContext *s, | ||||
|                    const uint8_t *buffer, int bit_size) | ||||
| { | ||||
|     s->buffer= buffer; | ||||
|     s->size_in_bits= bit_size; | ||||
|     s->index=0; | ||||
| } | ||||
|  | ||||
| unsigned int show_bits(const GetBitContext *s, int n) | ||||
| { | ||||
|     int i; | ||||
|     unsigned int result = 0; | ||||
|     assert(s->size_in_bits - s->index >= n); | ||||
|     for (i = s->index; i < s->index + n; i++) { | ||||
|         int byte_index = i / 8; | ||||
|         unsigned int right_shift = 7 - (i % 8); | ||||
|         uint8_t byte = s->buffer[byte_index]; | ||||
|         uint8_t bit; | ||||
|         result <<= 1; | ||||
|         if (right_shift == 0) | ||||
|             bit = byte & 0x1; | ||||
|         else | ||||
|             bit = (byte >> right_shift) & 0x1; | ||||
|         result |= (unsigned int)bit; | ||||
|     } | ||||
|     return result; | ||||
| } | ||||
|  | ||||
| void skip_bits(GetBitContext *s, int n) | ||||
| { | ||||
|     s->index += n; | ||||
| } | ||||
|  | ||||
| unsigned int get_bits(GetBitContext *s, int n) | ||||
| { | ||||
|     unsigned int result = show_bits(s, n); | ||||
|     skip_bits(s, n); | ||||
|     return result; | ||||
| } | ||||
|  | ||||
| int get_bits_count(const GetBitContext *s) | ||||
| { | ||||
|     return s->index; | ||||
| } | ||||
|  | ||||
| /* VLC decoding */ | ||||
|  | ||||
| /*#define DEBUG_VLC*/ | ||||
|  | ||||
| #define GET_DATA(v, table, i, wrap, size) \ | ||||
| {\ | ||||
|     const uint8_t *ptr = (const uint8_t *)table + i * wrap;\ | ||||
|     switch(size) {\ | ||||
|     case 1:\ | ||||
|         v = *(const uint8_t *)ptr;\ | ||||
|         break;\ | ||||
|     case 2:\ | ||||
|         v = *(const uint16_t *)ptr;\ | ||||
|         break;\ | ||||
|     default:\ | ||||
|         v = *(const uint32_t *)ptr;\ | ||||
|         break;\ | ||||
|     }\ | ||||
| } | ||||
|  | ||||
|  | ||||
| static int alloc_table(VLC *vlc, int size) | ||||
| { | ||||
|     int index; | ||||
|     index = vlc->table_size; | ||||
|     vlc->table_size += size; | ||||
|     if (vlc->table_size > vlc->table_allocated) { | ||||
|         vlc->table_allocated += (1 << vlc->bits); | ||||
|         vlc->table = realloc(vlc->table, | ||||
|                              sizeof(VLC_TYPE) * 2 * vlc->table_allocated); | ||||
|         if (!vlc->table) | ||||
|             return -1; | ||||
|     } | ||||
|     return index; | ||||
| } | ||||
|  | ||||
| static int build_table(VLC *vlc, int table_nb_bits, | ||||
|                        int nb_codes, | ||||
|                        const void *bits, int bits_wrap, int bits_size, | ||||
|                        const void *codes, int codes_wrap, int codes_size, | ||||
|                        uint32_t code_prefix, int n_prefix) | ||||
| { | ||||
|     int i, j, k, n, table_size, table_index, nb, n1, index; | ||||
|     uint32_t code; | ||||
|     VLC_TYPE (*table)[2]; | ||||
|  | ||||
|     table_size = 1 << table_nb_bits; | ||||
|     table_index = alloc_table(vlc, table_size); | ||||
| #ifdef DEBUG_VLC | ||||
|     printf("new table index=%d size=%d code_prefix=%x n=%d\n", | ||||
|            table_index, table_size, code_prefix, n_prefix); | ||||
| #endif | ||||
|     if (table_index < 0) | ||||
|         return -1; | ||||
|     table = &vlc->table[table_index]; | ||||
|  | ||||
|     for(i=0;i<table_size;i++) { | ||||
|         table[i][1] = 0; /*bits*/ | ||||
|         table[i][0] = -1; /*codes*/ | ||||
|     } | ||||
|  | ||||
|     /* first pass: map codes and compute auxillary table sizes */ | ||||
|     for(i=0;i<nb_codes;i++) { | ||||
|         GET_DATA(n, bits, i, bits_wrap, bits_size); | ||||
|         GET_DATA(code, codes, i, codes_wrap, codes_size); | ||||
|         /* we accept tables with holes */ | ||||
|         if (n <= 0) | ||||
|             continue; | ||||
| #if defined(DEBUG_VLC) && 0 | ||||
|         printf("i=%d n=%d code=0x%x\n", i, n, code); | ||||
| #endif | ||||
|         /* if code matches the prefix, it is in the table */ | ||||
|         n -= n_prefix; | ||||
|         if (n > 0 && (code >> n) == code_prefix) { | ||||
|             if (n <= table_nb_bits) { | ||||
|                 /* no need to add another table */ | ||||
|                 j = (code << (table_nb_bits - n)) & (table_size - 1); | ||||
|                 nb = 1 << (table_nb_bits - n); | ||||
|                 for(k=0;k<nb;k++) { | ||||
| #ifdef DEBUG_VLC | ||||
|                     printf("%4x: code=%d n=%d\n", | ||||
|                            j, i, n); | ||||
| #endif | ||||
|                     assert(table[j][1] /*bits*/ == 0); | ||||
|                     table[j][1] = n; /*bits*/ | ||||
|                     table[j][0] = i; /*code*/ | ||||
|                     j++; | ||||
|                 } | ||||
|             } else { | ||||
|                 n -= table_nb_bits; | ||||
|                 j = (code >> n) & ((1 << table_nb_bits) - 1); | ||||
| #ifdef DEBUG_VLC | ||||
|                 printf("%4x: n=%d (subtable)\n", | ||||
|                        j, n); | ||||
| #endif | ||||
|                 /* compute table size */ | ||||
|                 n1 = -table[j][1]; /*bits*/ | ||||
|                 if (n > n1) | ||||
|                     n1 = n; | ||||
|                 table[j][1] = -n1; /*bits*/ | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /* second pass : fill auxillary tables recursively */ | ||||
|     for(i=0;i<table_size;i++) { | ||||
|         n = table[i][1]; /*bits*/ | ||||
|         if (n < 0) { | ||||
|             n = -n; | ||||
|             if (n > table_nb_bits) { | ||||
|                 n = table_nb_bits; | ||||
|                 table[i][1] = -n; /*bits*/ | ||||
|             } | ||||
|             index = build_table(vlc, n, nb_codes, | ||||
|                                 bits, bits_wrap, bits_size, | ||||
|                                 codes, codes_wrap, codes_size, | ||||
|                                 (code_prefix << table_nb_bits) | i, | ||||
|                                 n_prefix + table_nb_bits); | ||||
|             if (index < 0) | ||||
|                 return -1; | ||||
|             /* note: realloc has been done, so reload tables */ | ||||
|             table = &vlc->table[table_index]; | ||||
|             table[i][0] = index; /*code*/ | ||||
|         } | ||||
|     } | ||||
|     return table_index; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Build VLC decoding tables suitable for use with get_vlc(). | ||||
|  | ||||
|    'nb_bits' set thee decoding table size (2^nb_bits) entries. The | ||||
|    bigger it is, the faster is the decoding. But it should not be too | ||||
|    big to save memory and L1 cache. '9' is a good compromise. | ||||
|     | ||||
|    'nb_codes' : number of vlcs codes | ||||
|  | ||||
|    'bits' : table which gives the size (in bits) of each vlc code. | ||||
|  | ||||
|    'codes' : table which gives the bit pattern of of each vlc code. | ||||
|  | ||||
|    'xxx_wrap' : give the number of bytes between each entry of the | ||||
|    'bits' or 'codes' tables. | ||||
|  | ||||
|    'xxx_size' : gives the number of bytes of each entry of the 'bits' | ||||
|    or 'codes' tables. | ||||
|  | ||||
|    'wrap' and 'size' allows to use any memory configuration and types | ||||
|    (byte/word/long) to store the 'bits' and 'codes' tables.   | ||||
| */ | ||||
| int init_vlc(VLC *vlc, int nb_bits, int nb_codes, | ||||
|              const void *bits, int bits_wrap, int bits_size, | ||||
|              const void *codes, int codes_wrap, int codes_size) | ||||
| { | ||||
|     vlc->bits = nb_bits; | ||||
|     vlc->table = NULL; | ||||
|     vlc->table_allocated = 0; | ||||
|     vlc->table_size = 0; | ||||
| #ifdef DEBUG_VLC | ||||
|     printf("build table nb_codes=%d\n", nb_codes); | ||||
| #endif | ||||
|  | ||||
|     if (build_table(vlc, nb_bits, nb_codes, | ||||
|                     bits, bits_wrap, bits_size, | ||||
|                     codes, codes_wrap, codes_size, | ||||
|                     0, 0) < 0) { | ||||
|         free(vlc->table); | ||||
|         return -1; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| void free_vlc(VLC *vlc) | ||||
| { | ||||
|     free(vlc->table); | ||||
| } | ||||
|  | ||||
| int get_vlc(GetBitContext *s, const VLC *vlc) | ||||
| { | ||||
|     int code = 0; | ||||
|     int depth = 0, max_depth = 3; | ||||
|     int n, index, bits = vlc->bits; | ||||
|      | ||||
|     do { | ||||
|         index = show_bits(s, bits) + code; | ||||
|         code = vlc->table[index][0]; | ||||
|         n = vlc->table[index][1]; | ||||
|         depth++; | ||||
|  | ||||
|         if (n < 0 && depth < max_depth) { | ||||
|             skip_bits(s, bits); | ||||
|             bits = -n; | ||||
|         } | ||||
|     } while (n < 0 && depth < max_depth); | ||||
|  | ||||
|     skip_bits(s, n); | ||||
|     return code; | ||||
| } | ||||
							
								
								
									
										86
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/internal.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/internal.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| /* Based on common.h from libavcodec.  Modified extensively by Matt Campbell | ||||
|    <mattcampbell@pobox.com> for the stand-alone mpaudec library. */ | ||||
|  | ||||
| #ifndef INTERNAL_H | ||||
| #define INTERNAL_H | ||||
|  | ||||
| #if defined(_WIN32) && !defined(__MINGW32__) && !defined(__CYGWIN__) | ||||
| #    define CONFIG_WIN32 | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include <ctype.h> | ||||
| #include <math.h> | ||||
| #include <stddef.h> | ||||
| #include "mpaudec.h" | ||||
|  | ||||
| #ifndef M_PI | ||||
| #define M_PI    3.14159265358979323846 | ||||
| #endif | ||||
|  | ||||
| #ifdef CONFIG_WIN32 | ||||
|  | ||||
| /* windows */ | ||||
|  | ||||
| typedef unsigned short uint16_t; | ||||
| typedef signed short int16_t; | ||||
| typedef unsigned char uint8_t; | ||||
| typedef unsigned int uint32_t; | ||||
| typedef unsigned __int64 uint64_t; | ||||
| typedef signed char int8_t; | ||||
| typedef signed int int32_t; | ||||
| typedef signed __int64 int64_t; | ||||
|  | ||||
| #    ifdef _DEBUG | ||||
| #        define DEBUG | ||||
| #    endif | ||||
|  | ||||
| /* CONFIG_WIN32 end */ | ||||
| #else | ||||
|  | ||||
| /* unix */ | ||||
|  | ||||
| #include <inttypes.h> | ||||
|  | ||||
| #endif /* !CONFIG_WIN32 */ | ||||
|  | ||||
| /* debug stuff */ | ||||
|  | ||||
| #if !defined(DEBUG) && !defined(NDEBUG) | ||||
| #    define NDEBUG | ||||
| #endif | ||||
| #include <assert.h> | ||||
|  | ||||
| /* bit input */ | ||||
|  | ||||
| typedef struct GetBitContext { | ||||
|     const uint8_t *buffer; | ||||
|     int index; | ||||
|     int size_in_bits; | ||||
| } GetBitContext; | ||||
|  | ||||
| int get_bits_count(const GetBitContext *s); | ||||
|  | ||||
| #define VLC_TYPE int16_t | ||||
|  | ||||
| typedef struct VLC { | ||||
|     int bits; | ||||
|     VLC_TYPE (*table)[2]; | ||||
|     int table_size, table_allocated; | ||||
| } VLC; | ||||
|  | ||||
| unsigned int get_bits(GetBitContext *s, int n); | ||||
| unsigned int show_bits(const GetBitContext *s, int n); | ||||
| void skip_bits(GetBitContext *s, int n); | ||||
| void init_get_bits(GetBitContext *s, | ||||
|                    const uint8_t *buffer, int buffer_size); | ||||
|  | ||||
| int init_vlc(VLC *vlc, int nb_bits, int nb_codes, | ||||
|              const void *bits, int bits_wrap, int bits_size, | ||||
|              const void *codes, int codes_wrap, int codes_size); | ||||
| void free_vlc(VLC *vlc); | ||||
| int get_vlc(GetBitContext *s, const VLC *vlc); | ||||
|  | ||||
| #endif /* INTERNAL_H */ | ||||
							
								
								
									
										2477
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudec.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2477
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudec.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										34
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudec.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudec.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
| /* Portions based on avcodec.h from libavcodec. */ | ||||
|  | ||||
| #ifndef MPAUDEC_H | ||||
| #define MPAUDEC_H | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /* in bytes */ | ||||
| #define MPAUDEC_MAX_AUDIO_FRAME_SIZE 4608 | ||||
|  | ||||
| typedef struct MPAuDecContext { | ||||
|     int bit_rate; | ||||
|     int layer; | ||||
|     int sample_rate; | ||||
|     int channels; | ||||
|     int frame_size; | ||||
|     void *priv_data; | ||||
|     int parse_only; | ||||
|     int coded_frame_size; | ||||
| } MPAuDecContext; | ||||
|  | ||||
| int mpaudec_init(MPAuDecContext *mpctx); | ||||
| int mpaudec_decode_frame(MPAuDecContext * mpctx, | ||||
|                          void *data, int *data_size, | ||||
|                          const unsigned char * buf, int buf_size); | ||||
| void mpaudec_clear(MPAuDecContext *mpctx); | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } | ||||
| #endif | ||||
|  | ||||
| #endif /* MPAUDEC_H */ | ||||
							
								
								
									
										772
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudectab.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										772
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpaudectab.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,772 @@ | ||||
| /* Modified slightly by Matt Campbell <mattcampbell@pobox.com> for the | ||||
|    stand-alone mpaudec library.  Based on mpegaudiodectab.h from libavcodec. */ | ||||
|  | ||||
| static const uint16_t mpa_bitrate_tab[2][3][15] = { | ||||
|     { {0, 32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448 }, | ||||
|       {0, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384 }, | ||||
|       {0, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320 } }, | ||||
|     { {0, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256}, | ||||
|       {0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160}, | ||||
|       {0, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160} | ||||
|     } | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_freq_tab[3] = { 44100, 48000, 32000 }; | ||||
|  | ||||
| /*******************************************************/ | ||||
| /* half mpeg encoding window (full precision) */ | ||||
| static const int32_t mpa_enwindow[257] = { | ||||
|      0,    -1,    -1,    -1,    -1,    -1,    -1,    -2, | ||||
|     -2,    -2,    -2,    -3,    -3,    -4,    -4,    -5, | ||||
|     -5,    -6,    -7,    -7,    -8,    -9,   -10,   -11, | ||||
|    -13,   -14,   -16,   -17,   -19,   -21,   -24,   -26, | ||||
|    -29,   -31,   -35,   -38,   -41,   -45,   -49,   -53, | ||||
|    -58,   -63,   -68,   -73,   -79,   -85,   -91,   -97, | ||||
|   -104,  -111,  -117,  -125,  -132,  -139,  -147,  -154, | ||||
|   -161,  -169,  -176,  -183,  -190,  -196,  -202,  -208, | ||||
|    213,   218,   222,   225,   227,   228,   228,   227, | ||||
|    224,   221,   215,   208,   200,   189,   177,   163, | ||||
|    146,   127,   106,    83,    57,    29,    -2,   -36, | ||||
|    -72,  -111,  -153,  -197,  -244,  -294,  -347,  -401, | ||||
|   -459,  -519,  -581,  -645,  -711,  -779,  -848,  -919, | ||||
|   -991, -1064, -1137, -1210, -1283, -1356, -1428, -1498, | ||||
|  -1567, -1634, -1698, -1759, -1817, -1870, -1919, -1962, | ||||
|  -2001, -2032, -2057, -2075, -2085, -2087, -2080, -2063, | ||||
|   2037,  2000,  1952,  1893,  1822,  1739,  1644,  1535, | ||||
|   1414,  1280,  1131,   970,   794,   605,   402,   185, | ||||
|    -45,  -288,  -545,  -814, -1095, -1388, -1692, -2006, | ||||
|  -2330, -2663, -3004, -3351, -3705, -4063, -4425, -4788, | ||||
|  -5153, -5517, -5879, -6237, -6589, -6935, -7271, -7597, | ||||
|  -7910, -8209, -8491, -8755, -8998, -9219, -9416, -9585, | ||||
|  -9727, -9838, -9916, -9959, -9966, -9935, -9863, -9750, | ||||
|  -9592, -9389, -9139, -8840, -8492, -8092, -7640, -7134, | ||||
|   6574,  5959,  5288,  4561,  3776,  2935,  2037,  1082, | ||||
|     70,  -998, -2122, -3300, -4533, -5818, -7154, -8540, | ||||
|  -9975,-11455,-12980,-14548,-16155,-17799,-19478,-21189, | ||||
| -22929,-24694,-26482,-28289,-30112,-31947,-33791,-35640, | ||||
| -37489,-39336,-41176,-43006,-44821,-46617,-48390,-50137, | ||||
| -51853,-53534,-55178,-56778,-58333,-59838,-61289,-62684, | ||||
| -64019,-65290,-66494,-67629,-68692,-69679,-70590,-71420, | ||||
| -72169,-72835,-73415,-73908,-74313,-74630,-74856,-74992, | ||||
|  75038, | ||||
| }; | ||||
|  | ||||
| /*******************************************************/ | ||||
| /* layer 2 tables */ | ||||
|  | ||||
| static const int sblimit_table[5] = { 27 , 30 , 8, 12 , 30 }; | ||||
|  | ||||
| static const int quant_steps[17] = { | ||||
|     3,     5,    7,    9,    15, | ||||
|     31,    63,  127,  255,   511, | ||||
|     1023,  2047, 4095, 8191, 16383, | ||||
|     32767, 65535 | ||||
| }; | ||||
|  | ||||
| /* we use a negative value if grouped */ | ||||
| static const int quant_bits[17] = { | ||||
|     -5,  -7,  3, -10, 4,  | ||||
|      5,  6,  7,  8,  9, | ||||
|     10, 11, 12, 13, 14, | ||||
|     15, 16  | ||||
| }; | ||||
|  | ||||
| /* encoding tables which give the quantization index. Note how it is | ||||
|    possible to store them efficiently ! */ | ||||
| static const unsigned char alloc_table_0[] = { | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
| }; | ||||
|  | ||||
| static const unsigned char alloc_table_1[] = { | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  2,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  3,  0,  1,  2,  3,  4,  5, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
|  2,  0,  1, 16,  | ||||
| }; | ||||
|  | ||||
| static const unsigned char alloc_table_2[] = { | ||||
|  4,  0,  1,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15,  | ||||
|  4,  0,  1,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
| }; | ||||
|  | ||||
| static const unsigned char alloc_table_3[] = { | ||||
|  4,  0,  1,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15,  | ||||
|  4,  0,  1,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
| }; | ||||
|  | ||||
| static const unsigned char alloc_table_4[] = { | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,  | ||||
|  4,  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  3,  0,  1,  3,  4,  5,  6,  7,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
|  2,  0,  1,  3,  | ||||
| }; | ||||
|  | ||||
| static const unsigned char *alloc_tables[5] =  | ||||
| { alloc_table_0, alloc_table_1, alloc_table_2, alloc_table_3, alloc_table_4, }; | ||||
|  | ||||
| /*******************************************************/ | ||||
| /* layer 3 tables */ | ||||
|  | ||||
| /* layer3 scale factor size */ | ||||
| static const uint8_t slen_table[2][16] = { | ||||
|     { 0, 0, 0, 0, 3, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4 }, | ||||
|     { 0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3 }, | ||||
| }; | ||||
|  | ||||
| /* number of lsf scale factors for a given size */ | ||||
| static const uint8_t lsf_nsf_table[6][3][4] = { | ||||
|     { {  6,  5,  5, 5 }, {  9,  9,  9, 9 }, {  6,  9,  9, 9 } }, | ||||
|     { {  6,  5,  7, 3 }, {  9,  9, 12, 6 }, {  6,  9, 12, 6 } }, | ||||
|     { { 11, 10,  0, 0 }, { 18, 18,  0, 0 }, { 15, 18,  0, 0 } }, | ||||
|     { {  7,  7,  7, 0 }, { 12, 12, 12, 0 }, {  6, 15, 12, 0 } },  | ||||
|     { {  6,  6,  6, 3 }, { 12,  9,  9, 6 }, {  6, 12,  9, 6 } }, | ||||
|     { {  8,  8,  5, 0 }, { 15, 12,  9, 0 }, {  6, 18,  9, 0 } }, | ||||
| }; | ||||
|  | ||||
| /* mpegaudio layer 3 huffman tables */ | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_1[4] = { | ||||
|  0x0001, 0x0001, 0x0001, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_1[4] = { | ||||
|   1,  3,  2,  3, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_2[9] = { | ||||
|  0x0001, 0x0002, 0x0001, 0x0003, 0x0001, 0x0001, 0x0003, 0x0002, | ||||
|  0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_2[9] = { | ||||
|   1,  3,  6,  3,  3,  5,  5,  5, | ||||
|   6, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_3[9] = { | ||||
|  0x0003, 0x0002, 0x0001, 0x0001, 0x0001, 0x0001, 0x0003, 0x0002, | ||||
|  0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_3[9] = { | ||||
|   2,  2,  6,  3,  2,  5,  5,  5, | ||||
|   6, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_5[16] = { | ||||
|  0x0001, 0x0002, 0x0006, 0x0005, 0x0003, 0x0001, 0x0004, 0x0004, | ||||
|  0x0007, 0x0005, 0x0007, 0x0001, 0x0006, 0x0001, 0x0001, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_5[16] = { | ||||
|   1,  3,  6,  7,  3,  3,  6,  7, | ||||
|   6,  6,  7,  8,  7,  6,  7,  8, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_6[16] = { | ||||
|  0x0007, 0x0003, 0x0005, 0x0001, 0x0006, 0x0002, 0x0003, 0x0002, | ||||
|  0x0005, 0x0004, 0x0004, 0x0001, 0x0003, 0x0003, 0x0002, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_6[16] = { | ||||
|   3,  3,  5,  7,  3,  2,  4,  5, | ||||
|   4,  4,  5,  6,  6,  5,  6,  7, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_7[36] = { | ||||
|  0x0001, 0x0002, 0x000a, 0x0013, 0x0010, 0x000a, 0x0003, 0x0003, | ||||
|  0x0007, 0x000a, 0x0005, 0x0003, 0x000b, 0x0004, 0x000d, 0x0011, | ||||
|  0x0008, 0x0004, 0x000c, 0x000b, 0x0012, 0x000f, 0x000b, 0x0002, | ||||
|  0x0007, 0x0006, 0x0009, 0x000e, 0x0003, 0x0001, 0x0006, 0x0004, | ||||
|  0x0005, 0x0003, 0x0002, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_7[36] = { | ||||
|   1,  3,  6,  8,  8,  9,  3,  4, | ||||
|   6,  7,  7,  8,  6,  5,  7,  8, | ||||
|   8,  9,  7,  7,  8,  9,  9,  9, | ||||
|   7,  7,  8,  9,  9, 10,  8,  8, | ||||
|   9, 10, 10, 10, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_8[36] = { | ||||
|  0x0003, 0x0004, 0x0006, 0x0012, 0x000c, 0x0005, 0x0005, 0x0001, | ||||
|  0x0002, 0x0010, 0x0009, 0x0003, 0x0007, 0x0003, 0x0005, 0x000e, | ||||
|  0x0007, 0x0003, 0x0013, 0x0011, 0x000f, 0x000d, 0x000a, 0x0004, | ||||
|  0x000d, 0x0005, 0x0008, 0x000b, 0x0005, 0x0001, 0x000c, 0x0004, | ||||
|  0x0004, 0x0001, 0x0001, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_8[36] = { | ||||
|   2,  3,  6,  8,  8,  9,  3,  2, | ||||
|   4,  8,  8,  8,  6,  4,  6,  8, | ||||
|   8,  9,  8,  8,  8,  9,  9, 10, | ||||
|   8,  7,  8,  9, 10, 10,  9,  8, | ||||
|   9,  9, 11, 11, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_9[36] = { | ||||
|  0x0007, 0x0005, 0x0009, 0x000e, 0x000f, 0x0007, 0x0006, 0x0004, | ||||
|  0x0005, 0x0005, 0x0006, 0x0007, 0x0007, 0x0006, 0x0008, 0x0008, | ||||
|  0x0008, 0x0005, 0x000f, 0x0006, 0x0009, 0x000a, 0x0005, 0x0001, | ||||
|  0x000b, 0x0007, 0x0009, 0x0006, 0x0004, 0x0001, 0x000e, 0x0004, | ||||
|  0x0006, 0x0002, 0x0006, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_9[36] = { | ||||
|   3,  3,  5,  6,  8,  9,  3,  3, | ||||
|   4,  5,  6,  8,  4,  4,  5,  6, | ||||
|   7,  8,  6,  5,  6,  7,  7,  8, | ||||
|   7,  6,  7,  7,  8,  9,  8,  7, | ||||
|   8,  8,  9,  9, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_10[64] = { | ||||
|  0x0001, 0x0002, 0x000a, 0x0017, 0x0023, 0x001e, 0x000c, 0x0011, | ||||
|  0x0003, 0x0003, 0x0008, 0x000c, 0x0012, 0x0015, 0x000c, 0x0007, | ||||
|  0x000b, 0x0009, 0x000f, 0x0015, 0x0020, 0x0028, 0x0013, 0x0006, | ||||
|  0x000e, 0x000d, 0x0016, 0x0022, 0x002e, 0x0017, 0x0012, 0x0007, | ||||
|  0x0014, 0x0013, 0x0021, 0x002f, 0x001b, 0x0016, 0x0009, 0x0003, | ||||
|  0x001f, 0x0016, 0x0029, 0x001a, 0x0015, 0x0014, 0x0005, 0x0003, | ||||
|  0x000e, 0x000d, 0x000a, 0x000b, 0x0010, 0x0006, 0x0005, 0x0001, | ||||
|  0x0009, 0x0008, 0x0007, 0x0008, 0x0004, 0x0004, 0x0002, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_10[64] = { | ||||
|   1,  3,  6,  8,  9,  9,  9, 10, | ||||
|   3,  4,  6,  7,  8,  9,  8,  8, | ||||
|   6,  6,  7,  8,  9, 10,  9,  9, | ||||
|   7,  7,  8,  9, 10, 10,  9, 10, | ||||
|   8,  8,  9, 10, 10, 10, 10, 10, | ||||
|   9,  9, 10, 10, 11, 11, 10, 11, | ||||
|   8,  8,  9, 10, 10, 10, 11, 11, | ||||
|   9,  8,  9, 10, 10, 11, 11, 11, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_11[64] = { | ||||
|  0x0003, 0x0004, 0x000a, 0x0018, 0x0022, 0x0021, 0x0015, 0x000f, | ||||
|  0x0005, 0x0003, 0x0004, 0x000a, 0x0020, 0x0011, 0x000b, 0x000a, | ||||
|  0x000b, 0x0007, 0x000d, 0x0012, 0x001e, 0x001f, 0x0014, 0x0005, | ||||
|  0x0019, 0x000b, 0x0013, 0x003b, 0x001b, 0x0012, 0x000c, 0x0005, | ||||
|  0x0023, 0x0021, 0x001f, 0x003a, 0x001e, 0x0010, 0x0007, 0x0005, | ||||
|  0x001c, 0x001a, 0x0020, 0x0013, 0x0011, 0x000f, 0x0008, 0x000e, | ||||
|  0x000e, 0x000c, 0x0009, 0x000d, 0x000e, 0x0009, 0x0004, 0x0001, | ||||
|  0x000b, 0x0004, 0x0006, 0x0006, 0x0006, 0x0003, 0x0002, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_11[64] = { | ||||
|   2,  3,  5,  7,  8,  9,  8,  9, | ||||
|   3,  3,  4,  6,  8,  8,  7,  8, | ||||
|   5,  5,  6,  7,  8,  9,  8,  8, | ||||
|   7,  6,  7,  9,  8, 10,  8,  9, | ||||
|   8,  8,  8,  9,  9, 10,  9, 10, | ||||
|   8,  8,  9, 10, 10, 11, 10, 11, | ||||
|   8,  7,  7,  8,  9, 10, 10, 10, | ||||
|   8,  7,  8,  9, 10, 10, 10, 10, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_12[64] = { | ||||
|  0x0009, 0x0006, 0x0010, 0x0021, 0x0029, 0x0027, 0x0026, 0x001a, | ||||
|  0x0007, 0x0005, 0x0006, 0x0009, 0x0017, 0x0010, 0x001a, 0x000b, | ||||
|  0x0011, 0x0007, 0x000b, 0x000e, 0x0015, 0x001e, 0x000a, 0x0007, | ||||
|  0x0011, 0x000a, 0x000f, 0x000c, 0x0012, 0x001c, 0x000e, 0x0005, | ||||
|  0x0020, 0x000d, 0x0016, 0x0013, 0x0012, 0x0010, 0x0009, 0x0005, | ||||
|  0x0028, 0x0011, 0x001f, 0x001d, 0x0011, 0x000d, 0x0004, 0x0002, | ||||
|  0x001b, 0x000c, 0x000b, 0x000f, 0x000a, 0x0007, 0x0004, 0x0001, | ||||
|  0x001b, 0x000c, 0x0008, 0x000c, 0x0006, 0x0003, 0x0001, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_12[64] = { | ||||
|   4,  3,  5,  7,  8,  9,  9,  9, | ||||
|   3,  3,  4,  5,  7,  7,  8,  8, | ||||
|   5,  4,  5,  6,  7,  8,  7,  8, | ||||
|   6,  5,  6,  6,  7,  8,  8,  8, | ||||
|   7,  6,  7,  7,  8,  8,  8,  9, | ||||
|   8,  7,  8,  8,  8,  9,  8,  9, | ||||
|   8,  7,  7,  8,  8,  9,  9, 10, | ||||
|   9,  8,  8,  9,  9,  9,  9, 10, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_13[256] = { | ||||
|  0x0001, 0x0005, 0x000e, 0x0015, 0x0022, 0x0033, 0x002e, 0x0047, | ||||
|  0x002a, 0x0034, 0x0044, 0x0034, 0x0043, 0x002c, 0x002b, 0x0013, | ||||
|  0x0003, 0x0004, 0x000c, 0x0013, 0x001f, 0x001a, 0x002c, 0x0021, | ||||
|  0x001f, 0x0018, 0x0020, 0x0018, 0x001f, 0x0023, 0x0016, 0x000e, | ||||
|  0x000f, 0x000d, 0x0017, 0x0024, 0x003b, 0x0031, 0x004d, 0x0041, | ||||
|  0x001d, 0x0028, 0x001e, 0x0028, 0x001b, 0x0021, 0x002a, 0x0010, | ||||
|  0x0016, 0x0014, 0x0025, 0x003d, 0x0038, 0x004f, 0x0049, 0x0040, | ||||
|  0x002b, 0x004c, 0x0038, 0x0025, 0x001a, 0x001f, 0x0019, 0x000e, | ||||
|  0x0023, 0x0010, 0x003c, 0x0039, 0x0061, 0x004b, 0x0072, 0x005b, | ||||
|  0x0036, 0x0049, 0x0037, 0x0029, 0x0030, 0x0035, 0x0017, 0x0018, | ||||
|  0x003a, 0x001b, 0x0032, 0x0060, 0x004c, 0x0046, 0x005d, 0x0054, | ||||
|  0x004d, 0x003a, 0x004f, 0x001d, 0x004a, 0x0031, 0x0029, 0x0011, | ||||
|  0x002f, 0x002d, 0x004e, 0x004a, 0x0073, 0x005e, 0x005a, 0x004f, | ||||
|  0x0045, 0x0053, 0x0047, 0x0032, 0x003b, 0x0026, 0x0024, 0x000f, | ||||
|  0x0048, 0x0022, 0x0038, 0x005f, 0x005c, 0x0055, 0x005b, 0x005a, | ||||
|  0x0056, 0x0049, 0x004d, 0x0041, 0x0033, 0x002c, 0x002b, 0x002a, | ||||
|  0x002b, 0x0014, 0x001e, 0x002c, 0x0037, 0x004e, 0x0048, 0x0057, | ||||
|  0x004e, 0x003d, 0x002e, 0x0036, 0x0025, 0x001e, 0x0014, 0x0010, | ||||
|  0x0035, 0x0019, 0x0029, 0x0025, 0x002c, 0x003b, 0x0036, 0x0051, | ||||
|  0x0042, 0x004c, 0x0039, 0x0036, 0x0025, 0x0012, 0x0027, 0x000b, | ||||
|  0x0023, 0x0021, 0x001f, 0x0039, 0x002a, 0x0052, 0x0048, 0x0050, | ||||
|  0x002f, 0x003a, 0x0037, 0x0015, 0x0016, 0x001a, 0x0026, 0x0016, | ||||
|  0x0035, 0x0019, 0x0017, 0x0026, 0x0046, 0x003c, 0x0033, 0x0024, | ||||
|  0x0037, 0x001a, 0x0022, 0x0017, 0x001b, 0x000e, 0x0009, 0x0007, | ||||
|  0x0022, 0x0020, 0x001c, 0x0027, 0x0031, 0x004b, 0x001e, 0x0034, | ||||
|  0x0030, 0x0028, 0x0034, 0x001c, 0x0012, 0x0011, 0x0009, 0x0005, | ||||
|  0x002d, 0x0015, 0x0022, 0x0040, 0x0038, 0x0032, 0x0031, 0x002d, | ||||
|  0x001f, 0x0013, 0x000c, 0x000f, 0x000a, 0x0007, 0x0006, 0x0003, | ||||
|  0x0030, 0x0017, 0x0014, 0x0027, 0x0024, 0x0023, 0x0035, 0x0015, | ||||
|  0x0010, 0x0017, 0x000d, 0x000a, 0x0006, 0x0001, 0x0004, 0x0002, | ||||
|  0x0010, 0x000f, 0x0011, 0x001b, 0x0019, 0x0014, 0x001d, 0x000b, | ||||
|  0x0011, 0x000c, 0x0010, 0x0008, 0x0001, 0x0001, 0x0000, 0x0001, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_13[256] = { | ||||
|   1,  4,  6,  7,  8,  9,  9, 10, | ||||
|   9, 10, 11, 11, 12, 12, 13, 13, | ||||
|   3,  4,  6,  7,  8,  8,  9,  9, | ||||
|   9,  9, 10, 10, 11, 12, 12, 12, | ||||
|   6,  6,  7,  8,  9,  9, 10, 10, | ||||
|   9, 10, 10, 11, 11, 12, 13, 13, | ||||
|   7,  7,  8,  9,  9, 10, 10, 10, | ||||
|  10, 11, 11, 11, 11, 12, 13, 13, | ||||
|   8,  7,  9,  9, 10, 10, 11, 11, | ||||
|  10, 11, 11, 12, 12, 13, 13, 14, | ||||
|   9,  8,  9, 10, 10, 10, 11, 11, | ||||
|  11, 11, 12, 11, 13, 13, 14, 14, | ||||
|   9,  9, 10, 10, 11, 11, 11, 11, | ||||
|  11, 12, 12, 12, 13, 13, 14, 14, | ||||
|  10,  9, 10, 11, 11, 11, 12, 12, | ||||
|  12, 12, 13, 13, 13, 14, 16, 16, | ||||
|   9,  8,  9, 10, 10, 11, 11, 12, | ||||
|  12, 12, 12, 13, 13, 14, 15, 15, | ||||
|  10,  9, 10, 10, 11, 11, 11, 13, | ||||
|  12, 13, 13, 14, 14, 14, 16, 15, | ||||
|  10, 10, 10, 11, 11, 12, 12, 13, | ||||
|  12, 13, 14, 13, 14, 15, 16, 17, | ||||
|  11, 10, 10, 11, 12, 12, 12, 12, | ||||
|  13, 13, 13, 14, 15, 15, 15, 16, | ||||
|  11, 11, 11, 12, 12, 13, 12, 13, | ||||
|  14, 14, 15, 15, 15, 16, 16, 16, | ||||
|  12, 11, 12, 13, 13, 13, 14, 14, | ||||
|  14, 14, 14, 15, 16, 15, 16, 16, | ||||
|  13, 12, 12, 13, 13, 13, 15, 14, | ||||
|  14, 17, 15, 15, 15, 17, 16, 16, | ||||
|  12, 12, 13, 14, 14, 14, 15, 14, | ||||
|  15, 15, 16, 16, 19, 18, 19, 16, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_15[256] = { | ||||
|  0x0007, 0x000c, 0x0012, 0x0035, 0x002f, 0x004c, 0x007c, 0x006c, | ||||
|  0x0059, 0x007b, 0x006c, 0x0077, 0x006b, 0x0051, 0x007a, 0x003f, | ||||
|  0x000d, 0x0005, 0x0010, 0x001b, 0x002e, 0x0024, 0x003d, 0x0033, | ||||
|  0x002a, 0x0046, 0x0034, 0x0053, 0x0041, 0x0029, 0x003b, 0x0024, | ||||
|  0x0013, 0x0011, 0x000f, 0x0018, 0x0029, 0x0022, 0x003b, 0x0030, | ||||
|  0x0028, 0x0040, 0x0032, 0x004e, 0x003e, 0x0050, 0x0038, 0x0021, | ||||
|  0x001d, 0x001c, 0x0019, 0x002b, 0x0027, 0x003f, 0x0037, 0x005d, | ||||
|  0x004c, 0x003b, 0x005d, 0x0048, 0x0036, 0x004b, 0x0032, 0x001d, | ||||
|  0x0034, 0x0016, 0x002a, 0x0028, 0x0043, 0x0039, 0x005f, 0x004f, | ||||
|  0x0048, 0x0039, 0x0059, 0x0045, 0x0031, 0x0042, 0x002e, 0x001b, | ||||
|  0x004d, 0x0025, 0x0023, 0x0042, 0x003a, 0x0034, 0x005b, 0x004a, | ||||
|  0x003e, 0x0030, 0x004f, 0x003f, 0x005a, 0x003e, 0x0028, 0x0026, | ||||
|  0x007d, 0x0020, 0x003c, 0x0038, 0x0032, 0x005c, 0x004e, 0x0041, | ||||
|  0x0037, 0x0057, 0x0047, 0x0033, 0x0049, 0x0033, 0x0046, 0x001e, | ||||
|  0x006d, 0x0035, 0x0031, 0x005e, 0x0058, 0x004b, 0x0042, 0x007a, | ||||
|  0x005b, 0x0049, 0x0038, 0x002a, 0x0040, 0x002c, 0x0015, 0x0019, | ||||
|  0x005a, 0x002b, 0x0029, 0x004d, 0x0049, 0x003f, 0x0038, 0x005c, | ||||
|  0x004d, 0x0042, 0x002f, 0x0043, 0x0030, 0x0035, 0x0024, 0x0014, | ||||
|  0x0047, 0x0022, 0x0043, 0x003c, 0x003a, 0x0031, 0x0058, 0x004c, | ||||
|  0x0043, 0x006a, 0x0047, 0x0036, 0x0026, 0x0027, 0x0017, 0x000f, | ||||
|  0x006d, 0x0035, 0x0033, 0x002f, 0x005a, 0x0052, 0x003a, 0x0039, | ||||
|  0x0030, 0x0048, 0x0039, 0x0029, 0x0017, 0x001b, 0x003e, 0x0009, | ||||
|  0x0056, 0x002a, 0x0028, 0x0025, 0x0046, 0x0040, 0x0034, 0x002b, | ||||
|  0x0046, 0x0037, 0x002a, 0x0019, 0x001d, 0x0012, 0x000b, 0x000b, | ||||
|  0x0076, 0x0044, 0x001e, 0x0037, 0x0032, 0x002e, 0x004a, 0x0041, | ||||
|  0x0031, 0x0027, 0x0018, 0x0010, 0x0016, 0x000d, 0x000e, 0x0007, | ||||
|  0x005b, 0x002c, 0x0027, 0x0026, 0x0022, 0x003f, 0x0034, 0x002d, | ||||
|  0x001f, 0x0034, 0x001c, 0x0013, 0x000e, 0x0008, 0x0009, 0x0003, | ||||
|  0x007b, 0x003c, 0x003a, 0x0035, 0x002f, 0x002b, 0x0020, 0x0016, | ||||
|  0x0025, 0x0018, 0x0011, 0x000c, 0x000f, 0x000a, 0x0002, 0x0001, | ||||
|  0x0047, 0x0025, 0x0022, 0x001e, 0x001c, 0x0014, 0x0011, 0x001a, | ||||
|  0x0015, 0x0010, 0x000a, 0x0006, 0x0008, 0x0006, 0x0002, 0x0000, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_15[256] = { | ||||
|   3,  4,  5,  7,  7,  8,  9,  9, | ||||
|   9, 10, 10, 11, 11, 11, 12, 13, | ||||
|   4,  3,  5,  6,  7,  7,  8,  8, | ||||
|   8,  9,  9, 10, 10, 10, 11, 11, | ||||
|   5,  5,  5,  6,  7,  7,  8,  8, | ||||
|   8,  9,  9, 10, 10, 11, 11, 11, | ||||
|   6,  6,  6,  7,  7,  8,  8,  9, | ||||
|   9,  9, 10, 10, 10, 11, 11, 11, | ||||
|   7,  6,  7,  7,  8,  8,  9,  9, | ||||
|   9,  9, 10, 10, 10, 11, 11, 11, | ||||
|   8,  7,  7,  8,  8,  8,  9,  9, | ||||
|   9,  9, 10, 10, 11, 11, 11, 12, | ||||
|   9,  7,  8,  8,  8,  9,  9,  9, | ||||
|   9, 10, 10, 10, 11, 11, 12, 12, | ||||
|   9,  8,  8,  9,  9,  9,  9, 10, | ||||
|  10, 10, 10, 10, 11, 11, 11, 12, | ||||
|   9,  8,  8,  9,  9,  9,  9, 10, | ||||
|  10, 10, 10, 11, 11, 12, 12, 12, | ||||
|   9,  8,  9,  9,  9,  9, 10, 10, | ||||
|  10, 11, 11, 11, 11, 12, 12, 12, | ||||
|  10,  9,  9,  9, 10, 10, 10, 10, | ||||
|  10, 11, 11, 11, 11, 12, 13, 12, | ||||
|  10,  9,  9,  9, 10, 10, 10, 10, | ||||
|  11, 11, 11, 11, 12, 12, 12, 13, | ||||
|  11, 10,  9, 10, 10, 10, 11, 11, | ||||
|  11, 11, 11, 11, 12, 12, 13, 13, | ||||
|  11, 10, 10, 10, 10, 11, 11, 11, | ||||
|  11, 12, 12, 12, 12, 12, 13, 13, | ||||
|  12, 11, 11, 11, 11, 11, 11, 11, | ||||
|  12, 12, 12, 12, 13, 13, 12, 13, | ||||
|  12, 11, 11, 11, 11, 11, 11, 12, | ||||
|  12, 12, 12, 12, 13, 13, 13, 13, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_16[256] = { | ||||
|  0x0001, 0x0005, 0x000e, 0x002c, 0x004a, 0x003f, 0x006e, 0x005d, | ||||
|  0x00ac, 0x0095, 0x008a, 0x00f2, 0x00e1, 0x00c3, 0x0178, 0x0011, | ||||
|  0x0003, 0x0004, 0x000c, 0x0014, 0x0023, 0x003e, 0x0035, 0x002f, | ||||
|  0x0053, 0x004b, 0x0044, 0x0077, 0x00c9, 0x006b, 0x00cf, 0x0009, | ||||
|  0x000f, 0x000d, 0x0017, 0x0026, 0x0043, 0x003a, 0x0067, 0x005a, | ||||
|  0x00a1, 0x0048, 0x007f, 0x0075, 0x006e, 0x00d1, 0x00ce, 0x0010, | ||||
|  0x002d, 0x0015, 0x0027, 0x0045, 0x0040, 0x0072, 0x0063, 0x0057, | ||||
|  0x009e, 0x008c, 0x00fc, 0x00d4, 0x00c7, 0x0183, 0x016d, 0x001a, | ||||
|  0x004b, 0x0024, 0x0044, 0x0041, 0x0073, 0x0065, 0x00b3, 0x00a4, | ||||
|  0x009b, 0x0108, 0x00f6, 0x00e2, 0x018b, 0x017e, 0x016a, 0x0009, | ||||
|  0x0042, 0x001e, 0x003b, 0x0038, 0x0066, 0x00b9, 0x00ad, 0x0109, | ||||
|  0x008e, 0x00fd, 0x00e8, 0x0190, 0x0184, 0x017a, 0x01bd, 0x0010, | ||||
|  0x006f, 0x0036, 0x0034, 0x0064, 0x00b8, 0x00b2, 0x00a0, 0x0085, | ||||
|  0x0101, 0x00f4, 0x00e4, 0x00d9, 0x0181, 0x016e, 0x02cb, 0x000a, | ||||
|  0x0062, 0x0030, 0x005b, 0x0058, 0x00a5, 0x009d, 0x0094, 0x0105, | ||||
|  0x00f8, 0x0197, 0x018d, 0x0174, 0x017c, 0x0379, 0x0374, 0x0008, | ||||
|  0x0055, 0x0054, 0x0051, 0x009f, 0x009c, 0x008f, 0x0104, 0x00f9, | ||||
|  0x01ab, 0x0191, 0x0188, 0x017f, 0x02d7, 0x02c9, 0x02c4, 0x0007, | ||||
|  0x009a, 0x004c, 0x0049, 0x008d, 0x0083, 0x0100, 0x00f5, 0x01aa, | ||||
|  0x0196, 0x018a, 0x0180, 0x02df, 0x0167, 0x02c6, 0x0160, 0x000b, | ||||
|  0x008b, 0x0081, 0x0043, 0x007d, 0x00f7, 0x00e9, 0x00e5, 0x00db, | ||||
|  0x0189, 0x02e7, 0x02e1, 0x02d0, 0x0375, 0x0372, 0x01b7, 0x0004, | ||||
|  0x00f3, 0x0078, 0x0076, 0x0073, 0x00e3, 0x00df, 0x018c, 0x02ea, | ||||
|  0x02e6, 0x02e0, 0x02d1, 0x02c8, 0x02c2, 0x00df, 0x01b4, 0x0006, | ||||
|  0x00ca, 0x00e0, 0x00de, 0x00da, 0x00d8, 0x0185, 0x0182, 0x017d, | ||||
|  0x016c, 0x0378, 0x01bb, 0x02c3, 0x01b8, 0x01b5, 0x06c0, 0x0004, | ||||
|  0x02eb, 0x00d3, 0x00d2, 0x00d0, 0x0172, 0x017b, 0x02de, 0x02d3, | ||||
|  0x02ca, 0x06c7, 0x0373, 0x036d, 0x036c, 0x0d83, 0x0361, 0x0002, | ||||
|  0x0179, 0x0171, 0x0066, 0x00bb, 0x02d6, 0x02d2, 0x0166, 0x02c7, | ||||
|  0x02c5, 0x0362, 0x06c6, 0x0367, 0x0d82, 0x0366, 0x01b2, 0x0000, | ||||
|  0x000c, 0x000a, 0x0007, 0x000b, 0x000a, 0x0011, 0x000b, 0x0009, | ||||
|  0x000d, 0x000c, 0x000a, 0x0007, 0x0005, 0x0003, 0x0001, 0x0003, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_16[256] = { | ||||
|   1,  4,  6,  8,  9,  9, 10, 10, | ||||
|  11, 11, 11, 12, 12, 12, 13,  9, | ||||
|   3,  4,  6,  7,  8,  9,  9,  9, | ||||
|  10, 10, 10, 11, 12, 11, 12,  8, | ||||
|   6,  6,  7,  8,  9,  9, 10, 10, | ||||
|  11, 10, 11, 11, 11, 12, 12,  9, | ||||
|   8,  7,  8,  9,  9, 10, 10, 10, | ||||
|  11, 11, 12, 12, 12, 13, 13, 10, | ||||
|   9,  8,  9,  9, 10, 10, 11, 11, | ||||
|  11, 12, 12, 12, 13, 13, 13,  9, | ||||
|   9,  8,  9,  9, 10, 11, 11, 12, | ||||
|  11, 12, 12, 13, 13, 13, 14, 10, | ||||
|  10,  9,  9, 10, 11, 11, 11, 11, | ||||
|  12, 12, 12, 12, 13, 13, 14, 10, | ||||
|  10,  9, 10, 10, 11, 11, 11, 12, | ||||
|  12, 13, 13, 13, 13, 15, 15, 10, | ||||
|  10, 10, 10, 11, 11, 11, 12, 12, | ||||
|  13, 13, 13, 13, 14, 14, 14, 10, | ||||
|  11, 10, 10, 11, 11, 12, 12, 13, | ||||
|  13, 13, 13, 14, 13, 14, 13, 11, | ||||
|  11, 11, 10, 11, 12, 12, 12, 12, | ||||
|  13, 14, 14, 14, 15, 15, 14, 10, | ||||
|  12, 11, 11, 11, 12, 12, 13, 14, | ||||
|  14, 14, 14, 14, 14, 13, 14, 11, | ||||
|  12, 12, 12, 12, 12, 13, 13, 13, | ||||
|  13, 15, 14, 14, 14, 14, 16, 11, | ||||
|  14, 12, 12, 12, 13, 13, 14, 14, | ||||
|  14, 16, 15, 15, 15, 17, 15, 11, | ||||
|  13, 13, 11, 12, 14, 14, 13, 14, | ||||
|  14, 15, 16, 15, 17, 15, 14, 11, | ||||
|   9,  8,  8,  9,  9, 10, 10, 10, | ||||
|  11, 11, 11, 11, 11, 11, 11,  8, | ||||
| }; | ||||
|  | ||||
| static const uint16_t mpa_huffcodes_24[256] = { | ||||
|  0x000f, 0x000d, 0x002e, 0x0050, 0x0092, 0x0106, 0x00f8, 0x01b2, | ||||
|  0x01aa, 0x029d, 0x028d, 0x0289, 0x026d, 0x0205, 0x0408, 0x0058, | ||||
|  0x000e, 0x000c, 0x0015, 0x0026, 0x0047, 0x0082, 0x007a, 0x00d8, | ||||
|  0x00d1, 0x00c6, 0x0147, 0x0159, 0x013f, 0x0129, 0x0117, 0x002a, | ||||
|  0x002f, 0x0016, 0x0029, 0x004a, 0x0044, 0x0080, 0x0078, 0x00dd, | ||||
|  0x00cf, 0x00c2, 0x00b6, 0x0154, 0x013b, 0x0127, 0x021d, 0x0012, | ||||
|  0x0051, 0x0027, 0x004b, 0x0046, 0x0086, 0x007d, 0x0074, 0x00dc, | ||||
|  0x00cc, 0x00be, 0x00b2, 0x0145, 0x0137, 0x0125, 0x010f, 0x0010, | ||||
|  0x0093, 0x0048, 0x0045, 0x0087, 0x007f, 0x0076, 0x0070, 0x00d2, | ||||
|  0x00c8, 0x00bc, 0x0160, 0x0143, 0x0132, 0x011d, 0x021c, 0x000e, | ||||
|  0x0107, 0x0042, 0x0081, 0x007e, 0x0077, 0x0072, 0x00d6, 0x00ca, | ||||
|  0x00c0, 0x00b4, 0x0155, 0x013d, 0x012d, 0x0119, 0x0106, 0x000c, | ||||
|  0x00f9, 0x007b, 0x0079, 0x0075, 0x0071, 0x00d7, 0x00ce, 0x00c3, | ||||
|  0x00b9, 0x015b, 0x014a, 0x0134, 0x0123, 0x0110, 0x0208, 0x000a, | ||||
|  0x01b3, 0x0073, 0x006f, 0x006d, 0x00d3, 0x00cb, 0x00c4, 0x00bb, | ||||
|  0x0161, 0x014c, 0x0139, 0x012a, 0x011b, 0x0213, 0x017d, 0x0011, | ||||
|  0x01ab, 0x00d4, 0x00d0, 0x00cd, 0x00c9, 0x00c1, 0x00ba, 0x00b1, | ||||
|  0x00a9, 0x0140, 0x012f, 0x011e, 0x010c, 0x0202, 0x0179, 0x0010, | ||||
|  0x014f, 0x00c7, 0x00c5, 0x00bf, 0x00bd, 0x00b5, 0x00ae, 0x014d, | ||||
|  0x0141, 0x0131, 0x0121, 0x0113, 0x0209, 0x017b, 0x0173, 0x000b, | ||||
|  0x029c, 0x00b8, 0x00b7, 0x00b3, 0x00af, 0x0158, 0x014b, 0x013a, | ||||
|  0x0130, 0x0122, 0x0115, 0x0212, 0x017f, 0x0175, 0x016e, 0x000a, | ||||
|  0x028c, 0x015a, 0x00ab, 0x00a8, 0x00a4, 0x013e, 0x0135, 0x012b, | ||||
|  0x011f, 0x0114, 0x0107, 0x0201, 0x0177, 0x0170, 0x016a, 0x0006, | ||||
|  0x0288, 0x0142, 0x013c, 0x0138, 0x0133, 0x012e, 0x0124, 0x011c, | ||||
|  0x010d, 0x0105, 0x0200, 0x0178, 0x0172, 0x016c, 0x0167, 0x0004, | ||||
|  0x026c, 0x012c, 0x0128, 0x0126, 0x0120, 0x011a, 0x0111, 0x010a, | ||||
|  0x0203, 0x017c, 0x0176, 0x0171, 0x016d, 0x0169, 0x0165, 0x0002, | ||||
|  0x0409, 0x0118, 0x0116, 0x0112, 0x010b, 0x0108, 0x0103, 0x017e, | ||||
|  0x017a, 0x0174, 0x016f, 0x016b, 0x0168, 0x0166, 0x0164, 0x0000, | ||||
|  0x002b, 0x0014, 0x0013, 0x0011, 0x000f, 0x000d, 0x000b, 0x0009, | ||||
|  0x0007, 0x0006, 0x0004, 0x0007, 0x0005, 0x0003, 0x0001, 0x0003, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huffbits_24[256] = { | ||||
|   4,  4,  6,  7,  8,  9,  9, 10, | ||||
|  10, 11, 11, 11, 11, 11, 12,  9, | ||||
|   4,  4,  5,  6,  7,  8,  8,  9, | ||||
|   9,  9, 10, 10, 10, 10, 10,  8, | ||||
|   6,  5,  6,  7,  7,  8,  8,  9, | ||||
|   9,  9,  9, 10, 10, 10, 11,  7, | ||||
|   7,  6,  7,  7,  8,  8,  8,  9, | ||||
|   9,  9,  9, 10, 10, 10, 10,  7, | ||||
|   8,  7,  7,  8,  8,  8,  8,  9, | ||||
|   9,  9, 10, 10, 10, 10, 11,  7, | ||||
|   9,  7,  8,  8,  8,  8,  9,  9, | ||||
|   9,  9, 10, 10, 10, 10, 10,  7, | ||||
|   9,  8,  8,  8,  8,  9,  9,  9, | ||||
|   9, 10, 10, 10, 10, 10, 11,  7, | ||||
|  10,  8,  8,  8,  9,  9,  9,  9, | ||||
|  10, 10, 10, 10, 10, 11, 11,  8, | ||||
|  10,  9,  9,  9,  9,  9,  9,  9, | ||||
|   9, 10, 10, 10, 10, 11, 11,  8, | ||||
|  10,  9,  9,  9,  9,  9,  9, 10, | ||||
|  10, 10, 10, 10, 11, 11, 11,  8, | ||||
|  11,  9,  9,  9,  9, 10, 10, 10, | ||||
|  10, 10, 10, 11, 11, 11, 11,  8, | ||||
|  11, 10,  9,  9,  9, 10, 10, 10, | ||||
|  10, 10, 10, 11, 11, 11, 11,  8, | ||||
|  11, 10, 10, 10, 10, 10, 10, 10, | ||||
|  10, 10, 11, 11, 11, 11, 11,  8, | ||||
|  11, 10, 10, 10, 10, 10, 10, 10, | ||||
|  11, 11, 11, 11, 11, 11, 11,  8, | ||||
|  12, 10, 10, 10, 10, 10, 10, 11, | ||||
|  11, 11, 11, 11, 11, 11, 11,  8, | ||||
|   8,  7,  7,  7,  7,  7,  7,  7, | ||||
|   7,  7,  7,  8,  8,  8,  8,  4, | ||||
| }; | ||||
|  | ||||
| static const HuffTable mpa_huff_tables[16] = { | ||||
| { 1, NULL, NULL }, | ||||
| { 2, mpa_huffbits_1, mpa_huffcodes_1 }, | ||||
| { 3, mpa_huffbits_2, mpa_huffcodes_2 }, | ||||
| { 3, mpa_huffbits_3, mpa_huffcodes_3 }, | ||||
| { 4, mpa_huffbits_5, mpa_huffcodes_5 }, | ||||
| { 4, mpa_huffbits_6, mpa_huffcodes_6 }, | ||||
| { 6, mpa_huffbits_7, mpa_huffcodes_7 }, | ||||
| { 6, mpa_huffbits_8, mpa_huffcodes_8 }, | ||||
| { 6, mpa_huffbits_9, mpa_huffcodes_9 }, | ||||
| { 8, mpa_huffbits_10, mpa_huffcodes_10 }, | ||||
| { 8, mpa_huffbits_11, mpa_huffcodes_11 }, | ||||
| { 8, mpa_huffbits_12, mpa_huffcodes_12 }, | ||||
| { 16, mpa_huffbits_13, mpa_huffcodes_13 }, | ||||
| { 16, mpa_huffbits_15, mpa_huffcodes_15 }, | ||||
| { 16, mpa_huffbits_16, mpa_huffcodes_16 }, | ||||
| { 16, mpa_huffbits_24, mpa_huffcodes_24 }, | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_huff_data[32][2] = { | ||||
| { 0, 0 }, | ||||
| { 1, 0 }, | ||||
| { 2, 0 }, | ||||
| { 3, 0 }, | ||||
| { 0, 0 }, | ||||
| { 4, 0 }, | ||||
| { 5, 0 }, | ||||
| { 6, 0 }, | ||||
| { 7, 0 }, | ||||
| { 8, 0 }, | ||||
| { 9, 0 }, | ||||
| { 10, 0 }, | ||||
| { 11, 0 }, | ||||
| { 12, 0 }, | ||||
| { 0, 0 }, | ||||
| { 13, 0 }, | ||||
| { 14, 1 }, | ||||
| { 14, 2 }, | ||||
| { 14, 3 }, | ||||
| { 14, 4 }, | ||||
| { 14, 6 }, | ||||
| { 14, 8 }, | ||||
| { 14, 10 }, | ||||
| { 14, 13 }, | ||||
| { 15, 4 }, | ||||
| { 15, 5 }, | ||||
| { 15, 6 }, | ||||
| { 15, 7 }, | ||||
| { 15, 8 }, | ||||
| { 15, 9 }, | ||||
| { 15, 11 }, | ||||
| { 15, 13 }, | ||||
| }; | ||||
|  | ||||
|  | ||||
| /* huffman tables for quadrules */ | ||||
| static uint8_t mpa_quad_codes[2][16] = { | ||||
|     {  1,  5,  4,  5,  6,  5,  4,  4, 7,  3,  6,  0,  7,  2,  3,  1, }, | ||||
|     { 15, 14, 13, 12, 11, 10,  9,  8, 7,  6,  5,  4,  3,  2,  1,  0, }, | ||||
| }; | ||||
|  | ||||
| static uint8_t mpa_quad_bits[2][16] = { | ||||
|     { 1, 4, 4, 5, 4, 6, 5, 6, 4, 5, 5, 6, 5, 6, 6, 6, }, | ||||
|     { 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, }, | ||||
| }; | ||||
|  | ||||
| /* band size tables */ | ||||
| static const uint8_t band_size_long[9][22] = { | ||||
| { 4, 4, 4, 4, 4, 4, 6, 6, 8, 8, 10, | ||||
|   12, 16, 20, 24, 28, 34, 42, 50, 54, 76, 158, }, /* 44100 */ | ||||
| { 4, 4, 4, 4, 4, 4, 6, 6, 6, 8, 10, | ||||
|   12, 16, 18, 22, 28, 34, 40, 46, 54, 54, 192, }, /* 48000 */ | ||||
| { 4, 4, 4, 4, 4, 4, 6, 6, 8, 10, 12, | ||||
|   16, 20, 24, 30, 38, 46, 56, 68, 84, 102, 26, }, /* 32000 */ | ||||
| { 6, 6, 6, 6, 6, 6, 8, 10, 12, 14, 16, | ||||
|   20, 24, 28, 32, 38, 46, 52, 60, 68, 58, 54, }, /* 22050 */ | ||||
| { 6, 6, 6, 6, 6, 6, 8, 10, 12, 14, 16, | ||||
|   18, 22, 26, 32, 38, 46, 52, 64, 70, 76, 36, }, /* 24000 */ | ||||
| { 6, 6, 6, 6, 6, 6, 8, 10, 12, 14, 16, | ||||
|   20, 24, 28, 32, 38, 46, 52, 60, 68, 58, 54, }, /* 16000 */ | ||||
| { 6, 6, 6, 6, 6, 6, 8, 10, 12, 14, 16, | ||||
|   20, 24, 28, 32, 38, 46, 52, 60, 68, 58, 54, }, /* 11025 */ | ||||
| { 6, 6, 6, 6, 6, 6, 8, 10, 12, 14, 16, | ||||
|   20, 24, 28, 32, 38, 46, 52, 60, 68, 58, 54, }, /* 12000 */ | ||||
| { 12, 12, 12, 12, 12, 12, 16, 20, 24, 28, 32, | ||||
|   40, 48, 56, 64, 76, 90, 2, 2, 2, 2, 2, }, /* 8000 */ | ||||
| }; | ||||
|  | ||||
| static const uint8_t band_size_short[9][13] = { | ||||
| { 4, 4, 4, 4, 6, 8, 10, 12, 14, 18, 22, 30, 56, }, /* 44100 */ | ||||
| { 4, 4, 4, 4, 6, 6, 10, 12, 14, 16, 20, 26, 66, }, /* 48000 */ | ||||
| { 4, 4, 4, 4, 6, 8, 12, 16, 20, 26, 34, 42, 12, }, /* 32000 */ | ||||
| { 4, 4, 4, 6, 6, 8, 10, 14, 18, 26, 32, 42, 18, }, /* 22050 */ | ||||
| { 4, 4, 4, 6, 8, 10, 12, 14, 18, 24, 32, 44, 12, }, /* 24000 */ | ||||
| { 4, 4, 4, 6, 8, 10, 12, 14, 18, 24, 30, 40, 18, }, /* 16000 */ | ||||
| { 4, 4, 4, 6, 8, 10, 12, 14, 18, 24, 30, 40, 18, }, /* 11025 */ | ||||
| { 4, 4, 4, 6, 8, 10, 12, 14, 18, 24, 30, 40, 18, }, /* 12000 */ | ||||
| { 8, 8, 8, 12, 16, 20, 24, 28, 36, 2, 2, 2, 26, }, /* 8000 */ | ||||
| }; | ||||
|  | ||||
| static const uint8_t mpa_pretab[2][22] = { | ||||
|     { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }, | ||||
|     { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 3, 3, 3, 2, 0 }, | ||||
| }; | ||||
|  | ||||
| /* table for alias reduction (XXX: store it as integer !) */ | ||||
| static const float ci_table[8] = { | ||||
|     -0.6f, -0.535f, -0.33f, -0.185f, -0.095f, -0.041f, -0.0142f, -0.0037f, | ||||
| }; | ||||
							
								
								
									
										17
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpegaudio.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/decoder/mpegaudio.h
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| /* Modified slightly by Matt Campbell <mattcampbell@pobox.com> for the | ||||
|    stand-alone mpaudec library.  Based on mpegaudio.h from libavcodec. */ | ||||
|  | ||||
| /* max frame size, in samples */ | ||||
| #define MPA_FRAME_SIZE 1152  | ||||
|  | ||||
| /* max compressed frame size */ | ||||
| #define MPA_MAX_CODED_FRAME_SIZE 1792 | ||||
|  | ||||
| #define MPA_MAX_CHANNELS 2 | ||||
|  | ||||
| #define SBLIMIT 32 /* number of subbands */ | ||||
|  | ||||
| #define MPA_STEREO  0 | ||||
| #define MPA_JSTEREO 1 | ||||
| #define MPA_DUAL    2 | ||||
| #define MPA_MONO    3 | ||||
							
								
								
									
										41
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/ikpMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/ikpMP3.cpp
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,41 @@ | ||||
|  | ||||
| #include <irrKlang.h> | ||||
| #include <stdio.h> | ||||
| #include <string.h> | ||||
| #include "CIrrKlangAudioStreamLoaderMP3.h" | ||||
|  | ||||
| using namespace irrklang; | ||||
|  | ||||
| // this is the only function needed to be implemented for the plugin, it gets | ||||
| // called by irrKlang when loaded. | ||||
| // In this plugin, we create an audiostream loader class and register | ||||
| // it at the engine, but a plugin can do anything. | ||||
| // Be sure to name the function 'irrKlangPluginInit' and let the dll start with 'ikp'. | ||||
|  | ||||
| #ifdef WIN32 | ||||
| // Windows version | ||||
| __declspec(dllexport) void __stdcall irrKlangPluginInit(ISoundEngine* engine, const char* version) | ||||
| #else | ||||
| // Linux version | ||||
| void irrKlangPluginInit(ISoundEngine* engine, const char* version) | ||||
| #endif | ||||
| { | ||||
| 	// do some version security check to be sure that this plugin isn't begin used | ||||
| 	// by some newer irrKlang version with changed interfaces which could possibily | ||||
| 	// cause crashes. | ||||
|  | ||||
| 	if (strcmp(version, IRR_KLANG_VERSION)) | ||||
| 	{ | ||||
| 		printf("This MP3 plugin only supports irrKlang version %s, mp3 playback disabled.\n", IRR_KLANG_VERSION); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	// create and register the loader | ||||
|  | ||||
| 	CIrrKlangAudioStreamLoaderMP3* loader = new CIrrKlangAudioStreamLoaderMP3(); | ||||
| 	engine->registerAudioStreamLoader(loader); | ||||
| 	loader->drop(); | ||||
|  | ||||
| 	// that's it, that's all. | ||||
| } | ||||
|  | ||||
							
								
								
									
										458
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/license.txt
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										458
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/license.txt
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,458 @@ | ||||
| 		  GNU LESSER GENERAL PUBLIC LICENSE | ||||
| 		       Version 2.1, February 1999 | ||||
| 		        | ||||
|  Copyright (C) 1991, 1999 Free Software Foundation, Inc. | ||||
|  51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA | ||||
|  Everyone is permitted to copy and distribute verbatim copies | ||||
|  of this license document, but changing it is not allowed. | ||||
|  | ||||
| [This is the first released version of the Lesser GPL.  It also counts | ||||
|  as the successor of the GNU Library Public License, version 2, hence | ||||
|  the version number 2.1.] | ||||
|  | ||||
| 			    Preamble | ||||
|  | ||||
|   The licenses for most software are designed to take away your | ||||
| freedom to share and change it.  By contrast, the GNU General Public | ||||
| Licenses are intended to guarantee your freedom to share and change | ||||
| free software--to make sure the software is free for all its users. | ||||
|  | ||||
|   This license, the Lesser General Public License, applies to some | ||||
| specially designated software packages--typically libraries--of the | ||||
| Free Software Foundation and other authors who decide to use it.  You | ||||
| can use it too, but we suggest you first think carefully about whether | ||||
| this license or the ordinary General Public License is the better | ||||
| strategy to use in any particular case, based on the explanations below. | ||||
|  | ||||
|   When we speak of free software, we are referring to freedom of use, | ||||
| not price.  Our General Public Licenses are designed to make sure that | ||||
| you have the freedom to distribute copies of free software (and charge | ||||
| for this service if you wish); that you receive source code or can get | ||||
| it if you want it; that you can change the software and use pieces of | ||||
| it in new free programs; and that you are informed that you can do | ||||
| these things. | ||||
|  | ||||
|   To protect your rights, we need to make restrictions that forbid | ||||
| distributors to deny you these rights or to ask you to surrender these | ||||
| rights.  These restrictions translate to certain responsibilities for | ||||
| you if you distribute copies of the library or if you modify it. | ||||
|  | ||||
|   For example, if you distribute copies of the library, whether gratis | ||||
| or for a fee, you must give the recipients all the rights that we gave | ||||
| you.  You must make sure that they, too, receive or can get the source | ||||
| code.  If you link other code with the library, you must provide | ||||
| complete object files to the recipients, so that they can relink them | ||||
| with the library after making changes to the library and recompiling | ||||
| it.  And you must show them these terms so they know their rights. | ||||
|  | ||||
|   We protect your rights with a two-step method: (1) we copyright the | ||||
| library, and (2) we offer you this license, which gives you legal | ||||
| permission to copy, distribute and/or modify the library. | ||||
|  | ||||
|   To protect each distributor, we want to make it very clear that | ||||
| there is no warranty for the free library.  Also, if the library is | ||||
| modified by someone else and passed on, the recipients should know | ||||
| that what they have is not the original version, so that the original | ||||
| author's reputation will not be affected by problems that might be | ||||
| introduced by others. | ||||
|  | ||||
|   Finally, software patents pose a constant threat to the existence of | ||||
| any free program.  We wish to make sure that a company cannot | ||||
| effectively restrict the users of a free program by obtaining a | ||||
| restrictive license from a patent holder.  Therefore, we insist that | ||||
| any patent license obtained for a version of the library must be | ||||
| consistent with the full freedom of use specified in this license. | ||||
|  | ||||
|   Most GNU software, including some libraries, is covered by the | ||||
| ordinary GNU General Public License.  This license, the GNU Lesser | ||||
| General Public License, applies to certain designated libraries, and | ||||
| is quite different from the ordinary General Public License.  We use | ||||
| this license for certain libraries in order to permit linking those | ||||
| libraries into non-free programs. | ||||
|  | ||||
|   When a program is linked with a library, whether statically or using | ||||
| a shared library, the combination of the two is legally speaking a | ||||
| combined work, a derivative of the original library.  The ordinary | ||||
| General Public License therefore permits such linking only if the | ||||
| entire combination fits its criteria of freedom.  The Lesser General | ||||
| Public License permits more lax criteria for linking other code with | ||||
| the library. | ||||
|  | ||||
|   We call this license the "Lesser" General Public License because it | ||||
| does Less to protect the user's freedom than the ordinary General | ||||
| Public License.  It also provides other free software developers Less | ||||
| of an advantage over competing non-free programs.  These disadvantages | ||||
| are the reason we use the ordinary General Public License for many | ||||
| libraries.  However, the Lesser license provides advantages in certain | ||||
| special circumstances. | ||||
|  | ||||
|   For example, on rare occasions, there may be a special need to | ||||
| encourage the widest possible use of a certain library, so that it becomes | ||||
| a de-facto standard.  To achieve this, non-free programs must be | ||||
| allowed to use the library.  A more frequent case is that a free | ||||
| library does the same job as widely used non-free libraries.  In this | ||||
| case, there is little to gain by limiting the free library to free | ||||
| software only, so we use the Lesser General Public License. | ||||
|  | ||||
|   In other cases, permission to use a particular library in non-free | ||||
| programs enables a greater number of people to use a large body of | ||||
| free software.  For example, permission to use the GNU C Library in | ||||
| non-free programs enables many more people to use the whole GNU | ||||
| operating system, as well as its variant, the GNU/Linux operating | ||||
| system. | ||||
|  | ||||
|   Although the Lesser General Public License is Less protective of the | ||||
| users' freedom, it does ensure that the user of a program that is | ||||
| linked with the Library has the freedom and the wherewithal to run | ||||
| that program using a modified version of the Library. | ||||
|  | ||||
|   The precise terms and conditions for copying, distribution and | ||||
| modification follow.  Pay close attention to the difference between a | ||||
| "work based on the library" and a "work that uses the library".  The | ||||
| former contains code derived from the library, whereas the latter must | ||||
| be combined with the library in order to run. | ||||
|  | ||||
| 		  GNU LESSER GENERAL PUBLIC LICENSE | ||||
|    TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION | ||||
|  | ||||
|   0. This License Agreement applies to any software library or other | ||||
| program which contains a notice placed by the copyright holder or | ||||
| other authorized party saying it may be distributed under the terms of | ||||
| this Lesser General Public License (also called "this License"). | ||||
| Each licensee is addressed as "you". | ||||
|  | ||||
|   A "library" means a collection of software functions and/or data | ||||
| prepared so as to be conveniently linked with application programs | ||||
| (which use some of those functions and data) to form executables. | ||||
|  | ||||
|   The "Library", below, refers to any such software library or work | ||||
| which has been distributed under these terms.  A "work based on the | ||||
| Library" means either the Library or any derivative work under | ||||
| copyright law: that is to say, a work containing the Library or a | ||||
| portion of it, either verbatim or with modifications and/or translated | ||||
| straightforwardly into another language.  (Hereinafter, translation is | ||||
| included without limitation in the term "modification".) | ||||
|  | ||||
|   "Source code" for a work means the preferred form of the work for | ||||
| making modifications to it.  For a library, complete source code means | ||||
| all the source code for all modules it contains, plus any associated | ||||
| interface definition files, plus the scripts used to control compilation | ||||
| and installation of the library. | ||||
|  | ||||
|   Activities other than copying, distribution and modification are not | ||||
| covered by this License; they are outside its scope.  The act of | ||||
| running a program using the Library is not restricted, and output from | ||||
| such a program is covered only if its contents constitute a work based | ||||
| on the Library (independent of the use of the Library in a tool for | ||||
| writing it).  Whether that is true depends on what the Library does | ||||
| and what the program that uses the Library does. | ||||
|    | ||||
|   1. You may copy and distribute verbatim copies of the Library's | ||||
| complete source code as you receive it, in any medium, provided that | ||||
| you conspicuously and appropriately publish on each copy an | ||||
| appropriate copyright notice and disclaimer of warranty; keep intact | ||||
| all the notices that refer to this License and to the absence of any | ||||
| warranty; and distribute a copy of this License along with the | ||||
| Library. | ||||
|  | ||||
|   You may charge a fee for the physical act of transferring a copy, | ||||
| and you may at your option offer warranty protection in exchange for a | ||||
| fee. | ||||
|  | ||||
|   2. You may modify your copy or copies of the Library or any portion | ||||
| of it, thus forming a work based on the Library, and copy and | ||||
| distribute such modifications or work under the terms of Section 1 | ||||
| above, provided that you also meet all of these conditions: | ||||
|  | ||||
|     a) The modified work must itself be a software library. | ||||
|  | ||||
|     b) You must cause the files modified to carry prominent notices | ||||
|     stating that you changed the files and the date of any change. | ||||
|  | ||||
|     c) You must cause the whole of the work to be licensed at no | ||||
|     charge to all third parties under the terms of this License. | ||||
|  | ||||
|     d) If a facility in the modified Library refers to a function or a | ||||
|     table of data to be supplied by an application program that uses | ||||
|     the facility, other than as an argument passed when the facility | ||||
|     is invoked, then you must make a good faith effort to ensure that, | ||||
|     in the event an application does not supply such function or | ||||
|     table, the facility still operates, and performs whatever part of | ||||
|     its purpose remains meaningful. | ||||
|  | ||||
|     (For example, a function in a library to compute square roots has | ||||
|     a purpose that is entirely well-defined independent of the | ||||
|     application.  Therefore, Subsection 2d requires that any | ||||
|     application-supplied function or table used by this function must | ||||
|     be optional: if the application does not supply it, the square | ||||
|     root function must still compute square roots.) | ||||
|  | ||||
| These requirements apply to the modified work as a whole.  If | ||||
| identifiable sections of that work are not derived from the Library, | ||||
| and can be reasonably considered independent and separate works in | ||||
| themselves, then this License, and its terms, do not apply to those | ||||
| sections when you distribute them as separate works.  But when you | ||||
| distribute the same sections as part of a whole which is a work based | ||||
| on the Library, the distribution of the whole must be on the terms of | ||||
| this License, whose permissions for other licensees extend to the | ||||
| entire whole, and thus to each and every part regardless of who wrote | ||||
| it. | ||||
|  | ||||
| Thus, it is not the intent of this section to claim rights or contest | ||||
| your rights to work written entirely by you; rather, the intent is to | ||||
| exercise the right to control the distribution of derivative or | ||||
| collective works based on the Library. | ||||
|  | ||||
| In addition, mere aggregation of another work not based on the Library | ||||
| with the Library (or with a work based on the Library) on a volume of | ||||
| a storage or distribution medium does not bring the other work under | ||||
| the scope of this License. | ||||
|  | ||||
|   3. You may opt to apply the terms of the ordinary GNU General Public | ||||
| License instead of this License to a given copy of the Library.  To do | ||||
| this, you must alter all the notices that refer to this License, so | ||||
| that they refer to the ordinary GNU General Public License, version 2, | ||||
| instead of to this License.  (If a newer version than version 2 of the | ||||
| ordinary GNU General Public License has appeared, then you can specify | ||||
| that version instead if you wish.)  Do not make any other change in | ||||
| these notices. | ||||
|  | ||||
|   Once this change is made in a given copy, it is irreversible for | ||||
| that copy, so the ordinary GNU General Public License applies to all | ||||
| subsequent copies and derivative works made from that copy. | ||||
|  | ||||
|   This option is useful when you wish to copy part of the code of | ||||
| the Library into a program that is not a library. | ||||
|  | ||||
|   4. You may copy and distribute the Library (or a portion or | ||||
| derivative of it, under Section 2) in object code or executable form | ||||
| under the terms of Sections 1 and 2 above provided that you accompany | ||||
| it with the complete corresponding machine-readable source code, which | ||||
| must be distributed under the terms of Sections 1 and 2 above on a | ||||
| medium customarily used for software interchange. | ||||
|  | ||||
|   If distribution of object code is made by offering access to copy | ||||
| from a designated place, then offering equivalent access to copy the | ||||
| source code from the same place satisfies the requirement to | ||||
| distribute the source code, even though third parties are not | ||||
| compelled to copy the source along with the object code. | ||||
|  | ||||
|   5. A program that contains no derivative of any portion of the | ||||
| Library, but is designed to work with the Library by being compiled or | ||||
| linked with it, is called a "work that uses the Library".  Such a | ||||
| work, in isolation, is not a derivative work of the Library, and | ||||
| therefore falls outside the scope of this License. | ||||
|  | ||||
|   However, linking a "work that uses the Library" with the Library | ||||
| creates an executable that is a derivative of the Library (because it | ||||
| contains portions of the Library), rather than a "work that uses the | ||||
| library".  The executable is therefore covered by this License. | ||||
| Section 6 states terms for distribution of such executables. | ||||
|  | ||||
|   When a "work that uses the Library" uses material from a header file | ||||
| that is part of the Library, the object code for the work may be a | ||||
| derivative work of the Library even though the source code is not. | ||||
| Whether this is true is especially significant if the work can be | ||||
| linked without the Library, or if the work is itself a library.  The | ||||
| threshold for this to be true is not precisely defined by law. | ||||
|  | ||||
|   If such an object file uses only numerical parameters, data | ||||
| structure layouts and accessors, and small macros and small inline | ||||
| functions (ten lines or less in length), then the use of the object | ||||
| file is unrestricted, regardless of whether it is legally a derivative | ||||
| work.  (Executables containing this object code plus portions of the | ||||
| Library will still fall under Section 6.) | ||||
|  | ||||
|   Otherwise, if the work is a derivative of the Library, you may | ||||
| distribute the object code for the work under the terms of Section 6. | ||||
| Any executables containing that work also fall under Section 6, | ||||
| whether or not they are linked directly with the Library itself. | ||||
|  | ||||
|   6. As an exception to the Sections above, you may also combine or | ||||
| link a "work that uses the Library" with the Library to produce a | ||||
| work containing portions of the Library, and distribute that work | ||||
| under terms of your choice, provided that the terms permit | ||||
| modification of the work for the customer's own use and reverse | ||||
| engineering for debugging such modifications. | ||||
|  | ||||
|   You must give prominent notice with each copy of the work that the | ||||
| Library is used in it and that the Library and its use are covered by | ||||
| this License.  You must supply a copy of this License.  If the work | ||||
| during execution displays copyright notices, you must include the | ||||
| copyright notice for the Library among them, as well as a reference | ||||
| directing the user to the copy of this License.  Also, you must do one | ||||
| of these things: | ||||
|  | ||||
|     a) Accompany the work with the complete corresponding | ||||
|     machine-readable source code for the Library including whatever | ||||
|     changes were used in the work (which must be distributed under | ||||
|     Sections 1 and 2 above); and, if the work is an executable linked | ||||
|     with the Library, with the complete machine-readable "work that | ||||
|     uses the Library", as object code and/or source code, so that the | ||||
|     user can modify the Library and then relink to produce a modified | ||||
|     executable containing the modified Library.  (It is understood | ||||
|     that the user who changes the contents of definitions files in the | ||||
|     Library will not necessarily be able to recompile the application | ||||
|     to use the modified definitions.) | ||||
|  | ||||
|     b) Use a suitable shared library mechanism for linking with the | ||||
|     Library.  A suitable mechanism is one that (1) uses at run time a | ||||
|     copy of the library already present on the user's computer system, | ||||
|     rather than copying library functions into the executable, and (2) | ||||
|     will operate properly with a modified version of the library, if | ||||
|     the user installs one, as long as the modified version is | ||||
|     interface-compatible with the version that the work was made with. | ||||
|  | ||||
|     c) Accompany the work with a written offer, valid for at | ||||
|     least three years, to give the same user the materials | ||||
|     specified in Subsection 6a, above, for a charge no more | ||||
|     than the cost of performing this distribution. | ||||
|  | ||||
|     d) If distribution of the work is made by offering access to copy | ||||
|     from a designated place, offer equivalent access to copy the above | ||||
|     specified materials from the same place. | ||||
|  | ||||
|     e) Verify that the user has already received a copy of these | ||||
|     materials or that you have already sent this user a copy. | ||||
|  | ||||
|   For an executable, the required form of the "work that uses the | ||||
| Library" must include any data and utility programs needed for | ||||
| reproducing the executable from it.  However, as a special exception, | ||||
| the materials to be distributed need not include anything that is | ||||
| normally distributed (in either source or binary form) with the major | ||||
| components (compiler, kernel, and so on) of the operating system on | ||||
| which the executable runs, unless that component itself accompanies | ||||
| the executable. | ||||
|  | ||||
|   It may happen that this requirement contradicts the license | ||||
| restrictions of other proprietary libraries that do not normally | ||||
| accompany the operating system.  Such a contradiction means you cannot | ||||
| use both them and the Library together in an executable that you | ||||
| distribute. | ||||
|  | ||||
|   7. You may place library facilities that are a work based on the | ||||
| Library side-by-side in a single library together with other library | ||||
| facilities not covered by this License, and distribute such a combined | ||||
| library, provided that the separate distribution of the work based on | ||||
| the Library and of the other library facilities is otherwise | ||||
| permitted, and provided that you do these two things: | ||||
|  | ||||
|     a) Accompany the combined library with a copy of the same work | ||||
|     based on the Library, uncombined with any other library | ||||
|     facilities.  This must be distributed under the terms of the | ||||
|     Sections above. | ||||
|  | ||||
|     b) Give prominent notice with the combined library of the fact | ||||
|     that part of it is a work based on the Library, and explaining | ||||
|     where to find the accompanying uncombined form of the same work. | ||||
|  | ||||
|   8. You may not copy, modify, sublicense, link with, or distribute | ||||
| the Library except as expressly provided under this License.  Any | ||||
| attempt otherwise to copy, modify, sublicense, link with, or | ||||
| distribute the Library is void, and will automatically terminate your | ||||
| rights under this License.  However, parties who have received copies, | ||||
| or rights, from you under this License will not have their licenses | ||||
| terminated so long as such parties remain in full compliance. | ||||
|  | ||||
|   9. You are not required to accept this License, since you have not | ||||
| signed it.  However, nothing else grants you permission to modify or | ||||
| distribute the Library or its derivative works.  These actions are | ||||
| prohibited by law if you do not accept this License.  Therefore, by | ||||
| modifying or distributing the Library (or any work based on the | ||||
| Library), you indicate your acceptance of this License to do so, and | ||||
| all its terms and conditions for copying, distributing or modifying | ||||
| the Library or works based on it. | ||||
|  | ||||
|   10. Each time you redistribute the Library (or any work based on the | ||||
| Library), the recipient automatically receives a license from the | ||||
| original licensor to copy, distribute, link with or modify the Library | ||||
| subject to these terms and conditions.  You may not impose any further | ||||
| restrictions on the recipients' exercise of the rights granted herein. | ||||
| You are not responsible for enforcing compliance by third parties with | ||||
| this License. | ||||
|  | ||||
|   11. If, as a consequence of a court judgment or allegation of patent | ||||
| infringement or for any other reason (not limited to patent issues), | ||||
| conditions are imposed on you (whether by court order, agreement or | ||||
| otherwise) that contradict the conditions of this License, they do not | ||||
| excuse you from the conditions of this License.  If you cannot | ||||
| distribute so as to satisfy simultaneously your obligations under this | ||||
| License and any other pertinent obligations, then as a consequence you | ||||
| may not distribute the Library at all.  For example, if a patent | ||||
| license would not permit royalty-free redistribution of the Library by | ||||
| all those who receive copies directly or indirectly through you, then | ||||
| the only way you could satisfy both it and this License would be to | ||||
| refrain entirely from distribution of the Library. | ||||
|  | ||||
| If any portion of this section is held invalid or unenforceable under any | ||||
| particular circumstance, the balance of the section is intended to apply, | ||||
| and the section as a whole is intended to apply in other circumstances. | ||||
|  | ||||
| It is not the purpose of this section to induce you to infringe any | ||||
| patents or other property right claims or to contest validity of any | ||||
| such claims; this section has the sole purpose of protecting the | ||||
| integrity of the free software distribution system which is | ||||
| implemented by public license practices.  Many people have made | ||||
| generous contributions to the wide range of software distributed | ||||
| through that system in reliance on consistent application of that | ||||
| system; it is up to the author/donor to decide if he or she is willing | ||||
| to distribute software through any other system and a licensee cannot | ||||
| impose that choice. | ||||
|  | ||||
| This section is intended to make thoroughly clear what is believed to | ||||
| be a consequence of the rest of this License. | ||||
|  | ||||
|   12. If the distribution and/or use of the Library is restricted in | ||||
| certain countries either by patents or by copyrighted interfaces, the | ||||
| original copyright holder who places the Library under this License may add | ||||
| an explicit geographical distribution limitation excluding those countries, | ||||
| so that distribution is permitted only in or among countries not thus | ||||
| excluded.  In such case, this License incorporates the limitation as if | ||||
| written in the body of this License. | ||||
|  | ||||
|   13. The Free Software Foundation may publish revised and/or new | ||||
| versions of the Lesser General Public License from time to time. | ||||
| Such new versions will be similar in spirit to the present version, | ||||
| but may differ in detail to address new problems or concerns. | ||||
|  | ||||
| Each version is given a distinguishing version number.  If the Library | ||||
| specifies a version number of this License which applies to it and | ||||
| "any later version", you have the option of following the terms and | ||||
| conditions either of that version or of any later version published by | ||||
| the Free Software Foundation.  If the Library does not specify a | ||||
| license version number, you may choose any version ever published by | ||||
| the Free Software Foundation. | ||||
|  | ||||
|   14. If you wish to incorporate parts of the Library into other free | ||||
| programs whose distribution conditions are incompatible with these, | ||||
| write to the author to ask for permission.  For software which is | ||||
| copyrighted by the Free Software Foundation, write to the Free | ||||
| Software Foundation; we sometimes make exceptions for this.  Our | ||||
| decision will be guided by the two goals of preserving the free status | ||||
| of all derivatives of our free software and of promoting the sharing | ||||
| and reuse of software generally. | ||||
|  | ||||
| 			    NO WARRANTY | ||||
|  | ||||
|   15. BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO | ||||
| WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW. | ||||
| EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR | ||||
| OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY | ||||
| KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE | ||||
| IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||||
| PURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE | ||||
| LIBRARY IS WITH YOU.  SHOULD THE LIBRARY PROVE DEFECTIVE, YOU ASSUME | ||||
| THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. | ||||
|  | ||||
|   16. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN | ||||
| WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY | ||||
| AND/OR REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU | ||||
| FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR | ||||
| CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE | ||||
| LIBRARY (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING | ||||
| RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A | ||||
| FAILURE OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF | ||||
| SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH | ||||
| DAMAGES. | ||||
|  | ||||
| 		     END OF TERMS AND CONDITIONS | ||||
							
								
								
									
										7
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/readme.txt
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								SQCSim2021/external/irrKlang-64bit-1.6.0/plugins/ikpMP3/readme.txt
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| ikpMP3 is a plugin for irrKlang. | ||||
| Copyright (C) 2002-2007 Nikolaus Gebhardt | ||||
| Part of the code for this plugin for irrKlang is based on: | ||||
|  MP3 input for Audiere by Matt Campbell <mattcampbell@pobox.com>, based on | ||||
|   libavcodec from ffmpeg (http://ffmpeg.sourceforge.net/).  | ||||
|  See license.txt for license details of this plugin. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user