diff options
Diffstat (limited to 'scumm/smush/imuse_channel.cpp')
-rw-r--r-- | scumm/smush/imuse_channel.cpp | 89 |
1 files changed, 45 insertions, 44 deletions
diff --git a/scumm/smush/imuse_channel.cpp b/scumm/smush/imuse_channel.cpp index ea969c9428..a4152a5a5c 100644 --- a/scumm/smush/imuse_channel.cpp +++ b/scumm/smush/imuse_channel.cpp @@ -25,9 +25,9 @@ #include "chunk_type.h" #include <assert.h> -#include <string.h> // for memcpy.h +#include <string.h> -ImuseChannel::ImuseChannel(int track, int freq) : +ImuseChannel::ImuseChannel(int32 track, int32 freq) : _track(track), _tbuffer(0), _tbufferSize(0), @@ -52,32 +52,32 @@ bool ImuseChannel::isTerminated() const { return (_dataSize <= 0 && _sbuffer == 0); } -bool ImuseChannel::setParameters(int nbframes, int size, int unk1, int unk2) { +bool ImuseChannel::setParameters(int32 nbframes, int32 size, int32 unk1, int32 unk2) { return true; } -bool ImuseChannel::checkParameters(int index, int nbframes, int size, int unk1, int unk2) { +bool ImuseChannel::checkParameters(int32 index, int32 nbframes, int32 size, int32 unk1, int32 unk2) { return true; } -bool ImuseChannel::appendData(Chunk & b, int size) { +bool ImuseChannel::appendData(Chunk & b, int32 size) { if(_dataSize == -1) { // First call assert(size > 8); Chunk::type imus_type = b.getDword(); imus_type = SWAP_BYTES(imus_type); - unsigned int imus_size = b.getDword(); imus_size = SWAP_BYTES(imus_size); + uint32 imus_size = b.getDword(); imus_size = SWAP_BYTES(imus_size); if(imus_type != TYPE_iMUS) error("Invalid Chunk for imuse_channel"); size -= 8; _tbufferSize = size; assert(_tbufferSize); - _tbuffer = new unsigned char[_tbufferSize]; + _tbuffer = new byte[_tbufferSize]; if(!_tbuffer) error("imuse_channel failed to allocate memory"); b.read(_tbuffer, size); _dataSize = -2; // even if _in_data does not get set, this won't be called again } else { if(_tbuffer) { // remaining from last call - unsigned char * old = _tbuffer; - int new_size = size + _tbufferSize; - _tbuffer = new unsigned char[new_size]; + byte * old = _tbuffer; + int32 new_size = size + _tbufferSize; + _tbuffer = new byte[new_size]; if(!_tbuffer) error("imuse_channel failed to allocate memory"); memcpy(_tbuffer, old, _tbufferSize); delete []old; @@ -85,7 +85,7 @@ bool ImuseChannel::appendData(Chunk & b, int size) { _tbufferSize += size; } else { _tbufferSize = size; - _tbuffer = new unsigned char[_tbufferSize]; + _tbuffer = new byte[_tbufferSize]; if(!_tbuffer) error("imuse_channel failed to allocate memory"); b.read(_tbuffer, size); } @@ -95,7 +95,7 @@ bool ImuseChannel::appendData(Chunk & b, int size) { bool ImuseChannel::handleFormat(Chunk & src) { if(src.getSize() != 20) error("invalid size for FRMT Chunk"); - unsigned imuse_start = src.getDword(); + uint32 imuse_start = src.getDword(); imuse_start = SWAP_BYTES(imuse_start); src.seek(4); _bitsize = src.getDword(); @@ -152,16 +152,16 @@ void ImuseChannel::decode() { _srbufferSize -= remaining_size; assert(_inData); if(_tbuffer == 0) { - _tbuffer = new unsigned char[remaining_size]; + _tbuffer = new byte[remaining_size]; memcpy(_tbuffer, _sbuffer + _sbufferSize - remaining_size, remaining_size); _tbufferSize = remaining_size; _sbufferSize -= remaining_size; } else { warning("impossible ! : %p, %d, %d, %p(%d), %p(%d, %d)", this, _dataSize, _inData, _tbuffer, _tbufferSize, _sbuffer, _sbufferSize, _srbufferSize); - unsigned char * old = _tbuffer; + byte * old = _tbuffer; int new_size = remaining_size + _tbufferSize; - _tbuffer = new unsigned char[new_size]; + _tbuffer = new byte[new_size]; if(!_tbuffer) error("imuse_channel failed to allocate memory"); memcpy(_tbuffer, old, _tbufferSize); delete []old; @@ -172,7 +172,7 @@ void ImuseChannel::decode() { int loop_size = _sbufferSize / 3; int new_size = loop_size * 2; short * keep, * decoded; - keep = decoded = new short[new_size]; + keep = decoded = new int16[new_size]; assert(keep); unsigned char * source = _sbuffer; while(loop_size--) { @@ -180,25 +180,25 @@ void ImuseChannel::decode() { int v2 = *source++; int v3 = *source++; int value = (((v2 & 0x0f) << 12) | (v1 << 4)) - 0x8000; - *decoded++ = (short)value; + *decoded++ = (int16)value; value = (((v2 & 0xf0) << 8) | (v3 << 4)) - 0x8000; - *decoded++ = (short)value; + *decoded++ = (int16)value; } delete []_sbuffer; - _sbuffer = (unsigned char*)keep; - _sbufferSize = new_size * sizeof(short); + _sbuffer = (byte *)keep; + _sbufferSize = new_size * sizeof(int16); } -bool ImuseChannel::handleSubTags(int & offset) { +bool ImuseChannel::handleSubTags(int32 & offset) { if(_tbufferSize - offset >= 8) { Chunk::type type = READ_BE_UINT32(_tbuffer + offset); - unsigned int size = READ_BE_UINT32(_tbuffer + offset + 4); - unsigned int available_size = _tbufferSize - offset; + uint32 size = READ_BE_UINT32(_tbuffer + offset + 4); + uint32 available_size = _tbufferSize - offset; switch(type) { case TYPE_MAP_: _inData = false; if(available_size >= (size + 8)) { - ContChunk c((char*)_tbuffer + offset); + ContChunk c((byte *)_tbuffer + offset); handleMap(c); } break; @@ -208,8 +208,10 @@ bool ImuseChannel::handleSubTags(int & offset) { offset += 8; { int reqsize = 1; - if(_channels == 2) reqsize *= 2; - if(_bitsize == 16) reqsize *= 2; + if(_channels == 2) + reqsize *= 2; + if(_bitsize == 16) + reqsize *= 2; else if(_bitsize == 12) { if(reqsize > 1) reqsize = reqsize * 3 / 2; @@ -239,14 +241,14 @@ bool ImuseChannel::processBuffer() { if(_inData) { if(_dataSize < _tbufferSize) { - int offset= _dataSize; + int32 offset= _dataSize; while(handleSubTags(offset)); _sbufferSize = _dataSize; _sbuffer = _tbuffer; if(offset < _tbufferSize) { // there is still some unprocessed data - int new_size = _tbufferSize - offset; - _tbuffer = new unsigned char[new_size]; - if(!_tbuffer) error("imuse_channel failed to allocate memory"); + int32 new_size = _tbufferSize - offset; + _tbuffer = new byte[new_size]; + if(!_tbuffer) error("imuse_channel failed to allocate memory"); memcpy(_tbuffer, _sbuffer + offset, new_size); _tbufferSize = new_size; } else { @@ -266,24 +268,23 @@ bool ImuseChannel::processBuffer() { _tbuffer = 0; } } else { - int offset = 0; + int32 offset = 0; while(handleSubTags(offset)); if(_inData) { - //~ unsigned char * old = _tbuffer; _sbufferSize = _tbufferSize - offset; assert(_sbufferSize); - _sbuffer = new unsigned char[_sbufferSize]; - if(!_sbuffer) error("imuse_channel failed to allocate memory"); + _sbuffer = new byte[_sbufferSize]; + if(!_sbuffer) error("imuse_channel failed to allocate memory"); memcpy(_sbuffer, _tbuffer + offset, _sbufferSize); delete []_tbuffer; _tbuffer = 0; _tbufferSize = 0; } else { if(offset) { // maybe I should assert() this to avoid a lock... - unsigned char * old = _tbuffer; - int new_size = _tbufferSize - offset; - _tbuffer = new unsigned char[new_size]; - if(!_tbuffer) error("imuse_channel failed to allocate memory"); + byte * old = _tbuffer; + int32 new_size = _tbufferSize - offset; + _tbuffer = new byte[new_size]; + if(!_tbuffer) error("imuse_channel failed to allocate memory"); memcpy(_tbuffer, old + offset, new_size); _tbufferSize = new_size; delete []old; @@ -295,17 +296,17 @@ bool ImuseChannel::processBuffer() { return true; } -int ImuseChannel::availableSoundData(void) const { - int ret = _sbufferSize; +int32 ImuseChannel::availableSoundData(void) const { + int32 ret = _sbufferSize; if(_channels == 2) ret /= 2; if(_bitsize > 8) ret /= 2; return ret; } -void ImuseChannel::getSoundData(short * snd, int size) { +void ImuseChannel::getSoundData(int16 * snd, int32 size) { if(_dataSize <= 0 || _bitsize <= 8) error("invalid call to imuse_channel::read_sound_data()"); if(_channels == 2) size *= 2; - for(int i = 0; i < size; i++) + for(int32 i = 0; i < size; i++) snd[i] = READ_BE_UINT16(_sbuffer + 2 * i); delete []_sbuffer; assert(_sbufferSize == 2 * size); @@ -314,10 +315,10 @@ void ImuseChannel::getSoundData(short * snd, int size) { _dataSize -= _srbufferSize; } -void ImuseChannel::getSoundData(char * snd, int size) { +void ImuseChannel::getSoundData(int8 * snd, int32 size) { if(_dataSize <= 0 || _bitsize > 8) error("invalid call to imuse_channel::read_sound_data()"); if(_channels == 2) size *= 2; - for(int i = 0; i < size; i++) + for(int32 i = 0; i < size; i++) snd[i] = _sbuffer[i]; delete []_sbuffer; _sbuffer = 0; |