scummvm/sys.cpp
2002-05-19 12:44:26 +00:00

242 lines
4.3 KiB
C++

/* ScummVM - Scumm Interpreter
* Copyright (C) 2001 Ludvig Strigeus
* Copyright (C) 2001/2002 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 "stdafx.h"
#include "scumm.h"
void *Scumm::fileOpen(const char *filename, int mode)
{
_fileMode = mode;
_whereInResToRead = 0;
clearFileReadFailed(_fileHandle);
if (mode == 1)
return fopen(filename, "rb");
if (mode == 2) {
error("fileOpen: write not supported");
}
return NULL;
}
void Scumm::fileClose(void *file)
{
if (_fileMode == 1 || _fileMode == 2)
fclose((FILE *) file);
}
bool Scumm::fileReadFailed(void *file)
{
return _fileReadFailed != 0;
}
void Scumm::clearFileReadFailed(void *file)
{
_fileReadFailed = false;
}
bool Scumm::fileEof(void *file)
{
return feof((FILE *) file) != 0;
}
uint32 Scumm::filePos(void *handle)
{
return ftell((FILE *) handle);
}
void Scumm::fileSeek(void *file, long offs, int whence)
{
switch (_fileMode) {
case 1:
case 2:
if (fseek((FILE *) file, offs, whence) != 0)
clearerr((FILE *) file);
return;
case 3:
_whereInResToRead = offs;
return;
}
}
void Scumm::fileRead(void *file, void *ptr, uint32 size)
{
byte *ptr2 = (byte *)ptr, *src;
switch (_fileMode) {
case 1:
if (size == 0)
return;
if ((uint32)fread(ptr2, size, 1, (FILE *) file) != 1) {
clearerr((FILE *) file);
_fileReadFailed = true;
}
do {
*ptr2++ ^= _encbyte;
} while (--size);
return;
case 3:
if (size == 0)
return;
src = getResourceAddress(rtTemp, 3) + _whereInResToRead;
_whereInResToRead += size;
do {
*ptr2++ = *src++ ^ _encbyte;
} while (--size);
return;
}
}
int Scumm::fileReadByte()
{
byte b;
byte *src;
switch (_fileMode) {
case 1:
if (fread(&b, 1, 1, (FILE *) _fileHandle) != 1) {
clearerr((FILE *) _fileHandle);
_fileReadFailed = true;
}
return b ^ _encbyte;
case 3:
src = getResourceAddress(rtTemp, 3) + _whereInResToRead;
_whereInResToRead++;
return *src ^ _encbyte;
}
return 0;
}
uint Scumm::fileReadWordLE()
{
uint a = fileReadByte();
uint b = fileReadByte();
return a | (b << 8);
}
uint32 Scumm::fileReadDwordLE()
{
uint a = fileReadWordLE();
uint b = fileReadWordLE();
return (b << 16) | a;
}
uint Scumm::fileReadWordBE()
{
uint b = fileReadByte();
uint a = fileReadByte();
return a | (b << 8);
}
uint32 Scumm::fileReadDwordBE()
{
uint b = fileReadWordBE();
uint a = fileReadWordBE();
return (b << 16) | a;
}
/* Overloaded versions */
int Scumm::fileReadByte(void *handle)
{
byte b;
if (fread(&b, 1, 1, (FILE *) handle) != 1) {
clearerr((FILE *) handle);
_fileReadFailed = true;
}
return b ^ _encbyte;
}
uint Scumm::fileReadWordLE(void *handle)
{
uint a = fileReadByte(handle);
uint b = fileReadByte(handle);
return a | (b << 8);
}
uint32 Scumm::fileReadDwordLE(void *handle)
{
uint a = fileReadWordLE(handle);
uint b = fileReadWordLE(handle);
return (b << 16) | a;
}
uint Scumm::fileReadWordBE(void *handle)
{
uint b = fileReadByte(handle);
uint a = fileReadByte(handle);
return a | (b << 8);
}
uint32 Scumm::fileReadDwordBE(void *handle)
{
uint b = fileReadWordBE(handle);
uint a = fileReadWordBE(handle);
return (b << 16) | a;
}
char *Scumm::Strdup(const char *s)
{
if (s) {
int l = strlen(s) + 1;
char * r = (char *) malloc(l);
memcpy(r, s, l);
return r;
}
return NULL;
}
bool Scumm::checkFixedDisk()
{
return true;
}
#ifdef NEED_STRDUP
char *strdup(const char *s)
{
int len = strlen(s) + 1;
char *d = (char *)malloc(len);
if (d)
memcpy(d, s, len);
return d;
}
#endif /* NEED_STRDUP */
void *operator new(size_t size)
{
return calloc(size, 1);
}
void operator delete(void *ptr)
{
free(ptr);
}