mirror of
https://github.com/libretro/scummvm.git
synced 2025-04-05 16:21:40 +00:00
MT32: Get rid of ANSIFile.
svn-id: r54827
This commit is contained in:
parent
08262d90fb
commit
d451084fb4
@ -20,95 +20,51 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
// FIXME: Disable symbol overrides so that we can use system headers.
|
|
||||||
// But we *really* should get rid of this usage of FILE, fopen etc.
|
|
||||||
#define FORBIDDEN_SYMBOL_ALLOW_ALL
|
|
||||||
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
#include "mt32emu.h"
|
#include "mt32emu.h"
|
||||||
|
|
||||||
namespace MT32Emu {
|
namespace MT32Emu {
|
||||||
|
|
||||||
bool ANSIFile::open(const char *filename, OpenMode mode) {
|
bool File::readBit16u(Bit16u *in) {
|
||||||
const char *fmode;
|
Bit8u b[2];
|
||||||
if (mode == OpenMode_read) {
|
if (read(&b[0], 2) != 2)
|
||||||
fmode = "rb";
|
return false;
|
||||||
} else {
|
*in = ((b[0] << 8) | b[1]);
|
||||||
fmode = "wb";
|
return true;
|
||||||
}
|
|
||||||
fp = fopen(filename, fmode);
|
|
||||||
return (fp != NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ANSIFile::close() {
|
|
||||||
fclose((FILE *)fp);
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t ANSIFile::read(void *in, size_t size) {
|
|
||||||
return fread(in, 1, size, (FILE *)fp);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ANSIFile::readBit8u(Bit8u *in) {
|
|
||||||
int c = fgetc((FILE *)fp);
|
|
||||||
if (c == EOF)
|
|
||||||
return false;
|
|
||||||
*in = (Bit8u)c;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool File::readBit16u(Bit16u *in) {
|
|
||||||
Bit8u b[2];
|
|
||||||
if (read(&b[0], 2) != 2)
|
|
||||||
return false;
|
|
||||||
*in = ((b[0] << 8) | b[1]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool File::readBit32u(Bit32u *in) {
|
|
||||||
Bit8u b[4];
|
|
||||||
if (read(&b[0], 4) != 4)
|
|
||||||
return false;
|
|
||||||
*in = ((b[0] << 24) | (b[1] << 16) | (b[2] << 8) | b[3]);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t ANSIFile::write(const void *out, size_t size) {
|
|
||||||
return fwrite(out, 1, size, (FILE *)fp);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ANSIFile::writeBit8u(Bit8u out) {
|
|
||||||
return fputc(out, (FILE *)fp) != EOF;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool File::writeBit16u(Bit16u out) {
|
|
||||||
if (!writeBit8u((Bit8u)((out & 0xFF00) >> 8))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!writeBit8u((Bit8u)(out & 0x00FF))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool File::writeBit32u(Bit32u out) {
|
|
||||||
if (!writeBit8u((Bit8u)((out & 0xFF000000) >> 24))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!writeBit8u((Bit8u)((out & 0x00FF0000) >> 16))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!writeBit8u((Bit8u)((out & 0x0000FF00) >> 8))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (!writeBit8u((Bit8u)(out & 0x000000FF))) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ANSIFile::isEOF() {
|
|
||||||
return feof((FILE *)fp) != 0;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool File::readBit32u(Bit32u *in) {
|
||||||
|
Bit8u b[4];
|
||||||
|
if (read(&b[0], 4) != 4)
|
||||||
|
return false;
|
||||||
|
*in = ((b[0] << 24) | (b[1] << 16) | (b[2] << 8) | b[3]);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool File::writeBit16u(Bit16u out) {
|
||||||
|
if (!writeBit8u((Bit8u)((out & 0xFF00) >> 8))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!writeBit8u((Bit8u)(out & 0x00FF))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool File::writeBit32u(Bit32u out) {
|
||||||
|
if (!writeBit8u((Bit8u)((out & 0xFF000000) >> 24))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!writeBit8u((Bit8u)((out & 0x00FF0000) >> 16))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!writeBit8u((Bit8u)((out & 0x0000FF00) >> 8))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (!writeBit8u((Bit8u)(out & 0x000000FF))) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // End of namespace MT32Emu
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
#ifndef MT32EMU_FILE_H
|
#ifndef MT32EMU_FILE_H
|
||||||
#define MT32EMU_FILE_H
|
#define MT32EMU_FILE_H
|
||||||
|
|
||||||
#include <stdio.h>
|
#include "common/scummsys.h"
|
||||||
|
|
||||||
namespace MT32Emu {
|
namespace MT32Emu {
|
||||||
|
|
||||||
@ -47,19 +47,6 @@ public:
|
|||||||
virtual bool isEOF() = 0;
|
virtual bool isEOF() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
class ANSIFile: public File {
|
} // End of namespace MT32Emu
|
||||||
private:
|
|
||||||
void *fp;
|
|
||||||
public:
|
|
||||||
bool open(const char *filename, OpenMode mode);
|
|
||||||
void close();
|
|
||||||
size_t read(void *in, size_t size);
|
|
||||||
bool readBit8u(Bit8u *in);
|
|
||||||
size_t write(const void *out, size_t size);
|
|
||||||
bool writeBit8u(Bit8u out);
|
|
||||||
bool isEOF();
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -162,21 +162,11 @@ void Synth::initReverb(Bit8u newRevMode, Bit8u newRevTime, Bit8u newRevLevel) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
File *Synth::openFile(const char *filename, File::OpenMode mode) {
|
File *Synth::openFile(const char *filename, File::OpenMode mode) {
|
||||||
if (myProp.openFile != NULL) {
|
// It should never happen that openFile is NULL in our use case.
|
||||||
return myProp.openFile(myProp.userData, filename, mode);
|
// Just to cover the case where something is horrible wrong we
|
||||||
}
|
// use an assert here.
|
||||||
char pathBuf[2048];
|
assert(myProp.openFile != NULL);
|
||||||
if (myProp.baseDir != NULL) {
|
return myProp.openFile(myProp.userData, filename, mode);
|
||||||
strcpy(&pathBuf[0], myProp.baseDir);
|
|
||||||
strcat(&pathBuf[0], filename);
|
|
||||||
filename = pathBuf;
|
|
||||||
}
|
|
||||||
ANSIFile *file = new ANSIFile();
|
|
||||||
if (!file->open(filename, mode)) {
|
|
||||||
delete file;
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
return file;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Synth::closeFile(File *file) {
|
void Synth::closeFile(File *file) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user