SOUND: Move the Mac snd decoder from SCI to /sound
For use with Kyra1 Mac instrument samples. T7G Mac and Loom Mac also use this format for their custom instrument samples. svn-id: r51327
This commit is contained in:
parent
5fb760b053
commit
7a86204e5c
4 changed files with 178 additions and 12 deletions
|
@ -36,6 +36,7 @@
|
||||||
#include "sound/audiostream.h"
|
#include "sound/audiostream.h"
|
||||||
#include "sound/decoders/aiff.h"
|
#include "sound/decoders/aiff.h"
|
||||||
#include "sound/decoders/flac.h"
|
#include "sound/decoders/flac.h"
|
||||||
|
#include "sound/decoders/mac_snd.h"
|
||||||
#include "sound/decoders/mp3.h"
|
#include "sound/decoders/mp3.h"
|
||||||
#include "sound/decoders/raw.h"
|
#include "sound/decoders/raw.h"
|
||||||
#include "sound/decoders/vorbis.h"
|
#include "sound/decoders/vorbis.h"
|
||||||
|
@ -338,19 +339,9 @@ Audio::RewindableAudioStream *AudioPlayer::getAudioStream(uint32 number, uint32
|
||||||
} else if (audioRes->size > 14 && READ_BE_UINT16(audioRes->data) == 1 && READ_BE_UINT16(audioRes->data + 2) == 1
|
} else if (audioRes->size > 14 && READ_BE_UINT16(audioRes->data) == 1 && READ_BE_UINT16(audioRes->data + 2) == 1
|
||||||
&& READ_BE_UINT16(audioRes->data + 4) == 5 && READ_BE_UINT32(audioRes->data + 10) == 0x00018051) {
|
&& READ_BE_UINT16(audioRes->data + 4) == 5 && READ_BE_UINT32(audioRes->data + 10) == 0x00018051) {
|
||||||
// Mac snd detected
|
// Mac snd detected
|
||||||
// See http://developer.apple.com/legacy/mac/library/documentation/mac/Sound/Sound-60.html#HEADING60-15 for more details
|
Common::MemoryReadStream *sndStream = new Common::MemoryReadStream(audioRes->data, audioRes->size, DisposeAfterUse::NO);
|
||||||
|
|
||||||
uint32 soundHeaderOffset = READ_BE_UINT32(audioRes->data + 16);
|
audioSeekStream = Audio::makeMacSndStream(sndStream, DisposeAfterUse::YES);
|
||||||
assert(READ_BE_UINT32(audioRes->data + soundHeaderOffset) == 0);
|
|
||||||
size = READ_BE_UINT32(audioRes->data + soundHeaderOffset + 4);
|
|
||||||
_audioRate = READ_BE_UINT16(audioRes->data + soundHeaderOffset + 8); // Really floating point, but we're just truncating
|
|
||||||
|
|
||||||
if (*(audioRes->data + soundHeaderOffset + 20) != 0)
|
|
||||||
error("Unhandled Mac snd extended/compressed header");
|
|
||||||
|
|
||||||
data = (byte *)malloc(size);
|
|
||||||
memcpy(data, audioRes->data + soundHeaderOffset + 22, size);
|
|
||||||
flags = Audio::FLAG_UNSIGNED;
|
|
||||||
} else {
|
} else {
|
||||||
// SCI1 raw audio
|
// SCI1 raw audio
|
||||||
size = audioRes->size;
|
size = audioRes->size;
|
||||||
|
|
116
sound/decoders/mac_snd.cpp
Normal file
116
sound/decoders/mac_snd.cpp
Normal file
|
@ -0,0 +1,116 @@
|
||||||
|
/* ScummVM - Graphic Adventure Engine
|
||||||
|
*
|
||||||
|
* ScummVM is the legal property of its developers, whose names
|
||||||
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
||||||
|
* file distributed with this source distribution.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* $URL$
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The code in this file is based on information found at
|
||||||
|
* http://developer.apple.com/legacy/mac/library/documentation/mac/Sound/Sound-60.html#HEADING60-15
|
||||||
|
*
|
||||||
|
* We implement both type 1 and type 2 snd resources, but only those that are sampled
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "common/util.h"
|
||||||
|
#include "common/stream.h"
|
||||||
|
|
||||||
|
#include "sound/decoders/mac_snd.h"
|
||||||
|
#include "sound/audiostream.h"
|
||||||
|
#include "sound/decoders/raw.h"
|
||||||
|
|
||||||
|
namespace Audio {
|
||||||
|
|
||||||
|
SeekableAudioStream *makeMacSndStream(Common::SeekableReadStream *stream,
|
||||||
|
DisposeAfterUse::Flag disposeAfterUse) {
|
||||||
|
|
||||||
|
uint16 sndType = stream->readUint16BE();
|
||||||
|
|
||||||
|
if (sndType == 1) {
|
||||||
|
// "normal" snd resources
|
||||||
|
if (stream->readUint16BE() != 1) {
|
||||||
|
warning("makeMacSndStream(): Unsupported data type count");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (stream->readUint16BE() != 5) {
|
||||||
|
// 5 == sampled
|
||||||
|
warning("makeMacSndStream(): Unsupported data type");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
stream->readUint32BE(); // initialization option
|
||||||
|
} else if (sndType == 2) {
|
||||||
|
// old HyperCard snd resources
|
||||||
|
stream->readUint16BE(); // reference count (unused)
|
||||||
|
} else {
|
||||||
|
warning("makeMacSndStream(): Unknown format type %d", sndType);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// We really should never get this as long as we have sampled data only
|
||||||
|
if (stream->readUint16BE() != 1) {
|
||||||
|
warning("makeMacSndStream(): Unsupported command count");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16 command = stream->readUint16BE();
|
||||||
|
|
||||||
|
// 0x8050 - soundCmd (with dataOffsetFlag set): install a sampled sound as a voice
|
||||||
|
// 0x8051 - bufferCmd (with dataOffsetFlag set): play a sample sound
|
||||||
|
if (command != 0x8050 && command != 0x8051) {
|
||||||
|
warning("makeMacSndStream(): Unsupported command %04x", command);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
stream->readUint16BE(); // 0
|
||||||
|
uint32 soundHeaderOffset = stream->readUint32BE();
|
||||||
|
|
||||||
|
stream->seek(soundHeaderOffset);
|
||||||
|
|
||||||
|
uint32 soundDataOffset = stream->readUint32BE();
|
||||||
|
uint32 size = stream->readUint32BE();
|
||||||
|
uint16 rate = stream->readUint32BE() >> 16; // Really floating point, but we only support integer rates
|
||||||
|
stream->readUint32BE(); // loop start
|
||||||
|
stream->readUint32BE(); // loop end
|
||||||
|
byte encoding = stream->readByte();
|
||||||
|
stream->readByte(); // base frequency
|
||||||
|
|
||||||
|
if (encoding != 0) {
|
||||||
|
// 0 == PCM
|
||||||
|
warning("makeMacSndStream(): Unsupported compression %d", encoding);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
stream->skip(soundDataOffset);
|
||||||
|
|
||||||
|
byte *data = (byte *)malloc(size);
|
||||||
|
assert(data);
|
||||||
|
stream->read(data, size);
|
||||||
|
|
||||||
|
if (disposeAfterUse == DisposeAfterUse::YES)
|
||||||
|
delete stream;
|
||||||
|
|
||||||
|
// Since we allocated our own buffer for the data, we must specify DisposeAfterUse::YES.
|
||||||
|
return makeRawStream(data, size, rate, Audio::FLAG_UNSIGNED);
|
||||||
|
}
|
||||||
|
|
||||||
|
} // End of namespace Audio
|
58
sound/decoders/mac_snd.h
Normal file
58
sound/decoders/mac_snd.h
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/* ScummVM - Graphic Adventure Engine
|
||||||
|
*
|
||||||
|
* ScummVM is the legal property of its developers, whose names
|
||||||
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
||||||
|
* file distributed with this source distribution.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*
|
||||||
|
* $URL$
|
||||||
|
* $Id$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file
|
||||||
|
* Sound decoder used in engines:
|
||||||
|
* - sci
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef SOUND_MAC_SND_H
|
||||||
|
#define SOUND_MAC_SND_H
|
||||||
|
|
||||||
|
#include "common/scummsys.h"
|
||||||
|
#include "common/types.h"
|
||||||
|
|
||||||
|
namespace Common { class SeekableReadStream; }
|
||||||
|
|
||||||
|
namespace Audio {
|
||||||
|
|
||||||
|
class SeekableAudioStream;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Try to load a Mac snd resource from the given seekable stream and create a SeekableAudioStream
|
||||||
|
* from that data.
|
||||||
|
*
|
||||||
|
* @param stream the SeekableReadStream from which to read the snd data
|
||||||
|
* @param disposeAfterUse whether to delete the stream after use
|
||||||
|
* @return a new SeekableAudioStream, or NULL, if an error occurred
|
||||||
|
*/
|
||||||
|
SeekableAudioStream *makeMacSndStream(
|
||||||
|
Common::SeekableReadStream *stream,
|
||||||
|
DisposeAfterUse::Flag disposeAfterUse);
|
||||||
|
|
||||||
|
} // End of namespace Audio
|
||||||
|
|
||||||
|
#endif
|
|
@ -17,6 +17,7 @@ MODULE_OBJS := \
|
||||||
decoders/aiff.o \
|
decoders/aiff.o \
|
||||||
decoders/flac.o \
|
decoders/flac.o \
|
||||||
decoders/iff_sound.o \
|
decoders/iff_sound.o \
|
||||||
|
decoders/mac_snd.o \
|
||||||
decoders/mp3.o \
|
decoders/mp3.o \
|
||||||
decoders/raw.o \
|
decoders/raw.o \
|
||||||
decoders/vag.o \
|
decoders/vag.o \
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue