mirror of
https://gitlab.com/GaryOderNichts/re3-wiiu.git
synced 2024-11-25 18:46:52 +01:00
wiiu: switch back to sndfile to support audio compression
This commit is contained in:
parent
bd2cc333d6
commit
8277064b1f
2
Makefile
2
Makefile
@ -65,7 +65,7 @@ CXXFLAGS := $(CFLAGS)
|
|||||||
ASFLAGS := -g $(ARCH)
|
ASFLAGS := -g $(ARCH)
|
||||||
LDFLAGS = -g $(ARCH) $(RPXSPECS) -Wl,-Map,$(notdir $*.map)
|
LDFLAGS = -g $(ARCH) $(RPXSPECS) -Wl,-Map,$(notdir $*.map)
|
||||||
|
|
||||||
LIBS := -lrw -lmpg123 -lopenal -lSDL2 -lwut
|
LIBS := -lrw -lmpg123 -lsndfile -lopenal -lSDL2 -lwut
|
||||||
|
|
||||||
#-------------------------------------------------------------------------------
|
#-------------------------------------------------------------------------------
|
||||||
# list of directories containing libraries, this must be the top level
|
# list of directories containing libraries, this must be the top level
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
#pragma comment( lib, "libsndfile-1.lib" )
|
#pragma comment( lib, "libsndfile-1.lib" )
|
||||||
#pragma comment( lib, "libmpg123-0.lib" )
|
#pragma comment( lib, "libmpg123-0.lib" )
|
||||||
#endif
|
#endif
|
||||||
#ifndef __WIIU__
|
#if 1
|
||||||
#include <sndfile.h>
|
#include <sndfile.h>
|
||||||
#else
|
#else
|
||||||
#define DR_WAV_IMPLEMENTATION
|
#define DR_WAV_IMPLEMENTATION
|
||||||
@ -27,17 +27,72 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef AUDIO_OPUS
|
#ifndef AUDIO_OPUS
|
||||||
#ifndef __WIIU__
|
#ifndef DR_WAV_IMPLEMENTATION
|
||||||
|
static sf_count_t sndfile_vio_get_filelen(void* user_data)
|
||||||
|
{
|
||||||
|
int32 pos = ftell((FILE*)user_data);
|
||||||
|
fseek((FILE*)user_data, 0, SEEK_END);
|
||||||
|
int32 size = ftell((FILE*)user_data);
|
||||||
|
fseek((FILE*)user_data, pos, SEEK_SET);
|
||||||
|
return size;
|
||||||
|
}
|
||||||
|
|
||||||
|
static sf_count_t sndfile_vio_seek(sf_count_t offset, int whence, void* user_data)
|
||||||
|
{
|
||||||
|
fseek((FILE*)user_data, offset, whence);
|
||||||
|
return ftell((FILE*)user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static sf_count_t sndfile_vio_read(void* ptr, sf_count_t count, void* user_data)
|
||||||
|
{
|
||||||
|
return fread(ptr, 1, count, (FILE*)user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static sf_count_t
|
||||||
|
sndfile_vio_write(const void* ptr, sf_count_t count, void* user_data)
|
||||||
|
{
|
||||||
|
return fwrite(ptr, 1, count, (FILE*)user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static sf_count_t
|
||||||
|
sndfile_vio_tell(void* user_data)
|
||||||
|
{
|
||||||
|
return ftell((FILE*)user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
static SF_VIRTUAL_IO vio =
|
||||||
|
{
|
||||||
|
.get_filelen = sndfile_vio_get_filelen,
|
||||||
|
.seek = sndfile_vio_seek,
|
||||||
|
.read = sndfile_vio_read,
|
||||||
|
.write = sndfile_vio_write,
|
||||||
|
.tell = sndfile_vio_tell,
|
||||||
|
};
|
||||||
|
|
||||||
class CSndFile : public IDecoder
|
class CSndFile : public IDecoder
|
||||||
{
|
{
|
||||||
SNDFILE *m_pfSound;
|
SNDFILE *m_pfSound;
|
||||||
SF_INFO m_soundInfo;
|
SF_INFO m_soundInfo;
|
||||||
|
FILE* m_fileHandle;
|
||||||
|
char* m_buffer;
|
||||||
public:
|
public:
|
||||||
CSndFile(const char *path) :
|
CSndFile(const char *path) :
|
||||||
m_pfSound(nil)
|
m_pfSound(nil),
|
||||||
|
m_fileHandle(NULL),
|
||||||
|
m_buffer(NULL)
|
||||||
{
|
{
|
||||||
memset(&m_soundInfo, 0, sizeof(m_soundInfo));
|
memset(&m_soundInfo, 0, sizeof(m_soundInfo));
|
||||||
m_pfSound = sf_open(path, SFM_READ, &m_soundInfo);
|
|
||||||
|
m_buffer = (char*) memalign(0x40, BUFSIZ);
|
||||||
|
|
||||||
|
m_fileHandle = fopen(path, "rb");
|
||||||
|
if (!m_fileHandle) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
setbuf(m_fileHandle, m_buffer);
|
||||||
|
|
||||||
|
m_pfSound = sf_open_virtual(&vio, SFM_READ, &m_soundInfo, m_fileHandle);
|
||||||
}
|
}
|
||||||
|
|
||||||
~CSndFile()
|
~CSndFile()
|
||||||
@ -47,6 +102,11 @@ public:
|
|||||||
sf_close(m_pfSound);
|
sf_close(m_pfSound);
|
||||||
m_pfSound = nil;
|
m_pfSound = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_fileHandle) {
|
||||||
|
fclose(m_fileHandle);
|
||||||
|
}
|
||||||
|
free(m_buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool IsOpened()
|
bool IsOpened()
|
||||||
@ -470,7 +530,7 @@ CStream::CStream(char *filename, ALuint &source, ALuint (&buffers)[NUM_STREAMBUF
|
|||||||
if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".mp3")], ".mp3"))
|
if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".mp3")], ".mp3"))
|
||||||
m_pSoundFile = new CMP3File(m_aFilename);
|
m_pSoundFile = new CMP3File(m_aFilename);
|
||||||
else if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".wav")], ".wav"))
|
else if (!strcasecmp(&m_aFilename[strlen(m_aFilename) - strlen(".wav")], ".wav"))
|
||||||
#ifndef __WIIU__
|
#ifndef DR_WAV_IMPLEMENTATION
|
||||||
m_pSoundFile = new CSndFile(m_aFilename);
|
m_pSoundFile = new CSndFile(m_aFilename);
|
||||||
#else
|
#else
|
||||||
m_pSoundFile = new CDrWav(m_aFilename);
|
m_pSoundFile = new CDrWav(m_aFilename);
|
||||||
|
Loading…
Reference in New Issue
Block a user