mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-06 09:48:39 +00:00
e1030e53a5
This commits a slightly modified patch from my patch tracker item #3104630 "OSYSTEM: Add logging API as proposed by Max on -devel". I was not able to test compilation on Android and SamsungTV, since there is no toolchain for those on buildbot (or I was too blind to find them). svn-id: r54339
93 lines
2.3 KiB
C++
93 lines
2.3 KiB
C++
/* ScummVM - Graphic Adventure Engine
|
|
*
|
|
* ScummVM is the legal property of its developers, whose names
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
* file distributed with this source distribution.
|
|
*
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
* $URL$
|
|
* $Id$
|
|
*
|
|
*/
|
|
|
|
// Disable symbol overrides so that we can use system headers.
|
|
// FIXME: Necessary for the PS2 port, should get rid of this eventually.
|
|
#define FORBIDDEN_SYMBOL_ALLOW_ALL
|
|
|
|
#include "common/system.h"
|
|
|
|
#ifdef __PLAYSTATION2__
|
|
// for those replaced fopen/fread/etc functions
|
|
#include "backends/platform/ps2/fileio.h"
|
|
|
|
#define fputs(str, file) ps2_fputs(str, file)
|
|
#define fflush(a) ps2_fflush(a)
|
|
#endif
|
|
|
|
#ifdef __DS__
|
|
#include "backends/fs/ds/ds-fs.h"
|
|
|
|
#define fputs(str, file) DS::std_fwrite(str, strlen(str), 1, file)
|
|
#define fflush(file) DS::std_fflush(file)
|
|
#endif
|
|
|
|
OSystem *g_system = 0;
|
|
|
|
OSystem::OSystem() {
|
|
}
|
|
|
|
OSystem::~OSystem() {
|
|
}
|
|
|
|
bool OSystem::setGraphicsMode(const char *name) {
|
|
if (!name)
|
|
return false;
|
|
|
|
// Special case for the 'default' filter
|
|
if (!scumm_stricmp(name, "normal") || !scumm_stricmp(name, "default")) {
|
|
return setGraphicsMode(getDefaultGraphicsMode());
|
|
}
|
|
|
|
const GraphicsMode *gm = getSupportedGraphicsModes();
|
|
|
|
while (gm->name) {
|
|
if (!scumm_stricmp(gm->name, name)) {
|
|
return setGraphicsMode(gm->id);
|
|
}
|
|
gm++;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
void OSystem::fatalError() {
|
|
quit();
|
|
exit(1);
|
|
}
|
|
|
|
void OSystem::logMessage(LogMessageType::Type type, const char *message) {
|
|
FILE *output = 0;
|
|
|
|
if (type == LogMessageType::kDebug)
|
|
output = stdout;
|
|
else
|
|
output = stderr;
|
|
|
|
fputs(message, output);
|
|
fflush(output);
|
|
}
|
|
|