aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMax Horn2003-07-25 13:42:05 +0000
committerMax Horn2003-07-25 13:42:05 +0000
commitc520d2d423f90811e2ad2eb6f768d1a88c6c1ca2 (patch)
tree53f398d41ceea4f67c6e1bf58b2a4abc7d2f2d3a
parent2ae3e45aea23a2e612276b6ce60486d21e889885 (diff)
downloadscummvm-rg350-c520d2d423f90811e2ad2eb6f768d1a88c6c1ca2.tar.gz
scummvm-rg350-c520d2d423f90811e2ad2eb6f768d1a88c6c1ca2.tar.bz2
scummvm-rg350-c520d2d423f90811e2ad2eb6f768d1a88c6c1ca2.zip
move AudioInputStream implementations & makeInputStream into separate .cpp file
svn-id: r9190
-rw-r--r--sound/audiostream.cpp91
-rw-r--r--sound/audiostream.h72
2 files changed, 95 insertions, 68 deletions
diff --git a/sound/audiostream.cpp b/sound/audiostream.cpp
new file mode 100644
index 0000000000..7b796b8d50
--- /dev/null
+++ b/sound/audiostream.cpp
@@ -0,0 +1,91 @@
+/* ScummVM - Scumm Interpreter
+ * Copyright (C) 2001-2003 The ScummVM project
+ *
+ * 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ *
+ * $Header$
+ *
+ */
+
+#include "audiostream.h"
+#include "mixer.h"
+
+template<int channels, int sampleSize>
+class MemoryAudioInputStream : public AudioInputStream {
+protected:
+ const byte *_ptr;
+ const byte *_end;
+ void advance() { _ptr += channels * sampleSize; }
+public:
+ MemoryAudioInputStream(const byte *ptr, uint len) : _ptr(ptr), _end(ptr+len) { }
+ virtual int size() { return (_end - _ptr) / (channels * sampleSize); }
+};
+
+
+template<int channels>
+class Input8bitSignedStream : public MemoryAudioInputStream<channels, 1> {
+protected:
+ int16 readIntern() { int8 v = (int8)*_ptr; return v << 8; }
+public:
+ Input8bitSignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 1>(ptr, len) { }
+};
+
+template<int channels>
+class Input8bitUnsignedStream : public MemoryAudioInputStream<channels, 1> {
+protected:
+ int16 readIntern() { int8 v = (int8)(*_ptr ^ 0x80); return v << 8; }
+public:
+ Input8bitUnsignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 1>(ptr, len) { }
+};
+
+template<int channels>
+class Input16bitSignedStream : public MemoryAudioInputStream<channels, 2> {
+protected:
+ int16 readIntern() { return (int16)READ_BE_UINT16(_ptr); }
+public:
+ Input16bitSignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 2>(ptr, len) { }
+};
+
+template<int channels>
+class Input16bitUnsignedStream : public MemoryAudioInputStream<channels, 2> {
+protected:
+ int16 readIntern() { return (int16)(READ_BE_UINT16(_ptr) ^ 0x8000); }
+public:
+ Input16bitUnsignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 2>(ptr, len) { }
+};
+
+
+template<int channels>
+static AudioInputStream *makeInputStream(const byte *ptr, uint32 len, bool isUnsigned, bool is16Bit) {
+ if (isUnsigned) {
+ if (is16Bit)
+ return new Input16bitUnsignedStream<channels>(ptr, len);
+ else
+ return new Input8bitUnsignedStream<channels>(ptr, len);
+ } else {
+ if (is16Bit)
+ return new Input16bitSignedStream<channels>(ptr, len);
+ else
+ return new Input8bitSignedStream<channels>(ptr, len);
+ }
+}
+
+
+AudioInputStream *makeInputStream(byte _flags, const byte *ptr, uint32 len) {
+ if (_flags & SoundMixer::FLAG_STEREO)
+ return makeInputStream<2>(ptr, len, _flags & SoundMixer::FLAG_UNSIGNED, _flags & SoundMixer::FLAG_16BITS);
+ else
+ return makeInputStream<1>(ptr, len, _flags & SoundMixer::FLAG_UNSIGNED, _flags & SoundMixer::FLAG_16BITS);
+}
diff --git a/sound/audiostream.h b/sound/audiostream.h
index 38c012a9e9..1eca349967 100644
--- a/sound/audiostream.h
+++ b/sound/audiostream.h
@@ -22,7 +22,8 @@
#ifndef AUDIOSTREAM_H
#define AUDIOSTREAM_H
-#include "mixer.h"
+#include "scummsys.h"
+#include <assert.h>
// TODO:
// * maybe make readIntern return 16.16 or 24.8 fixed point values
@@ -46,7 +47,7 @@ public:
class ZeroInputStream : public AudioInputStream {
protected:
- uint _len;
+ int _len;
int16 readIntern() { return 0; }
void advance() { _len--; }
public:
@@ -54,71 +55,6 @@ public:
virtual int size() { return _len; }
};
-template<int channels, int sampleSize>
-class MemoryAudioInputStream : public AudioInputStream {
-protected:
- const byte *_ptr;
- const byte *_end;
- void advance() { _ptr += channels * sampleSize; }
-public:
- MemoryAudioInputStream(const byte *ptr, uint len) : _ptr(ptr), _end(ptr+len) { }
- virtual int size() { return (_end - _ptr) / (channels * sampleSize); }
-};
-
-
-template<int channels>
-class Input8bitSignedStream : public MemoryAudioInputStream<channels, 1> {
-protected:
- int16 readIntern() { int8 v = (int8)*_ptr; return v << 8; }
-public:
- Input8bitSignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 1>(ptr, len) { }
-};
-
-template<int channels>
-class Input8bitUnsignedStream : public MemoryAudioInputStream<channels, 1> {
-protected:
- int16 readIntern() { int8 v = (int8)(*_ptr ^ 0x80); return v << 8; }
-public:
- Input8bitUnsignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 1>(ptr, len) { }
-};
-
-template<int channels>
-class Input16bitSignedStream : public MemoryAudioInputStream<channels, 2> {
-protected:
- int16 readIntern() { return (int16)READ_BE_UINT16(_ptr); }
-public:
- Input16bitSignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 2>(ptr, len) { }
-};
-
-template<int channels>
-class Input16bitUnsignedStream : public MemoryAudioInputStream<channels, 2> {
-protected:
- int16 readIntern() { return (int16)(READ_BE_UINT16(_ptr) ^ 0x8000); }
-public:
- Input16bitUnsignedStream(const byte *ptr, int len) : MemoryAudioInputStream<channels, 2>(ptr, len) { }
-};
-
-
-template<int channels>
-static AudioInputStream *makeInputStream(const byte *ptr, uint32 len, bool isUnsigned, bool is16Bit) {
- if (isUnsigned) {
- if (is16Bit)
- return new Input16bitUnsignedStream<channels>(ptr, len);
- else
- return new Input8bitUnsignedStream<channels>(ptr, len);
- } else {
- if (is16Bit)
- return new Input16bitSignedStream<channels>(ptr, len);
- else
- return new Input8bitSignedStream<channels>(ptr, len);
- }
-}
-
-static inline AudioInputStream *makeInputStream(byte _flags, const byte *ptr, uint32 len) {
- if (_flags & SoundMixer::FLAG_STEREO)
- return makeInputStream<2>(ptr, len, _flags & SoundMixer::FLAG_UNSIGNED, _flags & SoundMixer::FLAG_16BITS);
- else
- return makeInputStream<1>(ptr, len, _flags & SoundMixer::FLAG_UNSIGNED, _flags & SoundMixer::FLAG_16BITS);
-}
+AudioInputStream *makeInputStream(byte _flags, const byte *ptr, uint32 len);
#endif