dethrace/src/DETHRACE/pc-dos/dossys.c

937 lines
21 KiB
C

#include "dossys.h"
#include "brender.h"
#include "common/car.h"
#include "common/errors.h"
#include "common/globvars.h"
#include "common/grafdata.h"
#include "common/graphics.h"
#include "common/loadsave.h"
#include "common/main.h"
#include "common/sound.h"
#include "common/utility.h"
#include "harness.h"
#include "watcom_functions.h"
#include <dirent.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>
#include <time.h>
#include <unistd.h>
int gASCII_table[128];
tU32 gKeyboard_bits[8];
int gASCII_shift_table[128];
tGraf_spec gGraf_specs[2] = {
{ 8, 1, 0, 320, 200, 0, 0, "32X20X8", "MCGA,W:320,H:200,B:8", 0, 0, 0, NULL },
{ 8, 1, 0, 640, 480, 0, 0, "64X48X8", "VESA,W:640,H:480,B:8", 0, 0, 0, NULL }
};
char gNetwork_profile_fname[256];
tS32 gJoystick_min1y;
tS32 gJoystick_min2y;
tS32 gJoystick_min2x;
tS32 gRaw_joystick2y;
tS32 gRaw_joystick2x;
tS32 gRaw_joystick1y;
tS32 gRaw_joystick1x;
tS32 gJoystick_range2y;
tS32 gJoystick_range2x;
tS32 gJoystick_range1y;
tS32 gJoystick_range1x;
int gNo_voodoo;
int gSwitched_resolution;
int gReplay_override;
br_pixelmap* gReal_back_screen;
tS32 gJoystick_min1x;
br_pixelmap* gTemp_screen;
int gDOSGfx_initialized;
tU32 gUpper_loop_limit;
int gExtra_mem;
int gReal_back_screen_locked;
void (*gPrev_keyboard_handler)();
tU8 gScan_code[123][2];
const double NANOSECONDS_TO_MILLISECONDS = 1.0 / 1000000.0;
int _unittest_do_not_exit = 0;
char* _unittest_last_fatal_error;
// Offset: 0
// Size: 291
void KeyboardHandler() {
tU8 scan_code;
tU8 up;
static tU8 extended;
NOT_IMPLEMENTED();
}
// Offset: 292
// Size: 71
// EAX: pScan_code
int KeyDown(tU8 pScan_code) {
return Harness_Hook_KeyDown(pScan_code);
}
// Offset: 364
// Size: 71
// EAX: pKey_index
// EDX: pScan_code_1
// EBX: pScan_code_2
void KeyTranslation(tU8 pKey_index, tU8 pScan_code_1, tU8 pScan_code_2) {
NOT_IMPLEMENTED();
}
// Offset: 436
// Size: 1897
void KeyBegin() {
Harness_Hook_KeyBegin();
// int v0; // edx@0
// int v1; // ST00_4@1
// __int16 v2; // dx@1
// *(_WORD *)gScan_code[11] = 11;
// *(_WORD *)gScan_code[13] = 3;
// *(_WORD *)gScan_code[14] = 4;
// *(_WORD *)gScan_code[12] = 2;
// *(_WORD *)gScan_code[15] = 5;
// *(_WORD *)gScan_code[17] = 7;
// *(_WORD *)gScan_code[18] = 8;
// *(_WORD *)gScan_code[16] = 6;
// *(_WORD *)gScan_code[19] = 9;
// *(_WORD *)gScan_code[21] = 30;
// *(_WORD *)gScan_code[22] = 48;
// *(_WORD *)gScan_code[20] = 10;
// *(_WORD *)gScan_code[23] = 46;
// *(_WORD *)gScan_code[25] = 18;
// *(_WORD *)gScan_code[26] = 33;
// *(_WORD *)gScan_code[24] = 32;
// *(_WORD *)gScan_code[27] = 34;
// *(_WORD *)gScan_code[29] = 23;
// *(_WORD *)gScan_code[30] = 36;
// *(_WORD *)gScan_code[28] = 35;
// *(_WORD *)gScan_code[31] = 37;
// *(_WORD *)gScan_code[33] = 50;
// *(_WORD *)gScan_code[34] = 49;
// *(_WORD *)gScan_code[32] = 38;
// *(_WORD *)gScan_code[35] = 24;
// *(_WORD *)gScan_code[37] = 16;
// *(_WORD *)gScan_code[38] = 19;
// *(_WORD *)gScan_code[36] = 25;
// *(_WORD *)gScan_code[39] = 31;
// *(_WORD *)gScan_code[41] = 22;
// *(_WORD *)gScan_code[42] = 47;
// *(_WORD *)gScan_code[40] = 20;
// *(_WORD *)gScan_code[43] = 17;
// *(_WORD *)gScan_code[44] = 45;
// *(_WORD *)gScan_code[45] = 21;
// *(_WORD *)gScan_code[46] = 44;
// *(_WORD *)gScan_code[47] = 41;
// *(_WORD *)gScan_code[48] = 12;
// *(_WORD *)gScan_code[49] = 13;
// *(_WORD *)gScan_code[50] = 14;
// *(_WORD *)gScan_code[51] = 28;
// *(_WORD *)gScan_code[52] = 156;
// *(_WORD *)gScan_code[0] = 13866;
// *(_WORD *)gScan_code[1] = -18376;
// *(_WORD *)gScan_code[2] = -25315;
// *(_WORD *)gScan_code[3] = -25315;
// *(_WORD *)gScan_code[4] = 58;
// *(_WORD *)gScan_code[55] = 86;
// *(_WORD *)gScan_code[54] = 53;
// *(_WORD *)gScan_code[56] = 39;
// *(_WORD *)gScan_code[59] = 51;
// *(_WORD *)gScan_code[53] = 15;
// *(_WORD *)gScan_code[58] = 52;
// *(_WORD *)gScan_code[60] = 26;
// *(_WORD *)gScan_code[63] = 1;
// *(_WORD *)gScan_code[57] = 40;
// *(_WORD *)gScan_code[62] = 43;
// *(_WORD *)gScan_code[64] = 210;
// *(_WORD *)gScan_code[67] = 207;
// *(_WORD *)gScan_code[61] = 27;
// *(_WORD *)gScan_code[66] = 199;
// *(_WORD *)gScan_code[68] = 201;
// *(_WORD *)gScan_code[71] = 205;
// *(_WORD *)gScan_code[65] = 211;
// *(_WORD *)gScan_code[70] = 203;
// *(_WORD *)gScan_code[72] = 200;
// *(_WORD *)gScan_code[69] = 209;
// *(_WORD *)gScan_code[74] = 69;
// *(_WORD *)gScan_code[73] = 208;
// *(_WORD *)gScan_code[75] = 181;
// *(_WORD *)gScan_code[76] = 55;
// *(_WORD *)gScan_code[78] = 78;
// *(_WORD *)gScan_code[77] = 74;
// *(_WORD *)gScan_code[80] = 0;
// *(_WORD *)gScan_code[79] = 83;
// *(_WORD *)gScan_code[82] = 79;
// *(_WORD *)gScan_code[84] = 81;
// *(_WORD *)gScan_code[81] = 82;
// *(_WORD *)gScan_code[83] = 80;
// *(_WORD *)gScan_code[86] = 76;
// *(_WORD *)gScan_code[88] = 71;
// *(_WORD *)gScan_code[85] = 75;
// *(_WORD *)gScan_code[87] = 77;
// *(_WORD *)gScan_code[90] = 73;
// *(_WORD *)gScan_code[92] = 60;
// *(_WORD *)gScan_code[89] = 72;
// *(_WORD *)gScan_code[91] = 59;
// *(_WORD *)gScan_code[94] = 62;
// *(_WORD *)gScan_code[96] = 64;
// *(_WORD *)gScan_code[93] = 61;
// *(_WORD *)gScan_code[95] = 63;
// *(_WORD *)gScan_code[98] = 66;
// *(_WORD *)gScan_code[100] = 68;
// *(_WORD *)gScan_code[97] = 65;
// *(_WORD *)gScan_code[99] = 67;
// *(_WORD *)gScan_code[102] = 88;
// *(_WORD *)gScan_code[104] = 70;
// *(_WORD *)gScan_code[101] = 87;
// *(_WORD *)gScan_code[103] = 0;
// *(_WORD *)gScan_code[105] = 0;
// *(_WORD *)gScan_code[106] = 57;
// *(_WORD *)gScan_code[5] = 54;
// *(_WORD *)gScan_code[6] = 184;
// *(_WORD *)gScan_code[7] = 157;
// *(_WORD *)gScan_code[8] = 42;
// *(_WORD *)gScan_code[9] = 56;
// *(_WORD *)gScan_code[10] = 29;
//gPrev_keyboard_handler = (void (__fastcall *)())dos_getvect(9);
//unk_142E6C = v2;
//dos_setvect(9, KeyboardHandler);
}
// Offset: 2336
// Size: 52
void KeyEnd() {
NOT_IMPLEMENTED();
}
// Offset: 2388
// Size: 79
// EAX: pKey_index
int KeyDown22(int pKey_index) {
NOT_IMPLEMENTED();
}
// Offset: 2468
// Size: 141
// EAX: pKeys
// EDX: pMark
void PDSetKeyArray(int* pKeys, int pMark) {
int i;
tS32 joyX;
tS32 joyY;
LOG_TRACE10("(%p, %d)", pKeys, pMark);
gKeys_pressed = 0;
for (i = 0; i < 123; i++) {
if (KeyDown(gScan_code[i][0]) || KeyDown(gScan_code[i][1])) {
gKeys_pressed = (gKeys_pressed << 8) + i + 1;
pKeys[i] = pMark;
} else if (pKeys[i] == pMark) {
pKeys[i] = 0;
}
}
}
// Offset: 2612
// Size: 73
// EAX: pKey
int PDGetASCIIFromKey(int pKey) {
NOT_IMPLEMENTED();
}
// Offset: 2688
// Size: 174
// EAX: pThe_str
void PDFatalError(char* pThe_str) {
static int been_here = 0;
LOG_TRACE("(\"%s\")", pThe_str);
if (been_here) {
if (!_unittest_do_not_exit) {
exit(1);
}
}
been_here = 1;
_unittest_last_fatal_error = pThe_str;
fprintf(stderr, "FATAL ERROR: %s\n", pThe_str);
// wait for keypress
DoSaveGame(1);
if (!_unittest_do_not_exit) {
exit(1);
}
}
// Offset: 2864
// Size: 55
// EAX: pThe_str
void PDNonFatalError(char* pThe_str) {
NOT_IMPLEMENTED();
}
// Offset: 2920
// Size: 190
void PDInitialiseSystem() {
tPath_name the_path;
FILE* f;
int len;
KeyBegin();
//v4 = DOSMouseBegin();
gJoystick_deadzone = 8000;
//gUpper_loop_limit = sub_A1940(v4, v5, v3, v6) / 2;
PathCat(the_path, gApplication_path, "KEYBOARD.COK");
f = fopen(the_path, "rb");
if (!f) {
PDFatalError("This .exe must have KEYBOARD.COK in the DATA folder.");
}
fseek(f, 0, SEEK_END);
len = ftell(f);
rewind(f);
fread(gASCII_table, len / 2, 1, f);
fread(gASCII_shift_table, len / 2, 1, f);
fclose(f);
}
// Offset: 3112
// Size: 48
void PDShutdownSystem() {
NOT_IMPLEMENTED();
}
// Offset: 3160
// Size: 24
void PDSaveOriginalPalette() {
NOT_IMPLEMENTED();
}
// Offset: 3184
// Size: 24
void PDRevertPalette() {
NOT_IMPLEMENTED();
}
// Offset: 3208
// Size: 90
// EAX: pArgc
// EDX: pArgv
int PDInitScreenVars(int pArgc, char** pArgv) {
gGraf_specs[gGraf_spec_index].phys_width = gGraf_specs[gGraf_spec_index].total_width;
gGraf_specs[gGraf_spec_index].phys_height = gGraf_specs[gGraf_spec_index].total_height;
return 1;
}
// Offset: 3300
// Size: 24
void PDInitScreen() {
}
// Offset: 3324
// Size: 113
void PDLockRealBackScreen() {
NOT_IMPLEMENTED();
}
// Offset: 3440
// Size: 48
void PDUnlockRealBackScreen() {
NOT_IMPLEMENTED();
}
// Offset: 3488
// Size: 431
void PDAllocateScreenAndBack() {
gScreen = DOSGfxBegin(gGraf_specs[gGraf_spec_index].gfx_init_string);
gScreen->origin_x = 0;
gDOSGfx_initialized = 1;
gScreen->origin_y = 0;
gBack_screen = BrPixelmapMatch(gScreen, BR_PMMATCH_OFFSCREEN);
gBack_screen->origin_x = 0;
gBack_screen->origin_y = 0;
gTemp_screen = BrPixelmapMatch(gScreen, BR_PMMATCH_OFFSCREEN);
gTemp_screen->origin_x = 0;
gTemp_screen->origin_y = 0;
}
// Offset: 3920
// Size: 209
// EAX: pDst
// EDX: pSrc
// EBX: pPalette
void Copy8BitTo16BitPixelmap(br_pixelmap* pDst, br_pixelmap* pSrc, br_pixelmap* pPalette) {
int x;
int y;
tU8* src;
tU8 value;
tU8 red;
tU8 green;
tU8 blue;
tU16* dst;
tU16* palette_entry;
NOT_IMPLEMENTED();
}
// Offset: 4132
// Size: 307
// EAX: pDst
// EDX: pSrc
// EBX: pPalette
// ECX: pOff
void Double8BitTo16BitPixelmap(br_pixelmap* pDst, br_pixelmap* pSrc, br_pixelmap* pPalette, tU16 pOff, tU16 pSrc_width, tU16 pSrc_height) {
int x;
int y;
tU8* src;
tU8 value;
tU8 red;
tU8 green;
tU8 blue;
tU16* dst0;
tU16* dst1;
tU16 sixteen;
tU16* palette_entry;
NOT_IMPLEMENTED();
}
// Offset: 4440
// Size: 35
br_pixelmap* PDInterfacePixelmap() {
NOT_IMPLEMENTED();
}
// Offset: 4476
// Size: 154
void SwapBackScreen() {
NOT_IMPLEMENTED();
}
// Offset: 4632
// Size: 253
// EAX: pRendering_area_only
// EDX: pClear_top_and_bottom
void ReallyCopyBackScreen(int pRendering_area_only, int pClear_top_and_bottom) {
NOT_IMPLEMENTED();
}
// Offset: 4888
// Size: 40
// EAX: pRendering_area_only
void CopyBackScreen(int pRendering_area_only) {
NOT_IMPLEMENTED();
}
// Offset: 4928
// Size: 92
// EAX: pRendering_area_only
void PDScreenBufferSwap(int pRendering_area_only) {
LOG_TRACE10("(%d)", pRendering_area_only);
if (pRendering_area_only) {
BrPixelmapRectangleCopy(gScreen, gY_offset, gX_offset, gRender_screen, 0, 0, gWidth, gHeight);
} else {
if (gReal_graf_data_index == gGraf_data_index) {
BrPixelmapDoubleBuffer(gScreen, gBack_screen);
} else {
DRPixelmapDoubledCopy(gTemp_screen, gBack_screen, 320, 200, 0, 40);
BrPixelmapDoubleBuffer(gScreen, gTemp_screen);
}
}
}
// Offset: 5020
// Size: 82
// EAX: dst
// EDX: dx
// EBX: dy
// ECX: src
void PDPixelmapToScreenRectangleCopy(br_pixelmap* dst, br_int_16 dx, br_int_16 dy, br_pixelmap* src, br_int_16 sx, br_int_16 sy, br_uint_16 w, br_uint_16 h) {
NOT_IMPLEMENTED();
}
// Offset: 5104
// Size: 68
// EAX: dst
// EDX: x1
// EBX: y1
// ECX: x2
void PDPixelmapHLineOnScreen(br_pixelmap* dst, br_int_16 x1, br_int_16 y1, br_int_16 x2, br_int_16 y2, br_uint_32 colour) {
NOT_IMPLEMENTED();
}
// Offset: 5172
// Size: 68
// EAX: dst
// EDX: x1
// EBX: y1
// ECX: x2
void PDPixelmapVLineOnScreen(br_pixelmap* dst, br_int_16 x1, br_int_16 y1, br_int_16 x2, br_int_16 y2, br_uint_32 colour) {
NOT_IMPLEMENTED();
}
// Offset: 5240
// Size: 24
void PDInstallErrorHandlers() {
NOT_IMPLEMENTED();
}
// Offset: 5264
// Size: 39
void PDSetFileVariables() {
gDir_separator[0] = '\\';
// Added >>
gDir_separator[0] = '/';
gDir_separator[1] = '\0';
// <<
}
// Offset: 5304
// Size: 98
// EAX: pThe_path
void PDBuildAppPath(char* pThe_path) {
int pos;
getcwd(pThe_path, 256);
strcat(pThe_path, "/"); // original: pThe_path[pos] = '\\';
strcpy(gNetwork_profile_fname, pThe_path);
strcat(gNetwork_profile_fname, "NETWORK.INI");
}
// Offset: 5404
// Size: 133
// EAX: pThe_path
// EDX: pAction_routine
void PDForEveryFile(char* pThe_path, void (*pAction_routine)(char*)) {
char find_path[256];
char found_path[256];
//find_t the_find_buffer;
DIR* d;
struct dirent* entry;
d = opendir(pThe_path);
if (d) {
while ((entry = readdir(d)) != NULL) {
// only files, and only files that dont start with '.'
if (entry->d_type == DT_REG && entry->d_name[0] != '.') {
PathCat(found_path, pThe_path, entry->d_name);
pAction_routine(found_path);
}
}
closedir(d);
}
}
// Offset: 5540
// Size: 39
// EAX: pThe_palette
void PDSetPalette(br_pixelmap* pThe_palette) {
BrDevPaletteSetOld(pThe_palette);
}
// Offset: 5580
// Size: 136
// EAX: pPalette
// EDX: pFirst_colour
// EBX: pCount
void PDSetPaletteEntries(br_pixelmap* pPalette, int pFirst_colour, int pCount) {
int i;
tU8* p;
p = pPalette->pixels + 4 * pFirst_colour;
for (i = pFirst_colour; i < pFirst_colour + pCount; i++) {
BrDevPaletteSetEntryOld(i, (p[2] << 16) | (p[1] << 8) | *p);
p += 4;
}
}
// Offset: 5716
// Size: 44
void PDSwitchToRealResolution() {
NOT_IMPLEMENTED();
}
// Offset: 5760
// Size: 44
void PDSwitchToLoresMode() {
NOT_IMPLEMENTED();
}
// Offset: 5804
// Size: 86
// EAX: pButton_1
// EDX: pButton_2
void PDMouseButtons(int* pButton_1, int* pButton_2) {
br_uint_32 mouse_buttons;
br_int_32 mouse_x;
br_int_32 mouse_y;
NOT_IMPLEMENTED();
}
// Offset: 5892
// Size: 380
// EAX: pX_coord
// EDX: pY_coord
void PDGetMousePosition(int* pX_coord, int* pY_coord) {
br_uint_32 mouse_buttons;
br_int_32 mouse_x2;
br_int_32 mouse_y2;
int delta_x;
int delta_y;
static br_int_32 mouse_x;
static br_int_32 mouse_y;
NOT_IMPLEMENTED();
}
// Offset: 6272
// Size: 38
int PDGetTotalTime() {
struct timespec spec;
clock_gettime(CLOCK_MONOTONIC, &spec);
return spec.tv_sec * 1000 + spec.tv_nsec / 1000000;
}
// Offset: 6312
// Size: 37
// EAX: pTime_since_last_call
int PDServiceSystem(tU32 pTime_since_last_call) {
return 0;
}
// Offset: 6352
// Size: 121
tU32 LargestBlockAvail() {
SREGS sregs;
tMem_info mem_info;
size_t memmax;
// Added >>
return 15000000;
// <<
}
// Offset: 6476
// Size: 111
// EAX: pMaximum_required
// EDX: pAmount_allocated
void* PDGrabLargestMammaryWeCanPlayWith(tU32 pMaximum_required, tU32* pAmount_allocated) {
void* result;
NOT_IMPLEMENTED();
}
// Offset: 6588
// Size: 200
// EAX: pBuffer
// EDX: pBuffer_size
void PDAllocateActionReplayBuffer(char** pBuffer, tU32* pBuffer_size) {
tU32 lba;
tU32 required;
NOT_IMPLEMENTED();
}
// Offset: 6788
// Size: 35
// EAX: pBuffer
void PDDisposeActionReplayBuffer(char* pBuffer) {
NOT_IMPLEMENTED();
}
// Offset: 6824
// Size: 146
// EAX: pProgpath
void Usage(char* pProgpath) {
char basename[9];
splitpath(pProgpath, NULL, NULL, basename, NULL);
fprintf(stderr,
"Usage: %s [%s] [%s YonFactor] [%s CarSimplificationLevel] [%s SoundDetailLevel] [%s] [%s] [%s] [%s] [%s] [%s]\nWhere YonFactor is between 0 and 1,\nCarSimplificationLevel is a whole number between 0 and %d,\nand SoundDetailLevel is a whole number.\n",
basename,
"-hires",
"-yon",
"-simple",
"-sound",
"-robots",
"-lomem",
"-nosound",
"-spamfritter",
"-nocutscenes",
"-noreplay",
CAR_MAX_SIMPLIFICATION_LEVEL);
exit(1);
}
// Offset: 6972
// Size: 722
// EAX: pArgc
// EDX: pArgv
// Renamed from "main" to "original_main" to allow for harness + unit testing
int original_main(int pArgc, char** pArgv) {
int arg;
int i;
float f;
for (i = 1; i < pArgc; i++) {
if (strcasecmp(pArgv[i], "-hires") == 0) {
gGraf_spec_index = 1;
} else if (strcasecmp(pArgv[i], "-yon") == 0 && i < pArgc - 1) {
i++;
sscanf(pArgv[i], "%f", &f);
if (f >= 0.0 && f <= 1065353216) {
gYon_multiplier = f;
}
} else if (strcasecmp(pArgv[i], "-simple") == 0 && i < pArgc - 1) {
i++;
sscanf(pArgv[i], "%d", &arg);
if (arg >= 0 && arg < 5) {
gCar_simplification_level = arg;
}
} else if (strcasecmp(pArgv[i], "-sound") == 0 && i < pArgc - 1) {
i++;
sscanf(pArgv[i], "%d", &arg);
gSound_detail_level = arg;
} else if (strcasecmp(pArgv[i], "-robots") == 0) {
gSausage_override = 1;
} else if (strcasecmp(pArgv[i], "-lomem") == 0) {
gAustere_override = 1;
} else if (strcasecmp(pArgv[i], "-nosound") == 0) {
gSound_override = 1;
} else if (strcasecmp(pArgv[i], "-spamfritter") == 0) {
gExtra_mem = 2000000;
} else if (strcasecmp(pArgv[i], "-nocutscenes") == 0) {
gCut_scene_override = 1;
} else if (strcasecmp(pArgv[i], "-noreplay") == 0) {
gReplay_override = 1;
} else {
Usage(pArgv[0]);
}
}
GameMain(pArgc, pArgv);
return 0;
}
// Offset: 7696
// Size: 62
int OurGetChar() {
NOT_IMPLEMENTED();
}
// Offset: 7760
// Size: 34
int PDGetGorePassword() {
int len;
int chances;
char password[17];
NOT_IMPLEMENTED();
}
// Offset: 7796
// Size: 73
// EAX: pGory
void PDDisplayGoreworthiness(int pGory) {
tU32 delay_start;
NOT_IMPLEMENTED();
}
// Offset: 7872
// Size: 35
// EAX: pStr
void PDEnterDebugger(char* pStr) {
static unsigned char* save_it;
NOT_IMPLEMENTED();
}
// Offset: 7908
// Size: 24
void PDEndItAllAndReRunTheBastard() {
NOT_IMPLEMENTED();
}
// Offset: 7932
// Size: 57
// EAX: err
int matherr(struct exception_* err) {
NOT_IMPLEMENTED();
}
// Offset: 7992
// Size: 127
// EAX: limit
int LoopLimitTooLow(tU32 limit) {
clock_t start;
tU32 count;
tU32 val;
NOT_IMPLEMENTED();
}
// Offset: 8120
// Size: 131
tS32 UpperLoopLimit() {
NOT_IMPLEMENTED();
}
// Offset: 8252
// Size: 65
int InitJoysticks() {
NOT_IMPLEMENTED();
}
// Offset: 8320
// Size: 182
// EAX: pBit
tU32 ReadJoystickAxis(int pBit) {
tU32 val;
tU32 count;
NOT_IMPLEMENTED();
}
// Offset: 8504
// Size: 406
void PDReadJoySticks() {
tU32 temp1y;
tU32 temp2x;
tU32 temp2y;
NOT_IMPLEMENTED();
}
// Offset: 8912
// Size: 123
tS32 PDGetJoy1X() {
NOT_IMPLEMENTED();
}
// Offset: 9036
// Size: 123
tS32 PDGetJoy1Y() {
NOT_IMPLEMENTED();
}
// Offset: 9160
// Size: 123
tS32 PDGetJoy2X() {
NOT_IMPLEMENTED();
}
// Offset: 9284
// Size: 123
tS32 PDGetJoy2Y() {
NOT_IMPLEMENTED();
}
// Offset: 9408
// Size: 66
int PDGetJoy1Button1() {
NOT_IMPLEMENTED();
}
// Offset: 9476
// Size: 66
int PDGetJoy1Button2() {
NOT_IMPLEMENTED();
}
// Offset: 9544
// Size: 34
int PDGetJoy1Button3() {
NOT_IMPLEMENTED();
}
// Offset: 9580
// Size: 34
int PDGetJoy1Button4() {
NOT_IMPLEMENTED();
}
// Offset: 9616
// Size: 66
int PDGetJoy2Button1() {
NOT_IMPLEMENTED();
}
// Offset: 9684
// Size: 66
int PDGetJoy2Button2() {
NOT_IMPLEMENTED();
}
// Offset: 9752
// Size: 34
int PDGetJoy2Button3() {
NOT_IMPLEMENTED();
}
// Offset: 9788
// Size: 34
int PDGetJoy2Button4() {
NOT_IMPLEMENTED();
}
// Offset: 9824
// Size: 51
// EAX: pThe_path
int PDFileUnlock(char* pThe_path) {
unsigned int attr;
NOT_IMPLEMENTED();
}
// Offset: 9876
// Size: 33
void CriticalISR(INTPACK pRegs) {
NOT_IMPLEMENTED();
}
// Offset: 9912
// Size: 269
// EAX: pThe_path
// EDX: pFile_name
// EBX: pMin_size
int PDCheckDriveExists2(char* pThe_path, char* pFile_name, tU32 pMin_size) {
struct stat buf;
void (*old_critical_isr)();
int stat_failed;
char slasher[4];
char the_path[256];
LOG_TRACE9("(\"%s\", \"%s\", %d)", pThe_path, pFile_name, pMin_size);
strcpy(slasher, "?:\\");
if (pFile_name) {
PathCat(the_path, pThe_path, pFile_name);
} else {
strcpy(the_path, pThe_path);
}
// JeffH: force unix dir separator >>
char* rep = the_path;
while ((rep = strchr(rep, '\\')) != NULL) {
*rep++ = '/';
}
// <<
stat_failed = stat(the_path, &buf);
return !stat_failed && buf.st_size >= pMin_size;
}
// Offset: 10184
// Size: 108
int PDDoWeLeadAnAustereExistance() {
tU32 block;
block = LargestBlockAvail();
dr_dprintf("PDDoWeLeadAnAustereExistance (sic): LargestBlockAvail=%d\n", block);
if (gReal_graf_data_index == 0) {
return block < 13000000;
}
return block < 15000000;
}