2010-08-16 12:13:13 +00:00
|
|
|
#ifndef MANGLE_SOUND_SAMPLE_READER_H
|
|
|
|
#define MANGLE_SOUND_SAMPLE_READER_H
|
|
|
|
|
|
|
|
#include "../source.hpp"
|
|
|
|
|
|
|
|
namespace Mangle {
|
|
|
|
namespace Sound {
|
|
|
|
|
|
|
|
/* This is a helper base class for other SampleSource
|
|
|
|
implementations. Certain sources (like Audiere and libsndfile)
|
|
|
|
insist on reading whole samples rather than bytes. This class
|
|
|
|
compensates for that, and allows you to read bytes rather than
|
|
|
|
samples.
|
2010-08-16 14:26:24 +00:00
|
|
|
|
|
|
|
There are two ways for subclasses to use this class. EITHER call
|
|
|
|
setup() with the size of frameSize. This will allocate a buffer,
|
|
|
|
which the destructor frees. OR set frameSize manually and
|
|
|
|
manipulate the pullOver pointer yourself. In that case you MUST
|
|
|
|
reset it to NULL if you don't want the destructor to call
|
|
|
|
delete[] on it.
|
2010-08-16 12:13:13 +00:00
|
|
|
*/
|
|
|
|
class SampleReader : public SampleSource
|
|
|
|
{
|
|
|
|
// How much of the above buffer is in use.
|
|
|
|
int pullSize;
|
|
|
|
|
|
|
|
protected:
|
2010-08-16 14:26:24 +00:00
|
|
|
// Pullover buffer
|
|
|
|
char* pullOver;
|
|
|
|
|
2010-08-16 12:13:13 +00:00
|
|
|
// Size of one frame, in bytes. This is also the size of the
|
|
|
|
// pullOver buffer.
|
|
|
|
int frameSize;
|
|
|
|
|
2010-08-16 14:26:24 +00:00
|
|
|
// The parameter gives the size of one sample/frame, in bytes.
|
2010-08-16 12:13:13 +00:00
|
|
|
void setup(int);
|
|
|
|
|
|
|
|
// Read the given number of samples, in multiples of frameSize. Does
|
|
|
|
// not have to set or respect isEof.
|
|
|
|
virtual size_t readSamples(void *data, size_t num) = 0;
|
|
|
|
|
|
|
|
public:
|
2010-08-16 15:01:11 +00:00
|
|
|
SampleReader() : pullSize(0), pullOver(NULL) {}
|
2010-08-16 12:13:13 +00:00
|
|
|
~SampleReader();
|
|
|
|
size_t read(void *data, size_t length);
|
|
|
|
};
|
|
|
|
}} // Namespace
|
|
|
|
#endif
|