mirror of
https://github.com/ZDoom/qzdoom-gpl.git
synced 2024-11-17 17:50:57 +00:00
Move specific decoder classes to separate headers
This commit is contained in:
parent
e2708c8b3e
commit
4f6861d798
6 changed files with 108 additions and 86 deletions
|
@ -56,6 +56,9 @@ extern HINSTANCE g_hInst;
|
||||||
#include "fmodsound.h"
|
#include "fmodsound.h"
|
||||||
#include "oalsound.h"
|
#include "oalsound.h"
|
||||||
|
|
||||||
|
#include "mpg123_decoder.h"
|
||||||
|
#include "sndfile_decoder.h"
|
||||||
|
|
||||||
#include "m_swap.h"
|
#include "m_swap.h"
|
||||||
#include "stats.h"
|
#include "stats.h"
|
||||||
#include "files.h"
|
#include "files.h"
|
||||||
|
|
|
@ -139,88 +139,4 @@ private:
|
||||||
SoundDecoder& operator=(const SoundDecoder &rhs);
|
SoundDecoder& operator=(const SoundDecoder &rhs);
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef HAVE_MPG123
|
|
||||||
#include "mpg123.h"
|
|
||||||
struct MPG123Decoder : public SoundDecoder
|
|
||||||
{
|
|
||||||
virtual void getInfo(int *samplerate, ChannelConfig *chans, SampleType *type);
|
|
||||||
|
|
||||||
virtual size_t read(char *buffer, size_t bytes);
|
|
||||||
virtual bool seek(size_t ms_offset);
|
|
||||||
virtual size_t getSampleOffset();
|
|
||||||
|
|
||||||
MPG123Decoder() : MPG123(0), File(0) { }
|
|
||||||
virtual ~MPG123Decoder();
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual bool open(const char *data, size_t length);
|
|
||||||
virtual bool open(const char *fname, size_t offset, size_t length);
|
|
||||||
|
|
||||||
private:
|
|
||||||
mpg123_handle *MPG123;
|
|
||||||
bool Done;
|
|
||||||
|
|
||||||
FILE *File;
|
|
||||||
size_t FileLength;
|
|
||||||
size_t FileOffset;
|
|
||||||
static off_t file_lseek(void *handle, off_t offset, int whence);
|
|
||||||
static ssize_t file_read(void *handle, void *buffer, size_t bytes);
|
|
||||||
|
|
||||||
const char *MemData;
|
|
||||||
size_t MemLength;
|
|
||||||
size_t MemPos;
|
|
||||||
static off_t mem_lseek(void *handle, off_t offset, int whence);
|
|
||||||
static ssize_t mem_read(void *handle, void *buffer, size_t bytes);
|
|
||||||
|
|
||||||
// Make non-copyable
|
|
||||||
MPG123Decoder(const MPG123Decoder &rhs);
|
|
||||||
MPG123Decoder& operator=(const MPG123Decoder &rhs);
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_SNDFILE
|
|
||||||
#include "sndfile.h"
|
|
||||||
struct SndFileDecoder : public SoundDecoder
|
|
||||||
{
|
|
||||||
virtual void getInfo(int *samplerate, ChannelConfig *chans, SampleType *type);
|
|
||||||
|
|
||||||
virtual size_t read(char *buffer, size_t bytes);
|
|
||||||
virtual std::vector<char> readAll();
|
|
||||||
virtual bool seek(size_t ms_offset);
|
|
||||||
virtual size_t getSampleOffset();
|
|
||||||
|
|
||||||
SndFileDecoder() : SndFile(0), File(0) { }
|
|
||||||
virtual ~SndFileDecoder();
|
|
||||||
|
|
||||||
protected:
|
|
||||||
virtual bool open(const char *data, size_t length);
|
|
||||||
virtual bool open(const char *fname, size_t offset, size_t length);
|
|
||||||
|
|
||||||
private:
|
|
||||||
SNDFILE *SndFile;
|
|
||||||
SF_INFO SndInfo;
|
|
||||||
|
|
||||||
FILE *File;
|
|
||||||
size_t FileLength;
|
|
||||||
size_t FileOffset;
|
|
||||||
static sf_count_t file_get_filelen(void *user_data);
|
|
||||||
static sf_count_t file_seek(sf_count_t offset, int whence, void *user_data);
|
|
||||||
static sf_count_t file_read(void *ptr, sf_count_t count, void *user_data);
|
|
||||||
static sf_count_t file_write(const void *ptr, sf_count_t count, void *user_data);
|
|
||||||
static sf_count_t file_tell(void *user_data);
|
|
||||||
|
|
||||||
const char *MemData;
|
|
||||||
size_t MemLength;
|
|
||||||
size_t MemPos;
|
|
||||||
static sf_count_t mem_get_filelen(void *user_data);
|
|
||||||
static sf_count_t mem_seek(sf_count_t offset, int whence, void *user_data);
|
|
||||||
static sf_count_t mem_read(void *ptr, sf_count_t count, void *user_data);
|
|
||||||
static sf_count_t mem_write(const void *ptr, sf_count_t count, void *user_data);
|
|
||||||
static sf_count_t mem_tell(void *user_data);
|
|
||||||
|
|
||||||
// Make non-copyable
|
|
||||||
SndFileDecoder(const SndFileDecoder &rhs);
|
|
||||||
SndFileDecoder& operator=(const SndFileDecoder &rhs);
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#include "i_soundinternal.h"
|
#include "mpg123_decoder.h"
|
||||||
|
|
||||||
#ifdef HAVE_MPG123
|
#ifdef HAVE_MPG123
|
||||||
static bool inited = false;
|
static bool inited = false;
|
||||||
|
|
48
src/sound/mpg123_decoder.h
Normal file
48
src/sound/mpg123_decoder.h
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
#ifndef MPG123_DECODER_H
|
||||||
|
#define MPG123_DECODER_H
|
||||||
|
|
||||||
|
#include "i_soundinternal.h"
|
||||||
|
|
||||||
|
#ifdef HAVE_MPG123
|
||||||
|
|
||||||
|
#include "mpg123.h"
|
||||||
|
|
||||||
|
struct MPG123Decoder : public SoundDecoder
|
||||||
|
{
|
||||||
|
virtual void getInfo(int *samplerate, ChannelConfig *chans, SampleType *type);
|
||||||
|
|
||||||
|
virtual size_t read(char *buffer, size_t bytes);
|
||||||
|
virtual bool seek(size_t ms_offset);
|
||||||
|
virtual size_t getSampleOffset();
|
||||||
|
|
||||||
|
MPG123Decoder() : MPG123(0), File(0) { }
|
||||||
|
virtual ~MPG123Decoder();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual bool open(const char *data, size_t length);
|
||||||
|
virtual bool open(const char *fname, size_t offset, size_t length);
|
||||||
|
|
||||||
|
private:
|
||||||
|
mpg123_handle *MPG123;
|
||||||
|
bool Done;
|
||||||
|
|
||||||
|
FILE *File;
|
||||||
|
size_t FileLength;
|
||||||
|
size_t FileOffset;
|
||||||
|
static off_t file_lseek(void *handle, off_t offset, int whence);
|
||||||
|
static ssize_t file_read(void *handle, void *buffer, size_t bytes);
|
||||||
|
|
||||||
|
const char *MemData;
|
||||||
|
size_t MemLength;
|
||||||
|
size_t MemPos;
|
||||||
|
static off_t mem_lseek(void *handle, off_t offset, int whence);
|
||||||
|
static ssize_t mem_read(void *handle, void *buffer, size_t bytes);
|
||||||
|
|
||||||
|
// Make non-copyable
|
||||||
|
MPG123Decoder(const MPG123Decoder &rhs);
|
||||||
|
MPG123Decoder& operator=(const MPG123Decoder &rhs);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* MPG123_DECODER_H */
|
|
@ -1,4 +1,4 @@
|
||||||
#include "i_soundinternal.h"
|
#include "sndfile_decoder.h"
|
||||||
|
|
||||||
#ifdef HAVE_SNDFILE
|
#ifdef HAVE_SNDFILE
|
||||||
sf_count_t SndFileDecoder::file_get_filelen(void *user_data)
|
sf_count_t SndFileDecoder::file_get_filelen(void *user_data)
|
||||||
|
|
55
src/sound/sndfile_decoder.h
Normal file
55
src/sound/sndfile_decoder.h
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
#ifndef SNDFILE_DECODER_H
|
||||||
|
#define SNDFILE_DECODER_H
|
||||||
|
|
||||||
|
#include "i_soundinternal.h"
|
||||||
|
|
||||||
|
#ifdef HAVE_SNDFILE
|
||||||
|
|
||||||
|
#include "sndfile.h"
|
||||||
|
|
||||||
|
struct SndFileDecoder : public SoundDecoder
|
||||||
|
{
|
||||||
|
virtual void getInfo(int *samplerate, ChannelConfig *chans, SampleType *type);
|
||||||
|
|
||||||
|
virtual size_t read(char *buffer, size_t bytes);
|
||||||
|
virtual std::vector<char> readAll();
|
||||||
|
virtual bool seek(size_t ms_offset);
|
||||||
|
virtual size_t getSampleOffset();
|
||||||
|
|
||||||
|
SndFileDecoder() : SndFile(0), File(0) { }
|
||||||
|
virtual ~SndFileDecoder();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual bool open(const char *data, size_t length);
|
||||||
|
virtual bool open(const char *fname, size_t offset, size_t length);
|
||||||
|
|
||||||
|
private:
|
||||||
|
SNDFILE *SndFile;
|
||||||
|
SF_INFO SndInfo;
|
||||||
|
|
||||||
|
FILE *File;
|
||||||
|
size_t FileLength;
|
||||||
|
size_t FileOffset;
|
||||||
|
static sf_count_t file_get_filelen(void *user_data);
|
||||||
|
static sf_count_t file_seek(sf_count_t offset, int whence, void *user_data);
|
||||||
|
static sf_count_t file_read(void *ptr, sf_count_t count, void *user_data);
|
||||||
|
static sf_count_t file_write(const void *ptr, sf_count_t count, void *user_data);
|
||||||
|
static sf_count_t file_tell(void *user_data);
|
||||||
|
|
||||||
|
const char *MemData;
|
||||||
|
size_t MemLength;
|
||||||
|
size_t MemPos;
|
||||||
|
static sf_count_t mem_get_filelen(void *user_data);
|
||||||
|
static sf_count_t mem_seek(sf_count_t offset, int whence, void *user_data);
|
||||||
|
static sf_count_t mem_read(void *ptr, sf_count_t count, void *user_data);
|
||||||
|
static sf_count_t mem_write(const void *ptr, sf_count_t count, void *user_data);
|
||||||
|
static sf_count_t mem_tell(void *user_data);
|
||||||
|
|
||||||
|
// Make non-copyable
|
||||||
|
SndFileDecoder(const SndFileDecoder &rhs);
|
||||||
|
SndFileDecoder& operator=(const SndFileDecoder &rhs);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* SNDFILE_DECODER_H */
|
Loading…
Reference in a new issue