mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-19 08:25:35 +00:00
7fc6477ce2
Function now casts bytes (as <1024) to unsigned long int to correspond "%lu" format string. For consistency, KB are now printed as floating number. Finally, it looks like double is pretty precise to be used in comparisons, so I made the function a little bit shorter.
199 lines
3.8 KiB
C++
199 lines
3.8 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.
|
|
*
|
|
*/
|
|
|
|
#define FORBIDDEN_SYMBOL_EXCEPTION_ctype_h
|
|
|
|
#include "common/util.h"
|
|
#include "common/debug.h"
|
|
|
|
namespace Common {
|
|
|
|
//
|
|
// Print hexdump of the data passed in
|
|
//
|
|
void hexdump(const byte *data, int len, int bytesPerLine, int startOffset) {
|
|
assert(1 <= bytesPerLine && bytesPerLine <= 32);
|
|
int i;
|
|
byte c;
|
|
int offset = startOffset;
|
|
while (len >= bytesPerLine) {
|
|
debugN("%06x: ", offset);
|
|
for (i = 0; i < bytesPerLine; i++) {
|
|
debugN("%02x ", data[i]);
|
|
if (i % 4 == 3)
|
|
debugN(" ");
|
|
}
|
|
debugN(" |");
|
|
for (i = 0; i < bytesPerLine; i++) {
|
|
c = data[i];
|
|
if (c < 32 || c >= 127)
|
|
c = '.';
|
|
debugN("%c", c);
|
|
}
|
|
debugN("|\n");
|
|
data += bytesPerLine;
|
|
len -= bytesPerLine;
|
|
offset += bytesPerLine;
|
|
}
|
|
|
|
if (len <= 0)
|
|
return;
|
|
|
|
debugN("%06x: ", offset);
|
|
for (i = 0; i < bytesPerLine; i++) {
|
|
if (i < len)
|
|
debugN("%02x ", data[i]);
|
|
else
|
|
debugN(" ");
|
|
if (i % 4 == 3)
|
|
debugN(" ");
|
|
}
|
|
debugN(" |");
|
|
for (i = 0; i < len; i++) {
|
|
c = data[i];
|
|
if (c < 32 || c >= 127)
|
|
c = '.';
|
|
debugN("%c", c);
|
|
}
|
|
for (; i < bytesPerLine; i++)
|
|
debugN(" ");
|
|
debugN("|\n");
|
|
}
|
|
|
|
|
|
#pragma mark -
|
|
|
|
|
|
bool parseBool(const String &val, bool &valAsBool) {
|
|
if (val.equalsIgnoreCase("true") ||
|
|
val.equalsIgnoreCase("yes") ||
|
|
val.equals("1")) {
|
|
valAsBool = true;
|
|
return true;
|
|
}
|
|
if (val.equalsIgnoreCase("false") ||
|
|
val.equalsIgnoreCase("no") ||
|
|
val.equals("0")) {
|
|
valAsBool = false;
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
|
|
#pragma mark -
|
|
|
|
|
|
#define ENSURE_ASCII_CHAR(c) \
|
|
if (c < 0 || c > 127) \
|
|
return false
|
|
|
|
bool isAlnum(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isalnum((byte)c);
|
|
}
|
|
|
|
bool isAlpha(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isalpha((byte)c);
|
|
}
|
|
|
|
bool isDigit(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isdigit((byte)c);
|
|
}
|
|
|
|
bool isXDigit(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isxdigit((byte)c);
|
|
}
|
|
|
|
bool isLower(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return islower((byte)c);
|
|
}
|
|
|
|
bool isSpace(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isspace((byte)c);
|
|
}
|
|
|
|
bool isUpper(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isupper((byte)c);
|
|
}
|
|
|
|
bool isPrint(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isprint((byte)c);
|
|
}
|
|
|
|
bool isPunct(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return ispunct((byte)c);
|
|
}
|
|
|
|
bool isCntrl(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return iscntrl((byte)c);
|
|
}
|
|
|
|
bool isGraph(int c) {
|
|
ENSURE_ASCII_CHAR(c);
|
|
return isgraph((byte)c);
|
|
}
|
|
|
|
|
|
#pragma mark -
|
|
|
|
|
|
Common::String getHumanReadableBytes(uint64 bytes, Common::String &unitsOut) {
|
|
if (bytes < 1024) {
|
|
unitsOut = "B";
|
|
return Common::String::format("%lu", (unsigned long int)bytes);
|
|
}
|
|
|
|
double floating = bytes / 1024.0;
|
|
unitsOut = "KB";
|
|
|
|
if (floating >= 1024) {
|
|
floating /= 1024.0;
|
|
unitsOut = "MB";
|
|
}
|
|
|
|
if (floating >= 1024) {
|
|
floating /= 1024.0;
|
|
unitsOut = "GB";
|
|
}
|
|
|
|
if (floating >= 1024) { // woah
|
|
floating /= 1024.0;
|
|
unitsOut = "TB";
|
|
}
|
|
|
|
// print one digit after floating point
|
|
return Common::String::format("%.1f", floating);
|
|
}
|
|
|
|
} // End of namespace Common
|