scummvm/engines/hugo/util.cpp

211 lines
5.2 KiB
C++
Raw Normal View History

/* 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$
*
*/
/*
* This code is based on original Hugo Trilogy source code
*
* Copyright (c) 1989-1995 David P. Gray
*
*/
#include "common/system.h"
#include "gui/message.h"
#include "hugo/game.h"
#include "hugo/hugo.h"
#include "hugo/util.h"
#include "hugo/sound.h"
namespace Hugo {
int Utils::firstBit(byte data) {
/* Returns index (0 to 7) of first 1 in supplied byte, or 8 if not found */
int i;
if (!data)
return(8);
for (i = 0; i < 8; i++) {
if ((data << i) & 0x80)
break;
}
return(i);
}
int Utils::lastBit(byte data) {
/* Returns index (0 to 7) of last 1 in supplied byte, or 8 if not found */
int i;
if (!data)
return(8);
for (i = 7; i >= 0; i--) {
if ((data << i) & 0x80)
break;
}
return(i);
}
void Utils::reverseByte(byte *data) {
/* Reverse the bit order in supplied byte */
byte maskIn = 0x80;
byte maskOut = 0x01;
byte result = 0;
for (byte i = 0; i < 8; i++, maskIn >>= 1, maskOut <<= 1)
if (*data & maskIn)
result |= maskOut;
*data = result;
}
char *Utils::Box(box_t dismiss, const char *s, ...) {
static char buffer[MAX_STRLEN + 1]; // Format text into this
va_list marker;
if (!s) return(NULL); // NULL strings catered for
if (s[0] == '\0')
return(NULL);
if (strlen(s) > MAX_STRLEN - 100) { // Test length
Warn(false, "String too big:\n%s", s);
return(NULL);
}
va_start(marker, s);
vsprintf(buffer, s, marker); // Format string into buffer
va_end(marker);
if (buffer[0] == '\0')
return(NULL);
switch(dismiss) {
case BOX_ANY:
case BOX_OK: {
GUI::MessageDialog dialog(buffer, "OK");
dialog.runModal();
break;
}
case BOX_YESNO: {
GUI::MessageDialog dialog(buffer, "YES", "NO");
if (dialog.runModal() == GUI::kMessageOK)
return(buffer);
return 0;
break;
}
case BOX_PROMPT:
warning("Box: unhandled BOX_PROMPT");
int boxTime = strlen(buffer) * 30;
GUI::TimedMessageDialog dialog(buffer, MAX(1500, boxTime));
dialog.runModal();
// TODO: Some boxes (i.e. the combination code for the shed), needs to return an input.
}
return buffer;
}
void Utils::Warn(bool technote, const char *format, ...) {
/* Warning handler. Print supplied message and continue */
/* Arguments are same as printf */
/* technote TRUE if we are to refer user to technote file */
char buffer[WARNLEN];
va_list marker;
va_start(marker, format);
vsnprintf(buffer, WARNLEN, format, marker);
va_end(marker);
//// if (technote)
//// strcat (buffer, sTech);
//MessageBeep(MB_ICONEXCLAMATION);
//MessageBox(hwnd, buffer, "HugoWin Warning", MB_OK | MB_ICONEXCLAMATION);
warning("Hugo warning: %s", buffer);
}
void Utils::Error(int error_type, const char *format, ...) {
/* Fatal error handler. Reset environment, print error and exit */
/* Arguments are same as printf */
va_list marker;
char buffer[ERRLEN + 1];
bool fatal = true; // Fatal error, else continue
switch (error_type) {
case FILE_ERR:
strcpy(buffer, HugoEngine::get()._textUtil[kErr1]);
break;
case WRITE_ERR:
strcpy(buffer, HugoEngine::get()._textUtil[kErr2]);
fatal = false; // Allow continuation
break;
case PCCH_ERR:
strcpy(buffer, HugoEngine::get()._textUtil[kErr3]);
break;
case HEAP_ERR:
strcpy(buffer, HugoEngine::get()._textUtil[kErr4]);
break;
case SOUND_ERR:
strcpy(buffer, HugoEngine::get()._textUtil[kErr5]);
break;
default:
strcpy(buffer, HugoEngine::get()._textUtil[kErr6]);
break;
}
if (fatal)
HugoEngine::get().shutdown(); // Restore any devices before exit
va_start(marker, format);
vsnprintf(&buffer[strlen(buffer)], ERRLEN - strlen(buffer), format, marker);
va_end(marker);
//MessageBeep(MB_ICONEXCLAMATION);
//MessageBox(hwnd, buffer, "HugoWin Error", MB_OK | MB_ICONEXCLAMATION);
warning("Hugo Error: %s", buffer);
if (fatal)
exit(1);
}
void Utils::gameOverMsg(void) {
// Print options for user when dead
//MessageBox(hwnd, gameoverstring, "Be more careful next time!", MB_OK | MB_ICONINFORMATION);
warning("STUB: Gameover_msg(): %s", HugoEngine::get()._textUtil[kGameOver]);
}
char *Utils::strlwr(char *buffer) {
char *result = buffer;
while (*buffer != '\0') {
if (isupper(*buffer))
*buffer = tolower(*buffer);
buffer++;
}
return result;
}
} // End of namespace Hugo