- making more things compile.

This commit is contained in:
Christoph Oelckers 2019-11-24 10:03:19 +01:00
parent 6280b0b516
commit 40772d9f0c
50 changed files with 402 additions and 2116 deletions

View file

@ -408,12 +408,19 @@ FStringCVar* const CombatMacros[] = { &combatmacro0, &combatmacro1, &combatmacro
void CONFIG_ReadCombatMacros() void CONFIG_ReadCombatMacros()
{ {
FScanner sc; FScanner sc;
sc.Open("demolition/combatmacros.txt"); try
for (auto s : CombatMacros)
{ {
sc.MustGetToken(TK_StringConst); sc.Open("demolition/combatmacros.txt");
if (strlen(*s) == 0) for (auto s : CombatMacros)
*s = sc.String; {
sc.MustGetToken(TK_StringConst);
if (strlen(*s) == 0)
*s = sc.String;
}
}
catch (const std::runtime_error &)
{
// We do not want this to error out. Just ignore if it fails.
} }
} }

View file

@ -119,7 +119,10 @@ enum
GAMEFLAG_RRRA = 0x00000200, GAMEFLAG_RRRA = 0x00000200,
GAMEFLAG_BLOOD = 0x00000400, GAMEFLAG_BLOOD = 0x00000400,
GAMEFLAG_SW = 0x00000800, GAMEFLAG_SW = 0x00000800,
GAMEFLAG_STANDALONE = 0x00001000, GAMEFLAG_POWERSLAVE = 0x00001000,
GAMEFLAG_EXHUMED = 0x00002000,
GAMEFLAG_PSEXHUMED = 0x00003000, // the two games really are the same, except for the name and the publisher.
GAMEFLAG_STANDALONE = 0x00004000,
GAMEFLAGMASK = 0x00000FFF, // flags allowed from grpinfo GAMEFLAGMASK = 0x00000FFF, // flags allowed from grpinfo
}; };

View file

@ -267,7 +267,7 @@ static void D_AddDirectory (TArray<FString> &wadfiles, const char *dir)
{ {
skindir[stuffstart++] = '/'; skindir[stuffstart++] = '/';
int savedstart = stuffstart; int savedstart = stuffstart;
const char* validexts[] = { "*.grp", "*.zip", "*.pk3", "*.pk4", "*.7z", "*.pk7" }; const char* validexts[] = { "*.grp", "*.zip", "*.pk3", "*.pk4", "*.7z", "*.pk7", "*.dat" };
for (auto ext : validexts) for (auto ext : validexts)
{ {
stuffstart = savedstart; stuffstart = savedstart;

View file

@ -1061,6 +1061,9 @@ const char* G_DefaultDefFile(void)
if (g_gameType & GAMEFLAG_SW) if (g_gameType & GAMEFLAG_SW)
return "sw.def"; return "sw.def";
if (g_gameType & GAMEFLAG_PSEXHUMED)
return "exhumed.def";
if (g_gameType & GAMEFLAG_NAM) if (g_gameType & GAMEFLAG_NAM)
return fileSystem.FindFile("nam.def") ? "nam.def" : "napalm.def"; return fileSystem.FindFile("nam.def") ? "nam.def" : "napalm.def";

View file

@ -40,6 +40,7 @@ enum
void I_Error(const char *fmt, ...) ATTRIBUTE((format(printf,1,2))); void I_Error(const char *fmt, ...) ATTRIBUTE((format(printf,1,2)));
int PrintString (int iprintlevel, const char *outline); int PrintString (int iprintlevel, const char *outline);
int VPrintf(int printlevel, const char* format, va_list parms);
int Printf (int printlevel, const char *format, ...) ATTRIBUTE((format(printf,2,3))); int Printf (int printlevel, const char *format, ...) ATTRIBUTE((format(printf,2,3)));
int Printf (const char *format, ...) ATTRIBUTE((format(printf,1,2))); int Printf (const char *format, ...) ATTRIBUTE((format(printf,1,2)));
int DPrintf (int level, const char *format, ...) ATTRIBUTE((format(printf,2,3))); int DPrintf (int level, const char *format, ...) ATTRIBUTE((format(printf,2,3)));

View file

@ -51,7 +51,6 @@ set( PCH_SOURCES
src/exscript.cpp src/exscript.cpp
src/fish.cpp src/fish.cpp
src/grenade.cpp src/grenade.cpp
src/grpscan.cpp
src/gun.cpp src/gun.cpp
src/init.cpp src/init.cpp
src/input.cpp src/input.cpp

View file

@ -269,7 +269,7 @@ loc_2D755:
default: default:
{ {
DebugOut("unknown msg %x for anim\n", a & 0x7F0000); Printf("unknown msg %x for anim\n", a & 0x7F0000);
return; return;
} }
} }

View file

@ -483,7 +483,7 @@ void FuncAnubis(int a, int nDamage, int nRun)
} }
default: default:
{ {
DebugOut("unknown msg %d for Anubis\n", a & 0x7F0000); Printf("unknown msg %d for Anubis\n", a & 0x7F0000);
return; return;
} }
} }

View file

@ -194,7 +194,7 @@ void FuncBubble(int a, int b, int nRun)
return; return;
default: default:
DebugOut("unknown msg %d for Bubble\n", nMessage); Printf("unknown msg %d for Bubble\n", nMessage);
return; return;
} }
} }
@ -218,7 +218,7 @@ void DoBubbleMachines()
void BuildBubbleMachine(int nSprite) void BuildBubbleMachine(int nSprite)
{ {
if (nMachineCount >= kMaxMachines) { if (nMachineCount >= kMaxMachines) {
bail2dos("too many bubble machines in level %d\n", levelnew); I_Error("too many bubble machines in level %d\n", levelnew);
} }
Machine[nMachineCount]._4 = 75; Machine[nMachineCount]._4 = 75;

View file

@ -845,7 +845,7 @@ void FuncBullet(int a, int b, int nRun)
default: default:
{ {
DebugOut("unknown msg %x for bullet\n", a & 0x7F0000); Printf("unknown msg %x for bullet\n", a & 0x7F0000);
return; return;
} }
} }

View file

@ -15,7 +15,6 @@ along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/ */
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
#if 0
#include "ns.h" #include "ns.h"
#include "compat.h" #include "compat.h"
@ -27,7 +26,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "control.h" #include "control.h"
#include "exhumed.h" #include "exhumed.h"
#include "typedefs.h" #include "typedefs.h"
#include "scriplib.h"
#include "config.h" #include "config.h"
@ -38,167 +36,10 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_PS_NS BEGIN_PS_NS
const char gamefunctions[kMaxGameFunctions][kMaxGameFuncLen] =
{
"Move_Forward",
"Move_Backward",
"Turn_Left",
"Turn_Right",
"Strafe",
"Strafe_Left",
"Strafe_Right",
"Run",
"Jump",
"Crouch",
"Fire",
"Open",
"Look_Up",
"Look_Down",
"Look_Straight",
"Aim_Up",
"Aim_Down",
"SendMessage",
"Weapon_1",
"Weapon_2",
"Weapon_3",
"Weapon_4",
"Weapon_5",
"Weapon_6",
"Weapon_7",
"Mouseview",
"Pause",
"Map",
"Zoom_In",
"Zoom_Out",
"Gamma_Correction",
"Escape",
"Shrink_Screen",
"Enlarge_Screen",
"Inventory",
"Inventory_Left",
"Inventory_Right",
"Mouse_Sensitivity_Up",
"Mouse_Sensitivity_Down",
"Show_Console",
};
const char keydefaults[kMaxGameFunctions * 2][kMaxGameFuncLen] =
{
"W", "Kpad8",
"S", "Kpad2",
"Left", "Kpad4",
"Right", "KPad6",
"LAlt", "RAlt",
"A", "",
"D", "",
"LShift", "RShift",
"Space", "",
"LCtrl", "",
"RCtrl", "",
"E", "",
"PgUp", "",
"PgDn", "",
"Home", "",
"Insert", "",
"Delete", "",
"T", "",
"1", "",
"2", "",
"3", "",
"4", "",
"5", "",
"6", "",
"7", "",
"/", "",
"Pause", "",
"Tab", "",
"=", "",
"-", "",
"F11", "",
"Escape", "",
"Kpad-", "",
"Kpad+", "",
"Enter", "",
"[", "",
"]", "",
"F7", "",
"F8", "",
"`", "",
};
const char oldkeydefaults[kMaxGameFunctions * 2][kMaxGameFuncLen] =
{
"Up", "Kpad8",
"Down", "Kpad2",
"Left", "Kpad4",
"Right", "KPad6",
"LAlt", "RAlt",
",", "",
".", "",
"LShift", "RShift",
"A", "",
"Z", "",
"LCtrl", "RCtrl",
"Space", "",
"PgUp", "",
"PgDn", "",
"Home", "",
"Insert", "",
"Delete", "",
"T", "",
"1", "",
"2", "",
"3", "",
"4", "",
"5", "",
"6", "",
"7", "",
"/", "",
"Pause", "",
"Tab", "",
"=", "",
"-", "",
"F11", "",
"Escape", "",
"Kpad-", "",
"Kpad+", "",
"Enter", "",
"[", "",
"]", "",
"F7", "",
"F8", "",
"`", "",
};
static const char *mousedefaults[MAXMOUSEBUTTONS] =
{
"Fire",
"Strafe",
"Move_Forward"
"",
"",
"",
};
static const char *mouseclickeddefaults[MAXMOUSEBUTTONS] =
{
};
static const char* mouseanalogdefaults[MAXMOUSEAXES] =
{
"analog_strafing",
"analog_moving",
};
static const char* mousedigitaldefaults[MAXMOUSEDIGITAL] =
{
};
ud_setup_t gSetup; ud_setup_t gSetup;
char setupfilename[128] = {kSetupFilename};
int lMouseSens = 32; int lMouseSens = 32;
unsigned int dword_1B82E0 = 0; unsigned int dword_1B82E0 = 0;
@ -221,199 +62,6 @@ int32_t useprecache;
int32_t MouseDeadZone, MouseBias; int32_t MouseDeadZone, MouseBias;
int32_t SmoothInput; int32_t SmoothInput;
// JBF 20031211: Store the input settings because
// (currently) mact can't regurgitate them
int32_t MouseFunctions[MAXMOUSEBUTTONS][2];
int32_t MouseDigitalFunctions[MAXMOUSEAXES][2];
int32_t MouseAnalogueAxes[MAXMOUSEAXES];
int32_t MouseAnalogueScale[MAXMOUSEAXES];
int32_t JoystickFunctions[MAXJOYBUTTONSANDHATS][2];
int32_t JoystickDigitalFunctions[MAXJOYAXES][2];
int32_t JoystickAnalogueAxes[MAXJOYAXES];
int32_t JoystickAnalogueScale[MAXJOYAXES];
int32_t JoystickAnalogueInvert[MAXJOYAXES];
int32_t JoystickAnalogueDead[MAXJOYAXES];
int32_t JoystickAnalogueSaturate[MAXJOYAXES];
uint8_t KeyboardKeys[kMaxGameFunctions][2];
int32_t MAXCACHE1DSIZE = (96*1024*1024);
void SetupGameButtons()
{
CONTROL_DefineFlag(gamefunc_Move_Forward, kFalse);
CONTROL_DefineFlag(gamefunc_Move_Backward, kFalse);
CONTROL_DefineFlag(gamefunc_Turn_Left, kFalse);
CONTROL_DefineFlag(gamefunc_Turn_Right, kFalse);
CONTROL_DefineFlag(gamefunc_Strafe, kFalse);
CONTROL_DefineFlag(gamefunc_Strafe_Left, kFalse);
CONTROL_DefineFlag(gamefunc_Strafe_Right, kFalse);
CONTROL_DefineFlag(gamefunc_Jump, kFalse);
CONTROL_DefineFlag(gamefunc_Crouch, kFalse);
CONTROL_DefineFlag(gamefunc_Fire, kFalse);
CONTROL_DefineFlag(gamefunc_Open, kFalse);
CONTROL_DefineFlag(gamefunc_Aim_Up, kFalse);
CONTROL_DefineFlag(gamefunc_Aim_Down, kFalse);
CONTROL_DefineFlag(gamefunc_Look_Up, kFalse);
CONTROL_DefineFlag(gamefunc_Look_Down, kFalse);
CONTROL_DefineFlag(gamefunc_Look_Straight, kFalse);
CONTROL_DefineFlag(gamefunc_Run, kFalse);
CONTROL_DefineFlag(gamefunc_SendMessage, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_1, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_2, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_3, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_4, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_5, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_6, kFalse);
CONTROL_DefineFlag(gamefunc_Weapon_7, kFalse);
CONTROL_DefineFlag(gamefunc_Map, kFalse);
CONTROL_DefineFlag(gamefunc_Escape, kFalse);
CONTROL_DefineFlag(gamefunc_Shrink_Screen, kFalse);
CONTROL_DefineFlag(gamefunc_Enlarge_Screen, kFalse);
CONTROL_DefineFlag(gamefunc_Zoom_In, kFalse);
CONTROL_DefineFlag(gamefunc_Zoom_Out, kFalse);
CONTROL_DefineFlag(gamefunc_Inventory_Left, kFalse);
CONTROL_DefineFlag(gamefunc_Inventory_Right, kFalse);
CONTROL_DefineFlag(gamefunc_Mouseview, kFalse);
CONTROL_DefineFlag(gamefunc_Inventory, kFalse);
}
hashtable_t h_gamefuncs = { kMaxGameFunctions<<1, NULL };
int32_t CONFIG_FunctionNameToNum(const char *func)
{
if (!func)
return -1;
return hash_findcase(&h_gamefuncs, func);
}
static char const * CONFIG_FunctionNumToName(int32_t func)
{
if ((unsigned)func >= (unsigned)kMaxGameFunctions)
return "";
return gamefunctions[func];
}
int32_t CONFIG_AnalogNameToNum(const char *func)
{
if (!func)
return -1;
else if (!Bstrcasecmp(func, "analog_turning"))
return analog_turning;
else if (!Bstrcasecmp(func, "analog_strafing"))
return analog_strafing;
else if (!Bstrcasecmp(func, "analog_moving"))
return analog_moving;
else if (!Bstrcasecmp(func, "analog_lookingupanddown"))
return analog_lookingupanddown;
else
return -1;
}
static char const * CONFIG_AnalogNumToName(int32_t func)
{
switch (func)
{
case analog_turning:
return "analog_turning";
case analog_strafing:
return "analog_strafing";
case analog_moving:
return "analog_moving";
case analog_lookingupanddown:
return "analog_lookingupanddown";
}
return "";
}
static void CONFIG_SetJoystickButtonFunction(int i, int j, int function)
{
JoystickFunctions[i][j] = function;
CONTROL_MapButton(function, i, j, controldevice_joystick);
}
static void CONFIG_SetJoystickAnalogAxisScale(int i, int scale)
{
JoystickAnalogueScale[i] = scale;
CONTROL_SetAnalogAxisScale(i, scale, controldevice_joystick);
}
static void CONFIG_SetJoystickAnalogAxisInvert(int i, int invert)
{
JoystickAnalogueInvert[i] = invert;
CONTROL_SetAnalogAxisInvert(i, invert, controldevice_joystick);
}
static void CONFIG_SetJoystickAnalogAxisDeadSaturate(int i, int dead, int saturate)
{
JoystickAnalogueDead[i] = dead;
JoystickAnalogueSaturate[i] = saturate;
joySetDeadZone(i, dead, saturate);
}
static void CONFIG_SetJoystickDigitalAxisFunction(int i, int j, int function)
{
JoystickDigitalFunctions[i][j] = function;
CONTROL_MapDigitalAxis(i, function, j, controldevice_joystick);
}
static void CONFIG_SetJoystickAnalogAxisFunction(int i, int function)
{
JoystickAnalogueAxes[i] = function;
CONTROL_MapAnalogAxis(i, function, controldevice_joystick);
}
void CONFIG_SetDefaultKeys(const char (*keyptr)[kMaxGameFuncLen], bool lazy/*=false*/)
{
static char const s_gamefunc_[] = "gamefunc_";
int constexpr strlen_gamefunc_ = ARRAY_SIZE(s_gamefunc_) - 1;
if (!lazy)
{
Bmemset(KeyboardKeys, 0xff, sizeof(KeyboardKeys));
CONTROL_ClearAllBinds();
}
for (int i=0; i < ARRAY_SSIZE(gamefunctions); ++i)
{
if (gamefunctions[i][0] == '\0')
continue;
auto &key = KeyboardKeys[i];
int const default0 = KB_StringToScanCode(keyptr[i<<1]);
int const default1 = KB_StringToScanCode(keyptr[(i<<1)+1]);
// skip the function if the default key is already used
// or the function is assigned to another key
if (lazy && (key[0] != 0xff || (CONTROL_KeyIsBound(default0) && Bstrlen(CONTROL_KeyBinds[default0].cmdstr) > strlen_gamefunc_
&& CONFIG_FunctionNameToNum(CONTROL_KeyBinds[default0].cmdstr + strlen_gamefunc_) >= 0)))
{
#if 0 // defined(DEBUGGINGAIDS)
if (key[0] != 0xff)
initprintf("Skipping %s bound to %s\n", keyptr[i<<1], CONTROL_KeyBinds[default0].cmdstr);
#endif
continue;
}
key[0] = default0;
key[1] = default1;
if (key[0])
CONTROL_FreeKeyBind(key[0]);
if (key[1])
CONTROL_FreeKeyBind(key[1]);
if (i == gamefunc_Show_Console)
OSD_CaptureKey(key[0]);
else
CONFIG_MapKey(i, key[0], 0, key[1], 0);
}
}
void CONFIG_SetDefaults() void CONFIG_SetDefaults()
{ {
scripthandle = -1; scripthandle = -1;
@ -437,12 +85,6 @@ void CONFIG_SetDefaults()
gSetup.ydim = 768; gSetup.ydim = 768;
} }
#ifdef USE_OPENGL
gSetup.bpp = 32;
#else
gSetup.bpp = 8;
#endif
// currently settings.cfg is only read after the startup window launches the game, // currently settings.cfg is only read after the startup window launches the game,
// and rereading binds might be fickle so just enable this // and rereading binds might be fickle so just enable this
gSetup.usejoystick = 1; gSetup.usejoystick = 1;
@ -465,556 +107,18 @@ void CONFIG_SetDefaults()
runkey_mode = 0; runkey_mode = 0;
auto_run = 1; auto_run = 1;
CONFIG_SetDefaultKeys(keydefaults);
memset(MouseFunctions, -1, sizeof(MouseFunctions));
memset(MouseDigitalFunctions, -1, sizeof(MouseDigitalFunctions));
memset(JoystickFunctions, -1, sizeof(JoystickFunctions));
memset(JoystickDigitalFunctions, -1, sizeof(JoystickDigitalFunctions));
CONTROL_MouseSensitivity = DEFAULTMOUSESENSITIVITY;
for (int i=0; i<MAXMOUSEBUTTONS; i++)
{
MouseFunctions[i][0] = CONFIG_FunctionNameToNum(mousedefaults[i]);
CONTROL_MapButton(MouseFunctions[i][0], i, 0, controldevice_mouse);
if (i>=4) continue;
MouseFunctions[i][1] = CONFIG_FunctionNameToNum(mouseclickeddefaults[i]);
CONTROL_MapButton(MouseFunctions[i][1], i, 1, controldevice_mouse);
}
for (int i=0; i<MAXMOUSEAXES; i++)
{
MouseAnalogueScale[i] = DEFAULTMOUSEANALOGUESCALE;
CONTROL_SetAnalogAxisScale(i, MouseAnalogueScale[i], controldevice_mouse);
MouseDigitalFunctions[i][0] = CONFIG_FunctionNameToNum(mousedigitaldefaults[i*2]);
MouseDigitalFunctions[i][1] = CONFIG_FunctionNameToNum(mousedigitaldefaults[i*2+1]);
CONTROL_MapDigitalAxis(i, MouseDigitalFunctions[i][0], 0, controldevice_mouse);
CONTROL_MapDigitalAxis(i, MouseDigitalFunctions[i][1], 1, controldevice_mouse);
MouseAnalogueAxes[i] = CONFIG_AnalogNameToNum(mouseanalogdefaults[i]);
CONTROL_MapAnalogAxis(i, MouseAnalogueAxes[i], controldevice_mouse);
}
// TODO:
//CONFIG_SetGameControllerDefaultsStandard();
#if 0
FXVolume = 128;
MusicVolume = 128;
ReverseStereo = 0;
ControllerType = controltype_keyboardandmouse;
lMouseSens = 8;
#endif
} }
int CONFIG_ReadSetup() int CONFIG_ReadSetup(void)
{ {
char tempbuf[1024]; CONFIG_SetDefaults();
if (ScreenBPP < 8) ScreenBPP = 32;
CONTROL_ClearAssignments(); return 0;
CONFIG_SetDefaults();
setupread = 1;
pathsearchmode = 1;
if (scripthandle < 0)
{
if (buildvfs_exists(setupfilename)) // JBF 20031211
scripthandle = SCRIPT_Load(setupfilename);
else if (buildvfs_exists(kSetupFilename))
{
int const i = wm_ynbox("Import Configuration Settings",
"The configuration file \"%s\" was not found. "
"Import configuration data from \"%s\"?",
setupfilename, kSetupFilename);
if (i)
scripthandle = SCRIPT_Load(kSetupFilename);
}
}
pathsearchmode = 0;
if (scripthandle < 0)
return -1;
SCRIPT_GetNumber(scripthandle, "Setup", "ForceSetup", &gSetup.forcesetup);
SCRIPT_GetNumber(scripthandle, "Setup", "NoAutoLoad", &gSetup.noautoload);
int32_t cachesize;
SCRIPT_GetNumber(scripthandle, "Setup", "CacheSize", &cachesize);
if (cachesize > MAXCACHE1DSIZE)
MAXCACHE1DSIZE = cachesize;
if (g_noSetup == 0 && g_modDir[0] == '/')
{
SCRIPT_GetString(scripthandle, "Setup","ModDir",&g_modDir[0]);
if (!buildvfs_isdir(g_modDir))
{
initprintf("Invalid mod dir in cfg!\n");
Bsprintf(g_modDir,"/");
}
}
windowx = -1;
windowy = -1;
SCRIPT_GetNumber(scripthandle, "Screen Setup", "MaxRefreshFreq", (int32_t *)&maxrefreshfreq);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "ScreenBPP", &gSetup.bpp);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "ScreenHeight", &gSetup.ydim);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "ScreenMode", &gSetup.fullscreen);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "ScreenWidth", &gSetup.xdim);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "WindowPosX", (int32_t *)&windowx);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "WindowPosY", (int32_t *)&windowy);
SCRIPT_GetNumber(scripthandle, "Screen Setup", "WindowPositioning", (int32_t *)&windowpos);
if (gSetup.bpp < 8) gSetup.bpp = 32;
setupread = 1;
return 0;
} }
// wrapper for CONTROL_MapKey(), generates key bindings to reflect changes to keyboard setup
void CONFIG_MapKey(int which, kb_scancode key1, kb_scancode oldkey1, kb_scancode key2, kb_scancode oldkey2)
{
char tempbuf[256];
int const keys[] = { key1, key2, oldkey1, oldkey2 };
char buf[2*kMaxGameFuncLen];
if (which == gamefunc_Show_Console)
OSD_CaptureKey(key1);
for (int k = 0; (unsigned)k < ARRAY_SIZE(keys); k++)
{
if (keys[k] == 0xff || !keys[k])
continue;
int match = 0;
for (; match < ARRAY_SSIZE(sctokeylut); ++match)
{
if (keys[k] == sctokeylut[match].sc)
break;
}
tempbuf[0] = 0;
for (int i=kMaxGameFunctions-1; i>=0; i--)
{
if (KeyboardKeys[i][0] == keys[k] || KeyboardKeys[i][1] == keys[k])
{
Bsprintf(buf, "gamefunc_%s; ", CONFIG_FunctionNumToName(i));
Bstrcat(tempbuf,buf);
}
}
int const len = Bstrlen(tempbuf);
if (len >= 2)
{
tempbuf[len-2] = 0; // cut off the trailing "; "
CONTROL_BindKey(keys[k], tempbuf, 1, sctokeylut[match].key ? sctokeylut[match].key : "<?>");
}
else
{
CONTROL_FreeKeyBind(keys[k]);
}
}
}
void CONFIG_SetupMouse(void)
{
if (scripthandle < 0)
return;
char str[80];
char temp[80];
for (int i=0; i<MAXMOUSEBUTTONS; i++)
{
Bsprintf(str,"MouseButton%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle,"Controls", str,temp))
MouseFunctions[i][0] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"MouseButtonClicked%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle,"Controls", str,temp))
MouseFunctions[i][1] = CONFIG_FunctionNameToNum(temp);
}
// map over the axes
for (int i=0; i<MAXMOUSEAXES; i++)
{
Bsprintf(str,"MouseAnalogAxes%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
MouseAnalogueAxes[i] = CONFIG_AnalogNameToNum(temp);
Bsprintf(str,"MouseDigitalAxes%d_0",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
MouseDigitalFunctions[i][0] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"MouseDigitalAxes%d_1",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
MouseDigitalFunctions[i][1] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"MouseAnalogScale%d",i);
int32_t scale = MouseAnalogueScale[i];
SCRIPT_GetNumber(scripthandle, "Controls", str, &scale);
MouseAnalogueScale[i] = scale;
}
for (int i=0; i<MAXMOUSEBUTTONS; i++)
{
CONTROL_MapButton(MouseFunctions[i][0], i, 0, controldevice_mouse);
CONTROL_MapButton(MouseFunctions[i][1], i, 1, controldevice_mouse);
}
for (int i=0; i<MAXMOUSEAXES; i++)
{
CONTROL_MapAnalogAxis(i, MouseAnalogueAxes[i], controldevice_mouse);
CONTROL_MapDigitalAxis(i, MouseDigitalFunctions[i][0], 0,controldevice_mouse);
CONTROL_MapDigitalAxis(i, MouseDigitalFunctions[i][1], 1,controldevice_mouse);
CONTROL_SetAnalogAxisScale(i, MouseAnalogueScale[i], controldevice_mouse);
}
}
void CONFIG_SetupJoystick(void)
{
int32_t i;
char str[80];
char temp[80];
int32_t scale;
if (scripthandle < 0) return;
for (i=0; i<MAXJOYBUTTONSANDHATS; i++)
{
Bsprintf(str,"ControllerButton%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle,"Controls", str,temp))
JoystickFunctions[i][0] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"ControllerButtonClicked%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle,"Controls", str,temp))
JoystickFunctions[i][1] = CONFIG_FunctionNameToNum(temp);
}
// map over the axes
for (i=0; i<MAXJOYAXES; i++)
{
Bsprintf(str,"ControllerAnalogAxes%d",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
JoystickAnalogueAxes[i] = CONFIG_AnalogNameToNum(temp);
Bsprintf(str,"ControllerDigitalAxes%d_0",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
JoystickDigitalFunctions[i][0] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"ControllerDigitalAxes%d_1",i);
temp[0] = 0;
if (!SCRIPT_GetString(scripthandle, "Controls", str,temp))
JoystickDigitalFunctions[i][1] = CONFIG_FunctionNameToNum(temp);
Bsprintf(str,"ControllerAnalogScale%d",i);
scale = JoystickAnalogueScale[i];
SCRIPT_GetNumber(scripthandle, "Controls", str,&scale);
JoystickAnalogueScale[i] = scale;
Bsprintf(str,"ControllerAnalogInvert%d",i);
scale = JoystickAnalogueInvert[i];
SCRIPT_GetNumber(scripthandle, "Controls", str,&scale);
JoystickAnalogueInvert[i] = scale;
Bsprintf(str,"ControllerAnalogDead%d",i);
scale = JoystickAnalogueDead[i];
SCRIPT_GetNumber(scripthandle, "Controls", str,&scale);
JoystickAnalogueDead[i] = scale;
Bsprintf(str,"ControllerAnalogSaturate%d",i);
scale = JoystickAnalogueSaturate[i];
SCRIPT_GetNumber(scripthandle, "Controls", str,&scale);
JoystickAnalogueSaturate[i] = scale;
}
for (i=0; i<MAXJOYBUTTONSANDHATS; i++)
{
CONTROL_MapButton(JoystickFunctions[i][0], i, 0, controldevice_joystick);
CONTROL_MapButton(JoystickFunctions[i][1], i, 1, controldevice_joystick);
}
for (i=0; i<MAXJOYAXES; i++)
{
CONTROL_MapAnalogAxis(i, JoystickAnalogueAxes[i], controldevice_joystick);
CONTROL_MapDigitalAxis(i, JoystickDigitalFunctions[i][0], 0, controldevice_joystick);
CONTROL_MapDigitalAxis(i, JoystickDigitalFunctions[i][1], 1, controldevice_joystick);
CONTROL_SetAnalogAxisScale(i, JoystickAnalogueScale[i], controldevice_joystick);
CONTROL_SetAnalogAxisInvert(i, JoystickAnalogueInvert[i], controldevice_joystick);
}
}
void SetupInput()
{
if (CONTROL_Startup(controltype_keyboardandmouse, &BGetTime, kTimerTicks))
{
ERRprintf("There was an error initializing the CONTROL system.\n");
engineUnInit();
Bexit(5);
}
SetupGameButtons();
CONFIG_SetupMouse();
CONFIG_SetupJoystick();
CONTROL_JoystickEnabled = (gSetup.usejoystick && CONTROL_JoyPresent);
CONTROL_MouseEnabled = (gSetup.usemouse && CONTROL_MousePresent);
// JBF 20040215: evil and nasty place to do this, but joysticks are evil and nasty too
for (int i=0; i<joystick.numAxes; i++)
joySetDeadZone(i,JoystickAnalogueDead[i],JoystickAnalogueSaturate[i]);
}
void CONFIG_WriteSettings(void) // save binds and aliases to <cfgname>_settings.cfg void CONFIG_WriteSettings(void) // save binds and aliases to <cfgname>_settings.cfg
{ {
char filename[BMAX_PATH];
if (!Bstrcmp(setupfilename, kSetupFilename))
Bsprintf(filename, "settings.cfg");
else
Bsprintf(filename, "%s_settings.cfg", strtok(setupfilename, "."));
buildvfs_FILE fp = buildvfs_fopen_write(filename);
if (fp)
{
buildvfs_fputstr(fp, "// this file is automatically generated by ");
buildvfs_fputstrptr(fp, AppProperName);
buildvfs_fputstr(fp,"\nunbindall\n");
for (int i=0; i<MAXBOUNDKEYS+MAXMOUSEBUTTONS; i++)
{
if (CONTROL_KeyIsBound(i))
{
buildvfs_fputstr(fp, "bind \"");
buildvfs_fputstrptr(fp, CONTROL_KeyBinds[i].key);
if (CONTROL_KeyBinds[i].repeat)
buildvfs_fputstr(fp, "\" \"");
else
buildvfs_fputstr(fp, "\" norepeat \"");
buildvfs_fputstrptr(fp, CONTROL_KeyBinds[i].cmdstr);
buildvfs_fputstr(fp, "\"\n");
}
}
for (int i=0; i<kMaxGameFunctions; ++i)
{
char const * name = CONFIG_FunctionNumToName(i);
if (name && name[0] != '\0' && (KeyboardKeys[i][0] == 0xff || !KeyboardKeys[i][0]))
{
buildvfs_fputstr(fp, "unbound ");
buildvfs_fputstrptr(fp, name);
buildvfs_fputstr(fp, "\n");
}
}
OSD_WriteAliases(fp);
//if (g_crosshairSum != -1 && g_crosshairSum != DefaultCrosshairColors.r+(DefaultCrosshairColors.g<<8)+(DefaultCrosshairColors.b<<16))
//{
// buildvfs_fputstr(fp, "crosshaircolor ");
// char buf[64];
// snprintf(buf, sizeof(buf), "%d %d %d\n", CrosshairColors.r, CrosshairColors.g, CrosshairColors.b);
// buildvfs_fputstrptr(fp, buf);
//}
OSD_WriteCvars(fp);
buildvfs_fclose(fp);
OSD_Printf("Wrote %s\n", filename);
return;
}
OSD_Printf("Error writing %s: %s\n", filename, strerror(errno));
} }
void CONFIG_WriteSetup(uint32_t flags)
{
char buf[256];
if (!setupread) return;
if (scripthandle < 0)
scripthandle = SCRIPT_Init(setupfilename);
SCRIPT_PutNumber(scripthandle, "Setup", "CacheSize", MAXCACHE1DSIZE, FALSE, FALSE);
//SCRIPT_PutNumber(scripthandle, "Setup", "ConfigVersion", BYTEVERSION_EDUKE32, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Setup", "ForceSetup", gSetup.forcesetup, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Setup", "NoAutoLoad", gSetup.noautoload, FALSE, FALSE);
//#ifdef POLYMER
// SCRIPT_PutNumber(ud.config.scripthandle, "Screen Setup", "Polymer", glrendmode == REND_POLYMER, FALSE, FALSE);
//#endif
SCRIPT_PutNumber(scripthandle, "Screen Setup", "ScreenBPP", gSetup.bpp, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "ScreenHeight", gSetup.ydim, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "ScreenMode", gSetup.fullscreen, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "ScreenWidth", gSetup.xdim, FALSE, FALSE);
//if (g_grpNamePtr && !g_addonNum)
// SCRIPT_PutString(ud.config.scripthandle, "Setup", "SelectedGRP", g_grpNamePtr);
#ifdef STARTUP_SETUP_WINDOW
if (g_noSetup == 0)
SCRIPT_PutString(scripthandle, "Setup", "ModDir", &g_modDir[0]);
#endif
// exit early after only updating the values that can be changed from the startup window
if (flags & 1)
{
SCRIPT_Save(scripthandle, setupfilename);
SCRIPT_Free(scripthandle);
return;
}
SCRIPT_PutNumber(scripthandle, "Screen Setup", "MaxRefreshFreq", maxrefreshfreq, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "WindowPosX", windowx, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "WindowPosY", windowy, FALSE, FALSE);
SCRIPT_PutNumber(scripthandle, "Screen Setup", "WindowPositioning", windowpos, FALSE, FALSE);
//if (!NAM_WW2GI)
//{
// SCRIPT_PutNumber(ud.config.scripthandle, "Screen Setup", "Out",ud.lockout,FALSE,FALSE);
// SCRIPT_PutString(ud.config.scripthandle, "Screen Setup", "Password",ud.pwlockout);
//}
//#ifdef _WIN32
// SCRIPT_PutNumber(ud.config.scripthandle, "Updates", "CheckForUpdates", ud.config.CheckForUpdates, FALSE, FALSE);
// SCRIPT_PutNumber(ud.config.scripthandle, "Updates", "LastUpdateCheck", ud.config.LastUpdateCheck, FALSE, FALSE);
//#endif
if (gSetup.usemouse)
{
for (int i=0; i<MAXMOUSEBUTTONS; i++)
{
if (CONFIG_FunctionNumToName(MouseFunctions[i][0]))
{
Bsprintf(buf, "MouseButton%d", i);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(MouseFunctions[i][0]));
}
if (i >= (MAXMOUSEBUTTONS-2)) continue;
if (CONFIG_FunctionNumToName(MouseFunctions[i][1]))
{
Bsprintf(buf, "MouseButtonClicked%d", i);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(MouseFunctions[i][1]));
}
}
for (int i=0; i<MAXMOUSEAXES; i++)
{
if (CONFIG_AnalogNumToName(MouseAnalogueAxes[i]))
{
Bsprintf(buf, "MouseAnalogAxes%d", i);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_AnalogNumToName(MouseAnalogueAxes[i]));
}
if (CONFIG_FunctionNumToName(MouseDigitalFunctions[i][0]))
{
Bsprintf(buf, "MouseDigitalAxes%d_0", i);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(MouseDigitalFunctions[i][0]));
}
if (CONFIG_FunctionNumToName(MouseDigitalFunctions[i][1]))
{
Bsprintf(buf, "MouseDigitalAxes%d_1", i);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(MouseDigitalFunctions[i][1]));
}
Bsprintf(buf, "MouseAnalogScale%d", i);
SCRIPT_PutNumber(scripthandle, "Controls", buf, MouseAnalogueScale[i], FALSE, FALSE);
}
}
if (gSetup.usejoystick)
{
for (int dummy=0; dummy<MAXJOYBUTTONSANDHATS; dummy++)
{
if (CONFIG_FunctionNumToName(JoystickFunctions[dummy][0]))
{
Bsprintf(buf, "ControllerButton%d", dummy);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(JoystickFunctions[dummy][0]));
}
if (CONFIG_FunctionNumToName(JoystickFunctions[dummy][1]))
{
Bsprintf(buf, "ControllerButtonClicked%d", dummy);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(JoystickFunctions[dummy][1]));
}
}
for (int dummy=0; dummy<MAXJOYAXES; dummy++)
{
if (CONFIG_AnalogNumToName(JoystickAnalogueAxes[dummy]))
{
Bsprintf(buf, "ControllerAnalogAxes%d", dummy);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_AnalogNumToName(JoystickAnalogueAxes[dummy]));
}
if (CONFIG_FunctionNumToName(JoystickDigitalFunctions[dummy][0]))
{
Bsprintf(buf, "ControllerDigitalAxes%d_0", dummy);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(JoystickDigitalFunctions[dummy][0]));
}
if (CONFIG_FunctionNumToName(JoystickDigitalFunctions[dummy][1]))
{
Bsprintf(buf, "ControllerDigitalAxes%d_1", dummy);
SCRIPT_PutString(scripthandle, "Controls", buf, CONFIG_FunctionNumToName(JoystickDigitalFunctions[dummy][1]));
}
Bsprintf(buf, "ControllerAnalogScale%d", dummy);
SCRIPT_PutNumber(scripthandle, "Controls", buf, JoystickAnalogueScale[dummy], FALSE, FALSE);
Bsprintf(buf, "ControllerAnalogInvert%d", dummy);
SCRIPT_PutNumber(scripthandle, "Controls", buf, JoystickAnalogueInvert[dummy], FALSE, FALSE);
Bsprintf(buf, "ControllerAnalogDead%d", dummy);
SCRIPT_PutNumber(scripthandle, "Controls", buf, JoystickAnalogueDead[dummy], FALSE, FALSE);
Bsprintf(buf, "ControllerAnalogSaturate%d", dummy);
SCRIPT_PutNumber(scripthandle, "Controls", buf, JoystickAnalogueSaturate[dummy], FALSE, FALSE);
}
}
//SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","PlayerName",&szPlayerName[0]);
//SCRIPT_PutString(ud.config.scripthandle, "Comm Setup","RTSName",&ud.rtsname[0]);
// char commmacro[] = "CommbatMacro# ";
//for (int dummy = 0; dummy < MAXRIDECULE; dummy++)
//{
// commmacro[13] = dummy+'0';
// SCRIPT_PutString(ud.config.scripthandle, "Comm Setup",commmacro,&ud.ridecule[dummy][0]);
//}
SCRIPT_Save(scripthandle, setupfilename);
if ((flags & 2) == 0)
SCRIPT_Free(scripthandle);
OSD_Printf("Wrote %s\n",setupfilename);
CONFIG_WriteSettings();
Bfflush(NULL);
}
END_PS_NS END_PS_NS
#endif

View file

@ -24,32 +24,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
BEGIN_PS_NS BEGIN_PS_NS
#define kMaxGameFunctions 40
#define kMaxGameFuncLen 64
// KEEPINSYNC mact/include/_control.h, build/src/sdlayer.cpp
#define MAXJOYBUTTONS 32
#define MAXJOYBUTTONSANDHATS (MAXJOYBUTTONS+4)
// KEEPINSYNC mact/include/_control.h, build/src/sdlayer.cpp
#define MAXMOUSEAXES 2
#define MAXMOUSEDIGITAL (MAXMOUSEAXES*2)
// KEEPINSYNC mact/include/_control.h, build/src/sdlayer.cpp
#define MAXJOYAXES 9
#define MAXJOYDIGITAL (MAXJOYAXES*2)
// default mouse scale
#define DEFAULTMOUSEANALOGUESCALE 65536
// default joystick settings
#define DEFAULTJOYSTICKANALOGUESCALE 65536
#define DEFAULTJOYSTICKANALOGUEDEAD 2000
#define DEFAULTJOYSTICKANALOGUESATURATE 9500
extern const char gamefunctions[kMaxGameFunctions][kMaxGameFuncLen];
extern const char keydefaults[kMaxGameFunctions*2][kMaxGameFuncLen];
extern const char oldkeydefaults[kMaxGameFunctions*2][kMaxGameFuncLen];
typedef struct { typedef struct {
@ -63,57 +37,16 @@ typedef struct {
int32_t noautoload; int32_t noautoload;
} ud_setup_t; } ud_setup_t;
#define kSetupFilename "SETUP.CFG"
extern char setupfilename[];
extern hashtable_t h_gamefuncs;
void SetupInput();
void LoadConfig();
int CONFIG_ReadSetup();
void CONFIG_WriteSetup(uint32_t flags);
extern int lMouseSens; extern int lMouseSens;
extern ud_setup_t gSetup; extern ud_setup_t gSetup;
extern int32_t scripthandle; extern int32_t scripthandle;
extern int32_t setupread; extern int32_t setupread;
extern int32_t useprecache;
extern int32_t MouseDeadZone, MouseBias;
extern int32_t SmoothInput;
extern int32_t FXVolume;
extern int32_t MusicVolume;
extern int32_t MixRate;
extern int32_t MidiPort;
extern int32_t NumVoices;
extern int32_t NumChannels;
extern int32_t NumBits;
extern int32_t ReverseStereo;
extern int32_t MusicDevice;
extern int32_t FXDevice;
// JBF 20031211: Store the input settings because int CONFIG_ReadSetup(void);
// (currently) mact can't regurgitate them void CONFIG_SetDefaults(void);
extern int32_t MouseFunctions[MAXMOUSEBUTTONS][2];
extern int32_t MouseDigitalFunctions[MAXMOUSEAXES][2];
extern int32_t MouseAnalogueAxes[MAXMOUSEAXES];
extern int32_t MouseAnalogueScale[MAXMOUSEAXES];
extern int32_t JoystickFunctions[MAXJOYBUTTONSANDHATS][2];
extern int32_t JoystickDigitalFunctions[MAXJOYAXES][2];
extern int32_t JoystickAnalogueAxes[MAXJOYAXES];
extern int32_t JoystickAnalogueScale[MAXJOYAXES];
extern int32_t JoystickAnalogueInvert[MAXJOYAXES];
extern int32_t JoystickAnalogueDead[MAXJOYAXES];
extern int32_t JoystickAnalogueSaturate[MAXJOYAXES];
extern uint8_t KeyboardKeys[kMaxGameFunctions][2];
extern int32_t MAXCACHE1DSIZE;
void CONFIG_SetDefaultKeys(const char(*keyptr)[kMaxGameFuncLen], bool lazy=false);
void CONFIG_MapKey(int which, kb_scancode key1, kb_scancode oldkey1, kb_scancode key2, kb_scancode oldkey2);
int32_t CONFIG_FunctionNameToNum(const char* func);
END_PS_NS END_PS_NS

View file

@ -33,7 +33,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "menu.h" #include "menu.h"
#include "player.h" #include "player.h"
#include "network.h" #include "network.h"
#include "input.h" #include "ps_input.h"
#include "sound.h" #include "sound.h"
#include "cd.h" #include "cd.h"
#include "view.h" #include "view.h"
@ -68,7 +68,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "trigdat.h" #include "trigdat.h"
#include "record.h" #include "record.h"
#include "lighting.h" #include "lighting.h"
#include "grpscan.h"
#include <string.h> #include <string.h>
#include <cstdio> // for printf #include <cstdio> // for printf
#include <cstdlib> #include <cstdlib>
@ -446,64 +445,13 @@ const char *gString[] =
"", "",
}; };
static char g_rootDir[BMAX_PATH];
char g_modDir[BMAX_PATH] = "/";
buildvfs_kfd kopen4loadfrommod(const char *fileName, char searchfirst)
{
buildvfs_kfd kFile = buildvfs_kfd_invalid;
if (g_modDir[0] != '/' || g_modDir[1] != 0)
{
static char staticFileName[BMAX_PATH];
Bsnprintf(staticFileName, sizeof(staticFileName), "%s/%s", g_modDir, fileName);
kFile = kopen4load(staticFileName, searchfirst);
}
return (kFile == buildvfs_kfd_invalid) ? kopen4load(fileName, searchfirst) : kFile;
}
struct grpfile_t const *g_selectedGrp; struct grpfile_t const *g_selectedGrp;
int32_t g_gameType = GAMEFLAG_POWERSLAVE;
// g_gameNamePtr can point to one of: grpfiles[].name (string literal), string // g_gameNamePtr can point to one of: grpfiles[].name (string literal), string
// literal, malloc'd block (XXX: possible leak) // literal, malloc'd block (XXX: possible leak)
const char *g_gameNamePtr = NULL; const char *g_gameNamePtr = NULL;
// grp handling
static const char *defaultgamegrp = "STUFF.DAT";
static const char *defaultdeffilename = "exhumed.def";
// g_grpNamePtr can ONLY point to a malloc'd block (length BMAX_PATH)
char *g_grpNamePtr = NULL;
void clearGrpNamePtr(void)
{
Xfree(g_grpNamePtr);
// g_grpNamePtr assumed to be assigned to right after
}
const char *G_DefaultGrpFile(void)
{
return defaultgamegrp;
}
const char *G_DefaultDefFile(void)
{
return defaultdeffilename;
}
const char *G_GrpFile(void)
{
return (g_grpNamePtr == NULL) ? G_DefaultGrpFile() : g_grpNamePtr;
}
const char *G_DefFile(void)
{
return (g_defNamePtr == NULL) ? G_DefaultDefFile() : g_defNamePtr;
}
int32_t g_commandSetup = 0; int32_t g_commandSetup = 0;
int32_t g_noSetup = 0; int32_t g_noSetup = 0;
int32_t g_noAutoLoad = 0; int32_t g_noAutoLoad = 0;
@ -514,301 +462,10 @@ static struct strllist *CommandPaths, *CommandGrps;
void G_ExtPreInit(int32_t argc,char const * const * argv) void G_ExtPreInit(int32_t argc,char const * const * argv)
{ {
g_useCwd = G_CheckCmdSwitch(argc, argv, "-usecwd");
#ifdef _WIN32
GetModuleFileName(NULL,g_rootDir,BMAX_PATH);
Bcorrectfilename(g_rootDir,1);
//buildvfs_chdir(g_rootDir);
#else
buildvfs_getcwd(g_rootDir,BMAX_PATH);
strcat(g_rootDir,"/");
#endif
} }
void G_ExtInit(void) void G_ExtInit(void)
{ {
char cwd[BMAX_PATH];
#ifdef EDUKE32_OSX
char *appdir = Bgetappdir();
addsearchpath(appdir);
Xfree(appdir);
#endif
#ifdef USE_PHYSFS
strncpy(cwd, PHYSFS_getBaseDir(), ARRAY_SIZE(cwd));
cwd[ARRAY_SIZE(cwd)-1] = '\0';
#else
if (buildvfs_getcwd(cwd, ARRAY_SIZE(cwd)) && Bstrcmp(cwd, "/") != 0)
#endif
addsearchpath(cwd);
if (CommandPaths)
{
int32_t i;
struct strllist *s;
while (CommandPaths)
{
s = CommandPaths->next;
i = addsearchpath(CommandPaths->str);
if (i < 0)
{
initprintf("Failed adding %s for game data: %s\n", CommandPaths->str,
i==-1 ? "not a directory" : "no such directory");
}
Xfree(CommandPaths->str);
Xfree(CommandPaths);
CommandPaths = s;
}
}
#if defined(_WIN32) && !defined(EDUKE32_STANDALONE)
if (buildvfs_exists("user_profiles_enabled"))
#else
if (g_useCwd == 0 && !buildvfs_exists("user_profiles_disabled"))
#endif
{
char *homedir;
int32_t asperr;
if ((homedir = Bgethomedir()))
{
Bsnprintf(cwd, ARRAY_SIZE(cwd), "%s/"
#if defined(_WIN32)
APPNAME
#elif defined(GEKKO)
"apps/" APPBASENAME
#else
".config/" APPBASENAME
#endif
,homedir);
asperr = addsearchpath(cwd);
if (asperr == -2)
{
if (buildvfs_mkdir(cwd,S_IRWXU) == 0) asperr = addsearchpath(cwd);
else asperr = -1;
}
if (asperr == 0)
buildvfs_chdir(cwd);
Xfree(homedir);
}
}
}
void G_ScanGroups(void)
{
ScanGroups();
g_selectedGrp = NULL;
char const * const currentGrp = G_GrpFile();
for (grpfile_t const *fg = foundgrps; fg; fg=fg->next)
{
if (!Bstrcasecmp(fg->filename, currentGrp))
{
g_selectedGrp = fg;
break;
}
}
if (g_selectedGrp == NULL)
g_selectedGrp = foundgrps;
}
static int32_t G_TryLoadingGrp(char const * const grpfile)
{
int32_t i;
if ((i = initgroupfile(grpfile)) == -1)
initprintf("Warning: could not find main data file \"%s\"!\n", grpfile);
else
initprintf("Using \"%s\" as main game data file.\n", grpfile);
return i;
}
static int32_t G_LoadGrpDependencyChain(grpfile_t const * const grp)
{
if (!grp)
return -1;
if (grp->type->dependency && grp->type->dependency != grp->type->crcval)
G_LoadGrpDependencyChain(FindGroup(grp->type->dependency));
int32_t const i = G_TryLoadingGrp(grp->filename);
return i;
}
void G_LoadGroups(int32_t autoload)
{
if (g_modDir[0] != '/')
{
char cwd[BMAX_PATH];
Bstrcat(g_rootDir, g_modDir);
addsearchpath(g_rootDir);
// addsearchpath(mod_dir);
char path[BMAX_PATH];
if (buildvfs_getcwd(cwd, BMAX_PATH))
{
Bsnprintf(path, sizeof(path), "%s/%s", cwd, g_modDir);
if (!Bstrcmp(g_rootDir, path))
{
if (addsearchpath(path) == -2)
if (buildvfs_mkdir(path, S_IRWXU) == 0)
addsearchpath(path);
}
}
#ifdef USE_OPENGL
Bsnprintf(path, sizeof(path), "%s/%s", g_modDir, TEXCACHEFILE);
Bstrcpy(TEXCACHEFILE, path);
#endif
}
const char *grpfile;
int32_t i;
if ((i = G_LoadGrpDependencyChain(g_selectedGrp)) != -1)
{
grpfile = g_selectedGrp->filename;
clearGrpNamePtr();
g_grpNamePtr = dup_filename(grpfile);
grpinfo_t const * const type = g_selectedGrp->type;
g_gameType = type->game;
g_gameNamePtr = type->name;
if (type->defname && g_defNamePtr == NULL)
g_defNamePtr = dup_filename(type->defname);
}
else
{
grpfile = G_GrpFile();
i = G_TryLoadingGrp(grpfile);
}
if (autoload)
{
G_LoadGroupsInDir("autoload");
if (i != -1)
G_DoAutoload(grpfile);
}
if (g_modDir[0] != '/')
G_LoadGroupsInDir(g_modDir);
loaddefinitions_game(G_DefFile(), TRUE);
struct strllist *s;
int const bakpathsearchmode = pathsearchmode;
pathsearchmode = 1;
while (CommandGrps)
{
int32_t j;
s = CommandGrps->next;
if ((j = initgroupfile(CommandGrps->str)) == -1)
initprintf("Could not find file \"%s\".\n", CommandGrps->str);
else
{
g_groupFileHandle = j;
initprintf("Using file \"%s\" as game data.\n", CommandGrps->str);
if (autoload)
G_DoAutoload(CommandGrps->str);
}
Xfree(CommandGrps->str);
Xfree(CommandGrps);
CommandGrps = s;
}
pathsearchmode = bakpathsearchmode;
}
//////////
void G_AddGroup(const char *buffer)
{
char buf[BMAX_PATH];
struct strllist *s = (struct strllist *)Xcalloc(1,sizeof(struct strllist));
Bstrcpy(buf, buffer);
if (Bstrchr(buf,'.') == 0)
Bstrcat(buf,".grp");
s->str = Xstrdup(buf);
if (CommandGrps)
{
struct strllist *t;
for (t = CommandGrps; t->next; t=t->next) ;
t->next = s;
return;
}
CommandGrps = s;
}
void G_AddPath(const char *buffer)
{
struct strllist *s = (struct strllist *)Xcalloc(1,sizeof(struct strllist));
s->str = Xstrdup(buffer);
if (CommandPaths)
{
struct strllist *t;
for (t = CommandPaths; t->next; t=t->next) ;
t->next = s;
return;
}
CommandPaths = s;
}
//////////
// loads all group (grp, zip, pk3/4) files in the given directory
void G_LoadGroupsInDir(const char *dirname)
{
static const char *extensions[] = { "*.grp", "*.zip", "*.ssi", "*.pk3", "*.pk4" };
char buf[BMAX_PATH];
fnlist_t fnlist = FNLIST_INITIALIZER;
for (auto & extension : extensions)
{
BUILDVFS_FIND_REC *rec;
fnlist_getnames(&fnlist, dirname, extension, -1, 0);
for (rec=fnlist.findfiles; rec; rec=rec->next)
{
Bsnprintf(buf, sizeof(buf), "%s/%s", dirname, rec->name);
initprintf("Using group file \"%s\".\n", buf);
initgroupfile(buf);
}
fnlist_clearnames(&fnlist);
}
}
void G_DoAutoload(const char *dirname)
{
char buf[BMAX_PATH];
Bsnprintf(buf, sizeof(buf), "autoload/%s", dirname);
G_LoadGroupsInDir(buf);
} }
////////// //////////
@ -909,20 +566,10 @@ static int parsedefinitions_game(scriptfile *pScript, int firstPass)
{ {
char *fileName; char *fileName;
pathsearchmode = 1;
if (!scriptfile_getstring(pScript,&fileName) && firstPass) if (!scriptfile_getstring(pScript,&fileName) && firstPass)
{ {
if (initgroupfile(fileName) == -1) fileSystem.AddAdditionalFile(fileName);
initprintf("Could not find file \"%s\".\n", fileName);
else
{
initprintf("Using file \"%s\" as game data.\n", fileName);
if (!g_noAutoLoad && !gSetup.noautoload)
G_DoAutoload(fileName);
}
} }
pathsearchmode = 0;
} }
break; break;
case T_CACHESIZE: case T_CACHESIZE:
@ -931,9 +578,6 @@ static int parsedefinitions_game(scriptfile *pScript, int firstPass)
if (scriptfile_getnumber(pScript, &cacheSize) || !firstPass) if (scriptfile_getnumber(pScript, &cacheSize) || !firstPass)
break; break;
if (cacheSize > 0)
MAXCACHE1DSIZE = cacheSize << 10;
} }
break; break;
case T_INCLUDE: case T_INCLUDE:
@ -971,7 +615,7 @@ int loaddefinitions_game(const char *fileName, int32_t firstPass)
if (pScript) if (pScript)
parsedefinitions_game(pScript, firstPass); parsedefinitions_game(pScript, firstPass);
for (char const * m : g_defModules) for (auto &m : *userConfig.AddDefs)
parsedefinitions_game_include(m, NULL, "null", firstPass); parsedefinitions_game_include(m, NULL, "null", firstPass);
if (pScript) if (pScript)
@ -1165,21 +809,12 @@ void DebugOut(const char *fmt, ...)
#ifdef _DEBUG #ifdef _DEBUG
va_list args; va_list args;
va_start(args, fmt); va_start(args, fmt);
VPrintf(PRINT_HIGH, fmt, args);
debugBuffer[0] = '\0';
vsprintf(debugBuffer, fmt, args);
initprintf("%s", debugBuffer);
fflush(stdout);
va_end(args);
#endif #endif
} }
void ShutDown(void) void ShutDown(void)
{ {
CONFIG_WriteSetup(0);
StopCD(); StopCD();
if (bSerialPlay) if (bSerialPlay)
{ {
@ -1189,13 +824,12 @@ void ShutDown(void)
UnInitSerial(); UnInitSerial();
} }
KB_Shutdown();
RemoveEngine(); RemoveEngine();
UnInitNet(); UnInitNet();
UnInitFX(); UnInitFX();
} }
void bail2dos(const char *fmt, ...) void I_Error(const char *fmt, ...)
{ {
char buf[256]; char buf[256];
@ -1417,9 +1051,7 @@ void mysetbrightness(char nBrightness)
void CheckKeys() void CheckKeys()
{ {
int eax; if (buttonMap.ButtonDown(gamefunc_Enlarge_Screen))
if (BUTTON(gamefunc_Enlarge_Screen))
{ {
if (screensize == 0) if (screensize == 0)
{ {
@ -1438,12 +1070,12 @@ void CheckKeys()
UpdateScreenSize(); UpdateScreenSize();
} }
CONTROL_ClearButton(gamefunc_Enlarge_Screen); buttonMap.ClearButton(gamefunc_Enlarge_Screen);
} }
// F11? // F11?
#if 0 #if 0
if (BUTTON(gamefunc_Gamma_Correction)) if (buttonMap.ButtonDown(gamefunc_Gamma_Correction))
{ {
nGamma++; nGamma++;
@ -1451,11 +1083,11 @@ void CheckKeys()
nGamma = 0; nGamma = 0;
mysetbrightness((uint8_t)nGamma); mysetbrightness((uint8_t)nGamma);
CONTROL_ClearButton(gamefunc_Gamma_Correction); buttonMap.ClearButton(gamefunc_Gamma_Correction);
#endif
} }
#endif
if (BUTTON(gamefunc_Shrink_Screen)) if (buttonMap.ButtonDown(gamefunc_Shrink_Screen))
{ {
if (bFullScreen) if (bFullScreen)
{ {
@ -1468,19 +1100,11 @@ void CheckKeys()
} }
UpdateScreenSize(); UpdateScreenSize();
CONTROL_ClearButton(gamefunc_Shrink_Screen); buttonMap.ClearButton(gamefunc_Shrink_Screen);
}
// print version string?
if (KB_KeyDown[sc_V] && KB_KeyDown[sc_LeftAlt])
{
KB_KeyDown[sc_V] = 0;
StatusMessage(300, versionstr);
return;
} }
// go to 3rd person view? // go to 3rd person view?
if (KB_KeyDown[sc_C] && KB_KeyDown[sc_LeftAlt]) if (buttonMap.ButtonDown(gamefunc_Third_Person_View))
{ {
if (!nFreeze) if (!nFreeze)
{ {
@ -1494,11 +1118,11 @@ void CheckKeys()
if (bCamera) if (bCamera)
GrabPalette(); GrabPalette();
} }
KB_KeyDown[sc_C] = 0; buttonMap.ClearButton(gamefunc_Third_Person_View);
return; return;
} }
if (KB_KeyDown[sc_Pause]) if (inputState.GetKeyStatus(sc_Pause))
{ {
if (!nNetPlayerCount) if (!nNetPlayerCount)
{ {
@ -1516,15 +1140,15 @@ void CheckKeys()
// Clip(); // Clip();
// videoNextPage(); // videoNextPage();
} }
KB_KeyDown[sc_Pause] = 0; inputState.ClearKeyStatus(sc_Pause);
} }
return; return;
} }
// Handle cheat codes // Handle cheat codes
if (!bInDemo && KB_KeyWaiting()) if (!bInDemo && inputState.keyBufferWaiting())
{ {
char ch = KB_GetCh(); char ch = inputState.keyGetChar();
if (bHolly) if (bHolly)
{ {
@ -1667,7 +1291,7 @@ void CheckKeys()
} }
else else
{ {
KB_GetCh(); inputState.keyGetChar(); //???
} }
} }
@ -1771,11 +1395,11 @@ void DoCredits()
while ((int)totalclock + 600 > (int)totalclock) while ((int)totalclock + 600 > (int)totalclock)
{ {
if (KB_KeyDown[sc_F12]) if(inputState.GetKeyStatus(sc_F12))
{ {
var_20++; var_20++;
KB_KeyDown[sc_F12] = 0; inputState.ClearKeyStatus(sc_F12);
if (var_20 > 5) { if (var_20 > 5) {
return; return;
@ -1788,9 +1412,7 @@ void DoCredits()
while (CDplaying()) while (CDplaying())
{ {
if (KB_KeyWaiting()) { inputState.keyGetChar();
KB_GetCh();
}
} }
Clip(); Clip();
@ -2624,7 +2246,7 @@ int app_main(int argc, char const* const* argv)
GrabPalette(); GrabPalette();
if (bSerialPlay && !InitSerial()) { if (bSerialPlay && !InitSerial()) {
bail2dos("Unable to connect"); I_Error("Unable to connect");
} }
if (doTitle) if (doTitle)
@ -2689,7 +2311,7 @@ STARTGAME2:
{ {
int nPlayer = GrabPlayer(); int nPlayer = GrabPlayer();
if (nPlayer < 0) { if (nPlayer < 0) {
bail2dos("Can't create local player\n"); I_Error("Can't create local player\n");
} }
InitPlayerInventory(nPlayer); InitPlayerInventory(nPlayer);
@ -2780,7 +2402,7 @@ LOOP3:
Query(2, 0, "Insert CD into drive", "(ESC to abort)"); Query(2, 0, "Insert CD into drive", "(ESC to abort)");
KB_ClearKeysDown(); KB_ClearKeysDown();
if (KB_GetCh() == asc_Escape) { if (KB_GetCh() == asc_Escape) {
bail2dos("Aborted\n"); I_Error("Aborted\n");
} }
} }
} }
@ -2962,9 +2584,9 @@ LOOP3:
// } // }
// else if (nNetTime == 0) // else if (nNetTime == 0)
// { // {
// if (BUTTON(gamefunc_Open)) // if (buttonMap.ButtonDown(gamefunc_Open))
// { // {
// CONTROL_ClearButton(gamefunc_Open); // buttonMap.ClearButton(gamefunc_Open);
// goto MENU2; // goto MENU2;
// } // }
// } // }
@ -3035,9 +2657,9 @@ LOOP3:
} }
if (!bInDemo) if (!bInDemo)
{ {
if (BUTTON(gamefunc_Escape)) if (buttonMap.ButtonDown(gamefunc_Escape))
{ {
CONTROL_ClearButton(gamefunc_Escape); buttonMap.ClearButton(gamefunc_Escape);
// MENU2: // MENU2:
CONTROL_BindsEnabled = 0; CONTROL_BindsEnabled = 0;
bInMove = kTrue; bInMove = kTrue;
@ -3076,9 +2698,9 @@ LOOP3:
KB_ClearKeyDown(sc_F12); KB_ClearKeyDown(sc_F12);
videoCaptureScreen("captxxxx.png", 0); videoCaptureScreen("captxxxx.png", 0);
} }
else if (BUTTON(gamefunc_Map)) // e.g. TAB (to show 2D map) else if (buttonMap.ButtonDown(gamefunc_Map)) // e.g. TAB (to show 2D map)
{ {
CONTROL_ClearButton(gamefunc_Map); buttonMap.ClearButton(gamefunc_Map);
if (!nFreeze) { if (!nFreeze) {
nMapMode = (nMapMode+1)%3; nMapMode = (nMapMode+1)%3;
@ -3090,10 +2712,10 @@ LOOP3:
int const timerOffset = ((int) totalclock - nonsharedtimer); int const timerOffset = ((int) totalclock - nonsharedtimer);
nonsharedtimer += timerOffset; nonsharedtimer += timerOffset;
if (BUTTON(gamefunc_Zoom_In)) if (buttonMap.ButtonDown(gamefunc_Zoom_In))
lMapZoom += mulscale6(timerOffset, max<int>(lMapZoom, 256)); lMapZoom += mulscale6(timerOffset, max<int>(lMapZoom, 256));
if (BUTTON(gamefunc_Zoom_Out)) if (buttonMap.ButtonDown(gamefunc_Zoom_Out))
lMapZoom -= mulscale6(timerOffset, max<int>(lMapZoom, 256)); lMapZoom -= mulscale6(timerOffset, max<int>(lMapZoom, 256));
lMapZoom = clamp(lMapZoom, 48, 2048); lMapZoom = clamp(lMapZoom, 48, 2048);
@ -3101,20 +2723,20 @@ LOOP3:
if (PlayerList[nLocalPlayer].nHealth > 0) if (PlayerList[nLocalPlayer].nHealth > 0)
{ {
if (BUTTON(gamefunc_Inventory_Left)) if (buttonMap.ButtonDown(gamefunc_Inventory_Left))
{ {
SetPrevItem(nLocalPlayer); SetPrevItem(nLocalPlayer);
CONTROL_ClearButton(gamefunc_Inventory_Left); buttonMap.ClearButton(gamefunc_Inventory_Left);
} }
if (BUTTON(gamefunc_Inventory_Right)) if (buttonMap.ButtonDown(gamefunc_Inventory_Right))
{ {
SetNextItem(nLocalPlayer); SetNextItem(nLocalPlayer);
CONTROL_ClearButton(gamefunc_Inventory_Right); buttonMap.ClearButton(gamefunc_Inventory_Right);
} }
if (BUTTON(gamefunc_Inventory)) if (buttonMap.ButtonDown(gamefunc_Inventory))
{ {
UseCurItem(nLocalPlayer); UseCurItem(nLocalPlayer);
CONTROL_ClearButton(gamefunc_Inventory); buttonMap.ClearButton(gamefunc_Inventory);
} }
} }
else { else {
@ -3168,7 +2790,7 @@ void mychangespritesect(int nSprite, int nSector)
void mydeletesprite(int nSprite) void mydeletesprite(int nSprite)
{ {
if (nSprite < 0 || nSprite > kMaxSprites) { if (nSprite < 0 || nSprite > kMaxSprites) {
bail2dos("bad sprite value %d handed to mydeletesprite", nSprite); I_Error("bad sprite value %d handed to mydeletesprite", nSprite);
} }
deletesprite(nSprite); deletesprite(nSprite);

View file

@ -21,7 +21,13 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "compat.h" #include "compat.h"
#include "cache1d.h" #include "cache1d.h"
#include "grpscan.h" #include "v_text.h"
#include "printf.h"
#include "gamecvars.h"
#include "m_argv.h"
#include "gamecontrol.h"
#include "c_buttons.h"
#include "filesystem/filesystem.h"
BEGIN_PS_NS BEGIN_PS_NS
@ -31,17 +37,6 @@ BEGIN_PS_NS
void handleevents(); void handleevents();
#endif #endif
// TODO:
#define OSDTEXT_DEFAULT "^00"
#define OSDTEXT_DARKRED "^00"
#define OSDTEXT_GREEN "^00"
#define OSDTEXT_RED "^00"
#define OSDTEXT_YELLOW "^00"
#define OSDTEXT_BRIGHT "^S0"
#define OSD_ERROR OSDTEXT_DARKRED OSDTEXT_BRIGHT
enum basepal_t { enum basepal_t {
BASEPAL = 0, BASEPAL = 0,
ANIMPAL, ANIMPAL,
@ -50,7 +45,6 @@ enum basepal_t {
void ShutDown(void); void ShutDown(void);
void DebugOut(const char *fmt, ...); void DebugOut(const char *fmt, ...);
void bail2dos(const char *fmt, ...);
int ExhumedMain(int argc, char *argv[]); int ExhumedMain(int argc, char *argv[]);
void FinishLevel(); void FinishLevel();

View file

@ -325,7 +325,7 @@ void FuncFish(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Fish\n", a & 0x7F0000); Printf("unknown msg %d for Fish\n", a & 0x7F0000);
return; return;
} }

View file

@ -295,7 +295,7 @@ void FuncGrenade(int a, int nDamage, int nRun)
default: default:
{ {
DebugOut("unknown msg %d for bullet\n", a & 0x7F0000); // TODO - change 'bullet' to 'grenade' ? Printf("unknown msg %d for bullet\n", a & 0x7F0000); // TODO - change 'bullet' to 'grenade' ?
return; return;
} }

View file

@ -1,474 +0,0 @@
//-------------------------------------------------------------------------
/*
Copyright (C) 2010 EDuke32 developers and contributors
This file is part of EDuke32.
EDuke32 is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License version 2
as published by the Free Software Foundation.
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.
*/
//-------------------------------------------------------------------------
#include "ns.h"
#include "baselayer.h"
#include "cache1d.h"
#include "exhumed.h"
#include "common.h"
#include "compat.h"
//#include "crc32.h"
#include "grpscan.h"
#include "scriptfile.h"
BEGIN_PS_NS
#ifndef EDUKE32_STANDALONE
static void process_vaca13(int32_t crcval);
static void process_vacapp15(int32_t crcval);
// custom GRP support for the startup window, file format reflects the structure below
#define GAMELISTFILE "games.list"
// name crc size flags dependency
static internalgrpinfo_t const internalgrpfiles[] =
{
{ "Powerslave", POWERSLAVE_CRC, 27020745, GAMEFLAG_POWERSLAVE, 0 },
{ "Exhumed", EXHUMED_CRC, 27108170, GAMEFLAG_EXHUMED, 0 },
};
#endif
struct grpfile_t *foundgrps = NULL;
struct grpinfo_t *listgrps = NULL;
static void LoadList(const char * filename)
{
scriptfile *script = scriptfile_fromfile(filename);
if (!script)
return;
#ifndef EDUKE32_STANDALONE
scriptfile_addsymbolvalue("GAMEFLAG_POWERSLAVE", GAMEFLAG_POWERSLAVE);
scriptfile_addsymbolvalue("POWERSLAVE_CRC", POWERSLAVE_CRC);
scriptfile_addsymbolvalue("EXHUMED_CRC", EXHUMED_CRC);
#endif
while (!scriptfile_eof(script))
{
enum
{
T_GRPINFO,
T_GAMENAME,
T_CRC,
T_SIZE,
T_DEPCRC,
T_DEFNAME,
T_FLAGS,
};
static const tokenlist profiletokens[] =
{
{ "grpinfo", T_GRPINFO },
};
int32_t token = getatoken(script,profiletokens,ARRAY_SIZE(profiletokens));
switch (token)
{
case T_GRPINFO:
{
int32_t gsize = 0, gcrcval = 0, gflags = GAMEFLAG_POWERSLAVE, gdepcrc = POWERSLAVE_CRC;
char *gname = NULL, *gdef = NULL;
char *grpend = NULL;
static const tokenlist grpinfotokens[] =
{
{ "name", T_GAMENAME },
{ "defname", T_DEFNAME },
{ "crc", T_CRC },
{ "dependency", T_DEPCRC },
{ "size", T_SIZE },
{ "flags", T_FLAGS },
};
if (scriptfile_getbraces(script,&grpend)) break;
while (script->textptr < grpend)
{
int32_t token = getatoken(script,grpinfotokens,ARRAY_SIZE(grpinfotokens));
switch (token)
{
case T_GAMENAME:
scriptfile_getstring(script,&gname); break;
case T_DEFNAME:
scriptfile_getstring(script,&gdef); break;
case T_FLAGS:
scriptfile_getsymbol(script,&gflags); gflags &= GAMEFLAGMASK; break;
case T_DEPCRC:
scriptfile_getsymbol(script,&gdepcrc); break;
case T_CRC:
scriptfile_getsymbol(script,&gcrcval); break;
case T_SIZE:
scriptfile_getnumber(script,&gsize); break;
default:
break;
}
grpinfo_t * const fg = (grpinfo_t *)Xcalloc(1, sizeof(grpinfo_t));
fg->next = listgrps;
listgrps = fg;
if (gname)
fg->name = Xstrdup(gname);
fg->size = gsize;
fg->crcval = gcrcval;
fg->dependency = gdepcrc;
fg->game = gflags;
if (gdef)
fg->defname = dup_filename(gdef);
}
break;
}
default:
break;
}
}
scriptfile_close(script);
scriptfile_clearsymbols();
}
static void LoadGameList(void)
{
#ifndef EDUKE32_STANDALONE
for (size_t i = 0; i < ARRAY_SIZE(internalgrpfiles); i++)
{
grpinfo_t * const fg = (grpinfo_t *)Xcalloc(1, sizeof(grpinfo_t));
fg->name = Xstrdup(internalgrpfiles[i].name);
fg->crcval = internalgrpfiles[i].crcval;
fg->size = internalgrpfiles[i].size;
fg->game = internalgrpfiles[i].game;
fg->dependency = internalgrpfiles[i].dependency;
fg->next = listgrps;
listgrps = fg;
}
#endif
#ifdef USE_PHYSFS
auto const base = PHYSFS_getBaseDir();
#else
static char const base[] = "/";
#endif
BUILDVFS_FIND_REC * const srch = klistpath(base, "*.grpinfo", BUILDVFS_FIND_FILE);
for (BUILDVFS_FIND_REC *sidx = srch; sidx; sidx = sidx->next)
LoadList(sidx->name);
klistfree(srch);
}
static void FreeGameList(void)
{
while (listgrps)
{
Xfree(listgrps->name);
Xfree(listgrps->defname);
grpinfo_t * const fg = listgrps->next;
Xfree(listgrps);
listgrps = fg;
}
}
#define GRPCACHEFILE "grpfiles.cache"
static struct grpcache
{
struct grpcache *next;
int32_t size;
int32_t mtime;
int32_t crcval;
char name[BMAX_PATH];
}
*grpcache = NULL, *usedgrpcache = NULL;
static int32_t LoadGroupsCache(void)
{
struct grpcache *fg;
int32_t fsize, fmtime, fcrcval;
char *fname;
scriptfile *script;
script = scriptfile_fromfile(GRPCACHEFILE);
if (!script) return -1;
while (!scriptfile_eof(script))
{
if (scriptfile_getstring(script, &fname)) break; // filename
if (scriptfile_getnumber(script, &fsize)) break; // filesize
if (scriptfile_getnumber(script, &fmtime)) break; // modification time
if (scriptfile_getnumber(script, &fcrcval)) break; // crc checksum
fg = (struct grpcache *)Xcalloc(1, sizeof(struct grpcache));
fg->next = grpcache;
grpcache = fg;
Bstrncpy(fg->name, fname, BMAX_PATH);
fg->size = fsize;
fg->mtime = fmtime;
fg->crcval = fcrcval;
}
scriptfile_close(script);
return 0;
}
static void FreeGroupsCache(void)
{
while (grpcache)
{
struct grpcache * const fg = grpcache->next;
Xfree(grpcache);
grpcache = fg;
}
}
static void RemoveGroup(grpfile_t *igrp)
{
for (grpfile_t *prev = NULL, *grp = foundgrps; grp; grp=grp->next)
{
if (grp == igrp)
{
if (grp == foundgrps)
foundgrps = grp->next;
else
prev->next = grp->next;
Xfree((char *)grp->filename);
Xfree(grp);
return;
}
prev = grp;
}
}
grpfile_t * FindGroup(int32_t crcval)
{
grpfile_t *grp;
for (grp = foundgrps; grp; grp=grp->next)
{
if (grp->type->crcval == crcval)
return grp;
}
return NULL;
}
#ifndef USE_PHYSFS
static grpinfo_t const * FindGrpInfo(int32_t crcval, int32_t size)
{
grpinfo_t *grpinfo;
for (grpinfo = listgrps; grpinfo; grpinfo=grpinfo->next)
{
if (grpinfo->crcval == crcval && grpinfo->size == size)
return grpinfo;
}
return NULL;
}
static void ProcessGroups(BUILDVFS_FIND_REC *srch)
{
BUILDVFS_FIND_REC *sidx;
struct grpcache *fg, *fgg;
char *fn;
struct Bstat st;
static constexpr int ReadSize = 65536;
auto buf = (uint8_t *)Xmalloc(ReadSize);
for (sidx = srch; sidx; sidx = sidx->next)
{
for (fg = grpcache; fg; fg = fg->next)
{
if (!Bstrcmp(fg->name, sidx->name)) break;
}
if (fg)
{
if (findfrompath(sidx->name, &fn)) continue; // failed to resolve the filename
if (Bstat(fn, &st))
{
Xfree(fn);
continue;
} // failed to stat the file
Xfree(fn);
if (fg->size == (int32_t)st.st_size && fg->mtime == (int32_t)st.st_mtime)
{
grpinfo_t const * const grptype = FindGrpInfo(fg->crcval, fg->size);
if (grptype)
{
grpfile_t * const grp = (grpfile_t *)Xcalloc(1, sizeof(grpfile_t));
grp->filename = Xstrdup(sidx->name);
grp->type = grptype;
grp->next = foundgrps;
foundgrps = grp;
}
fgg = (struct grpcache *)Xcalloc(1, sizeof(struct grpcache));
strcpy(fgg->name, fg->name);
fgg->size = fg->size;
fgg->mtime = fg->mtime;
fgg->crcval = fg->crcval;
fgg->next = usedgrpcache;
usedgrpcache = fgg;
continue;
}
}
{
int32_t b, fh;
int32_t crcval = 0;
fh = openfrompath(sidx->name, BO_RDONLY|BO_BINARY, BS_IREAD);
if (fh < 0) continue;
if (Bfstat(fh, &st)) continue;
initprintf(" Checksumming %s...", sidx->name);
do
{
b = read(fh, buf, ReadSize);
if (b > 0) crcval = Bcrc32((uint8_t *)buf, b, crcval);
}
while (b == ReadSize);
close(fh);
initprintf(" Done\n");
grpinfo_t const * const grptype = FindGrpInfo(crcval, st.st_size);
if (grptype)
{
grpfile_t * const grp = (grpfile_t *)Xcalloc(1, sizeof(grpfile_t));
grp->filename = Xstrdup(sidx->name);
grp->type = grptype;
grp->next = foundgrps;
foundgrps = grp;
}
fgg = (struct grpcache *)Xcalloc(1, sizeof(struct grpcache));
Bstrncpy(fgg->name, sidx->name, BMAX_PATH);
fgg->size = st.st_size;
fgg->mtime = st.st_mtime;
fgg->crcval = crcval;
fgg->next = usedgrpcache;
usedgrpcache = fgg;
}
}
Xfree(buf);
}
#endif
int32_t ScanGroups(void)
{
#ifndef USE_PHYSFS
struct grpcache *fg, *fgg;
initprintf("Searching for game data...\n");
LoadGameList();
LoadGroupsCache();
static char const *extensions[] =
{
"*.grp",
"*.ssi",
"*.dat",
};
for (char const *extension : extensions)
{
BUILDVFS_FIND_REC *srch = klistpath("/", extension, BUILDVFS_FIND_FILE);
ProcessGroups(srch);
klistfree(srch);
}
FreeGroupsCache();
for (grpfile_t *grp = foundgrps; grp; grp=grp->next)
{
if (grp->type->dependency)
{
if (FindGroup(grp->type->dependency) == NULL) // couldn't find dependency
{
//initprintf("removing %s\n", grp->name);
RemoveGroup(grp);
grp = foundgrps;
// start from the beginning so we can remove anything that depended on this grp
continue;
}
}
}
if (usedgrpcache)
{
int32_t i = 0;
buildvfs_FILE fp = buildvfs_fopen_write(GRPCACHEFILE);
if (fp)
{
for (fg = usedgrpcache; fg; fg=fgg)
{
fgg = fg->next;
fprintf(fp, "\"%s\" %d %d %d\n", fg->name, fg->size, fg->mtime, fg->crcval);
Xfree(fg);
i++;
}
buildvfs_fclose(fp);
}
// initprintf("Found %d recognized GRP %s.\n",i,i>1?"files":"file");
return 0;
}
initprintf("Found no recognized game data!\n");
#endif
return 0;
}
void FreeGroups(void)
{
while (foundgrps)
{
Xfree((char *)foundgrps->filename);
grpfile_t * const fg = foundgrps->next;
Xfree(foundgrps);
foundgrps = fg;
}
FreeGameList();
}
END_PS_NS

View file

@ -1,80 +0,0 @@
//-------------------------------------------------------------------------
/*
Copyright (C) 2010 EDuke32 developers and contributors
This file is part of EDuke32.
EDuke32 is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License version 2
as published by the Free Software Foundation.
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.
*/
//-------------------------------------------------------------------------
#ifndef grpscan_h_
#define grpscan_h_
BEGIN_PS_NS
#define MAXLISTNAMELEN 32
// List of internally-known GRP files
#define POWERSLAVE_CRC (int32_t)0x303CBD89
// TODO:
#define EXHUMED_CRC (int32_t)0xE3B172F1
#define GAMEFLAG_POWERSLAVE 0x00000001
#define GAMEFLAG_EXHUMED 0x00000002
//#define GAMEFLAG_ADDON 0x00000010
//#define GAMEFLAG_SHAREWARE 0x00000020
#define GAMEFLAGMASK 0x000000FF // flags allowed from grpinfo
typedef struct internalgrpinfo_t {
char const *name;
int32_t const crcval;
int32_t const size;
int32_t const game;
int32_t const dependency;
// char const *scriptname;
// void(*postprocessing)(int32_t);
} internalgrpinfo_t;
typedef struct grpinfo_t {
char *name;
int32_t crcval;
int32_t size;
int32_t game;
int32_t dependency;
// char *scriptname;
char *defname;
// char *rtsname;
// void (*postprocessing)(int32_t);
struct grpinfo_t *next;
} grpinfo_t;
typedef struct grpfile_t {
char *filename;
struct grpinfo_t const *type;
struct grpfile_t *next;
} grpfile_t;
extern grpfile_t *foundgrps;
extern grpinfo_t *listgrps;
extern grpfile_t * FindGroup(int32_t crcval);
int32_t ScanGroups(void);
void FreeGroups(void);
END_PS_NS
#endif

View file

@ -32,7 +32,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "grenade.h" #include "grenade.h"
#include "lighting.h" #include "lighting.h"
#include "light.h" #include "light.h"
#include "input.h" #include "ps_input.h"
#include "util.h" #include "util.h"
#include "anims.h" #include "anims.h"
#include "runlist.h" #include "runlist.h"

View file

@ -40,7 +40,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "menu.h" #include "menu.h"
#include "lighting.h" #include "lighting.h"
#include "anims.h" #include "anims.h"
#include "input.h" #include "ps_input.h"
#include "util.h" #include "util.h"
#include <stdio.h> #include <stdio.h>
#include <string.h> #include <string.h>
@ -449,7 +449,7 @@ void InstallEngine()
{ {
buildvfs_chdir(cwd); buildvfs_chdir(cwd);
if (artLoadFiles("tiles000.art", MAXCACHE1DSIZE) < 0) if (artLoadFiles("tiles000.art", MAXCACHE1DSIZE) < 0)
bail2dos("Failed loading art."); I_Error("Failed loading art.");
} }
buildvfs_chdir(cwd); buildvfs_chdir(cwd);
#ifndef __ANDROID__ //This crashes on *some* Android devices. Small onetime memory leak. TODO fix above function #ifndef __ANDROID__ //This crashes on *some* Android devices. Small onetime memory leak. TODO fix above function
@ -457,7 +457,7 @@ void InstallEngine()
#endif #endif
} }
else if (artLoadFiles("tiles000.art",MAXCACHE1DSIZE) < 0) else if (artLoadFiles("tiles000.art",MAXCACHE1DSIZE) < 0)
bail2dos("Failed loading art."); I_Error("Failed loading art.");
// TEMP // TEMP
@ -502,7 +502,7 @@ void InstallEngine()
if (++resIdx == validmodecnt) if (++resIdx == validmodecnt)
{ {
if (bpp == 8) if (bpp == 8)
bail2dos("Fatal error: unable to set any video mode!"); I_Error("Fatal error: unable to set any video mode!");
resIdx = savedIdx; resIdx = savedIdx;
bpp = 8; bpp = 8;

View file

@ -16,7 +16,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/ */
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
#include "ns.h" #include "ns.h"
#include "input.h" #include "ps_input.h"
#include "engine.h" #include "engine.h"
#include "exhumed.h" #include "exhumed.h"
#include "player.h" #include "player.h"
@ -73,7 +73,7 @@ void InitInput()
void ClearSpaceBar(short nPlayer) void ClearSpaceBar(short nPlayer)
{ {
sPlayerInput[nPlayer].buttons &= 0x0FB; sPlayerInput[nPlayer].buttons &= 0x0FB;
CONTROL_ClearButton(gamefunc_Open); buttonMap.ClearButton(gamefunc_Open);
} }
void GetLocalInput() void GetLocalInput()
@ -81,22 +81,22 @@ void GetLocalInput()
int i; int i;
for (i = 6; i >= 0; i--) for (i = 6; i >= 0; i--)
{ {
if (BUTTON(gamefunc_Weapon_1+i)) if (buttonMap.ButtonDown(gamefunc_Weapon_1+i))
break; break;
} }
i++; i++;
if (PlayerList[nLocalPlayer].nHealth) if (PlayerList[nLocalPlayer].nHealth)
{ {
lLocalButtons = (BUTTON(gamefunc_Crouch) << 4) | (BUTTON(gamefunc_Fire) << 3) lLocalButtons = (buttonMap.ButtonDown(gamefunc_Crouch) << 4) | (buttonMap.ButtonDown(gamefunc_Fire) << 3)
| (BUTTON(gamefunc_Jump)<<0) | (i<<13); | (buttonMap.ButtonDown(gamefunc_Jump)<<0) | (i<<13);
} }
else else
{ {
lLocalButtons = 0; lLocalButtons = 0;
} }
lLocalButtons |= BUTTON(gamefunc_Open) << 2; lLocalButtons |= buttonMap.ButtonDown(gamefunc_Open) << 2;
// TODO ExecRecord(&sPlayerInput[nLocalPlayer], sizeof(PlayerInput)); // TODO ExecRecord(&sPlayerInput[nLocalPlayer], sizeof(PlayerInput));
} }

View file

@ -26,7 +26,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "engine.h" #include "engine.h"
#include "random.h" #include "random.h"
#include "init.h" #include "init.h"
#include "input.h" #include "ps_input.h"
#include "object.h" #include "object.h"
BEGIN_PS_NS BEGIN_PS_NS

View file

@ -223,7 +223,7 @@ void FuncLava(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Lava\n", a & 0x7F0000); Printf("unknown msg %d for Lava\n", a & 0x7F0000);
return; return;
} }

View file

@ -138,7 +138,7 @@ void FuncLion(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Lion\n", nMessage); Printf("unknown msg %d for Lion\n", nMessage);
return; return;
} }

View file

@ -31,7 +31,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "sound.h" #include "sound.h"
#include "names.h" #include "names.h"
#include "init.h" #include "init.h"
#include "input.h" #include "ps_input.h"
#include "gun.h" #include "gun.h"
#include "view.h" #include "view.h"
#include "object.h" #include "object.h"

View file

@ -58,7 +58,7 @@ palette_t moviepal[256];
int ReadFrame(FILE *fp) int ReadFrame(FILE *fp)
{ {
static int nFrame = 0; static int nFrame = 0;
DebugOut("Reading frame %d...\n", nFrame); Printf("Reading frame %d...\n", nFrame);
nFrame++; nFrame++;
uint8_t nType; uint8_t nType;
@ -100,14 +100,14 @@ int ReadFrame(FILE *fp)
} }
case kFrameSound: case kFrameSound:
{ {
DebugOut("Reading sound block size %d...\n", nSize); Printf("Reading sound block size %d...\n", nSize);
// TODO - just skip for now // TODO - just skip for now
fseek(fp, nSize, SEEK_CUR); fseek(fp, nSize, SEEK_CUR);
continue; continue;
} }
case kFrameImage: case kFrameImage:
{ {
DebugOut("Reading image block size %d...\n", nSize); Printf("Reading image block size %d...\n", nSize);
if (nSize == 0) { if (nSize == 0) {
continue; continue;
} }
@ -173,11 +173,11 @@ void PlayMovie(const char *fileName)
FILE *fp = fopen(buffer, "rb"); FILE *fp = fopen(buffer, "rb");
if (fp == NULL) if (fp == NULL)
{ {
DebugOut("Can't open movie file '%s' on CD-ROM\n", buffer); Printf("Can't open movie file '%s' on CD-ROM\n", buffer);
fp = fopen(fileName, "rb"); fp = fopen(fileName, "rb");
if (fp == NULL) if (fp == NULL)
{ {
DebugOut("Can't open movie file on hard drive\n"); Printf("Can't open movie file on hard drive\n");
return; return;
} }
} }

View file

@ -523,7 +523,7 @@ void FuncMummy(int a, int nDamage, int nRun)
default: default:
{ {
DebugOut("unknown msg %d for Mummy\n", a & 0x7F0000); Printf("unknown msg %d for Mummy\n", a & 0x7F0000);
break; break;
} }
} }

View file

@ -21,7 +21,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "typedefs.h" #include "typedefs.h"
#include "network.h" #include "network.h"
#include "serial.h" #include "serial.h"
#include "input.h" #include "ps_input.h"
BEGIN_PS_NS BEGIN_PS_NS

View file

@ -797,7 +797,7 @@ void InitWallFace()
int BuildWallFace(short nChannel, short nWall, short nCount, ...) int BuildWallFace(short nChannel, short nWall, short nCount, ...)
{ {
if (WallFaceCount <= 0) { if (WallFaceCount <= 0) {
bail2dos("Too many wall faces!\n"); I_Error("Too many wall faces!\n");
} }
WallFaceCount--; WallFaceCount--;
@ -898,7 +898,7 @@ int BuildSlide(int nChannel, int edx, int ebx, int ecx, int arg1, int arg2, int
int nVal = ecx; int nVal = ecx;
if (SlideCount <= 0) { if (SlideCount <= 0) {
bail2dos("Too many slides!\n"); I_Error("Too many slides!\n");
return -1; return -1;
} }
@ -1162,7 +1162,7 @@ int BuildTrap(int nSprite, int edx, int ebx, int ecx)
int var_10 = ecx; int var_10 = ecx;
if (nTraps >= kMaxTraps) { if (nTraps >= kMaxTraps) {
bail2dos("Too many traps!\n"); I_Error("Too many traps!\n");
} }
short nTrap = nTraps; short nTrap = nTraps;
@ -1828,7 +1828,7 @@ void FuncEnergyBlock(int a, int nDamage, int nRun)
int BuildObject(short nSprite, int nOjectType, int nHitag) int BuildObject(short nSprite, int nOjectType, int nHitag)
{ {
if (ObjectCount >= kMaxObjects) { if (ObjectCount >= kMaxObjects) {
bail2dos("Too many objects!\n"); I_Error("Too many objects!\n");
} }
short nObject = ObjectCount; short nObject = ObjectCount;
@ -2139,7 +2139,7 @@ FUNCOBJECT_GOTO:
void BuildDrip(int nSprite) void BuildDrip(int nSprite)
{ {
if (nDrips >= kMaxDrips) { if (nDrips >= kMaxDrips) {
bail2dos("Too many drips!\n"); I_Error("Too many drips!\n");
} }
sDrip[nDrips].nSprite = nSprite; sDrip[nDrips].nSprite = nSprite;
@ -2239,7 +2239,7 @@ void SnapBobs(short nSectorA, short nSectorB)
void AddSectorBob(int nSector, int nHitag, int bx) void AddSectorBob(int nSector, int nHitag, int bx)
{ {
if (nBobs >= kMaxBobs) { if (nBobs >= kMaxBobs) {
bail2dos("Too many bobs!\n"); I_Error("Too many bobs!\n");
} }
sBob[nBobs].field_3 = bx; sBob[nBobs].field_3 = bx;
@ -2283,7 +2283,7 @@ int FindTrail(int nVal)
void ProcessTrailSprite(int nSprite, int nLotag, int nHitag) void ProcessTrailSprite(int nSprite, int nLotag, int nHitag)
{ {
if (nTrailPoints >= 100) { if (nTrailPoints >= 100) {
bail2dos("Too many trail point sprites (900-949)... increase MAX_TRAILPOINTS\n"); I_Error("Too many trail point sprites (900-949)... increase MAX_TRAILPOINTS\n");
} }
short nPoint = nTrailPoints; short nPoint = nTrailPoints;
@ -2347,7 +2347,7 @@ void ProcessTrailSprite(int nSprite, int nLotag, int nHitag)
void AddMovingSector(int nSector, int edx, int ebx, int ecx) void AddMovingSector(int nSector, int edx, int ebx, int ecx)
{ {
if (nMoveSects >= kMaxMoveSects) { if (nMoveSects >= kMaxMoveSects) {
bail2dos("Too many moving sectors\n"); I_Error("Too many moving sectors\n");
} }
CreatePushBlock(nSector); CreatePushBlock(nSector);

View file

@ -48,7 +48,7 @@ int osdcmd_restartvid(osdcmdptr_t UNUSED(parm))
UNREFERENCED_CONST_PARAMETER(parm); UNREFERENCED_CONST_PARAMETER(parm);
videoResetMode(); videoResetMode();
if (videoSetGameMode(gSetup.fullscreen,gSetup.xdim,gSetup.ydim,gSetup.bpp,0)) if (videoSetGameMode(gSetup.fullscreen,gSetup.xdim,gSetup.ydim,gSetup.bpp,0))
bail2dos("restartvid: Reset failed...\n"); I_Error("restartvid: Reset failed...\n");
onvideomodechange(gSetup.bpp>8); onvideomodechange(gSetup.bpp>8);
UpdateScreenSize(); UpdateScreenSize();
@ -92,7 +92,7 @@ static int osdcmd_vidmode(osdcmdptr_t parm)
{ {
initprintf("vidmode: Mode change failed!\n"); initprintf("vidmode: Mode change failed!\n");
if (videoSetGameMode(gSetup.fullscreen, gSetup.xdim, gSetup.ydim, gSetup.bpp, upscalefactor)) if (videoSetGameMode(gSetup.fullscreen, gSetup.xdim, gSetup.ydim, gSetup.bpp, upscalefactor))
bail2dos("vidmode: Reset failed!\n"); I_Error("vidmode: Reset failed!\n");
} }
gSetup.bpp = newbpp; gSetup.bpp = newbpp;
gSetup.xdim = newwidth; gSetup.xdim = newwidth;
@ -142,31 +142,6 @@ static int osdcmd_button(osdcmdptr_t parm)
return OSDCMD_OK; return OSDCMD_OK;
} }
static int osdcmd_unbound(osdcmdptr_t parm)
{
if (parm->numparms != 1)
return OSDCMD_OK;
int const gameFunc = CONFIG_FunctionNameToNum(parm->parms[0]);
if (gameFunc != -1)
KeyboardKeys[gameFunc][0] = 0;
return OSDCMD_OK;
}
static int osdcmd_screenshot(osdcmdptr_t parm)
{
// KB_ClearKeysDown();
static const char *fn = "capt0000.png";
if (parm->numparms == 1 && !Bstrcasecmp(parm->parms[0], "tga"))
videoCaptureScreenTGA(fn, 0);
else videoCaptureScreen(fn, 0);
return OSDCMD_OK;
}
static int osdcmd_cvar_set_game(osdcmdptr_t parm) static int osdcmd_cvar_set_game(osdcmdptr_t parm)
{ {
int const r = osdcmd_cvar_set(parm); int const r = osdcmd_cvar_set(parm);
@ -380,36 +355,13 @@ int32_t registerosdcommands(void)
//OSD_RegisterFunction("restartmap", "restartmap: restarts the current map", osdcmd_restartmap); //OSD_RegisterFunction("restartmap", "restartmap: restarts the current map", osdcmd_restartmap);
//OSD_RegisterFunction("restartsound","restartsound: reinitializes the sound system",osdcmd_restartsound); //OSD_RegisterFunction("restartsound","restartsound: reinitializes the sound system",osdcmd_restartsound);
OSD_RegisterFunction("restartvid","restartvid: reinitializes the video mode",osdcmd_restartvid); OSD_RegisterFunction("restartvid","restartvid: reinitializes the video mode",osdcmd_restartvid);
OSD_RegisterFunction("screenshot","screenshot [format]: takes a screenshot.", osdcmd_screenshot);
//OSD_RegisterFunction("spawn","spawn <picnum> [palnum] [cstat] [ang] [x y z]: spawns a sprite with the given properties",osdcmd_spawn); //OSD_RegisterFunction("spawn","spawn <picnum> [palnum] [cstat] [ang] [x y z]: spawns a sprite with the given properties",osdcmd_spawn);
OSD_RegisterFunction("unbound", NULL, osdcmd_unbound);
OSD_RegisterFunction("vidmode","vidmode <xdim> <ydim> <bpp> <fullscreen>: change the video mode",osdcmd_vidmode); OSD_RegisterFunction("vidmode","vidmode <xdim> <ydim> <bpp> <fullscreen>: change the video mode",osdcmd_vidmode);
#ifdef USE_OPENGL
baselayer_osdcmd_vidmode_func = osdcmd_vidmode;
#endif
return 0; return 0;
} }
void GAME_onshowosd(int shown)
{
// G_UpdateScreenArea();
mouseLockToWindow((!shown) + 2);
//osdshown = shown;
// XXX: it's weird to fake a keypress like this.
// if (numplayers == 1 && ((shown && !ud.pause_on) || (!shown && ud.pause_on)))
// KB_KeyDown[sc_Pause] = 1;
}
void GAME_clearbackground(int numcols, int numrows)
{
COMMON_clearbackground(numcols, numrows);
}
END_PS_NS END_PS_NS

View file

@ -31,7 +31,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "bubbles.h" #include "bubbles.h"
#include "random.h" #include "random.h"
#include "ra.h" #include "ra.h"
#include "input.h" #include "ps_input.h"
#include "light.h" #include "light.h"
#include "status.h" #include "status.h"
#include "mouse.h" #include "mouse.h"
@ -194,7 +194,7 @@ void PlayerInterruptKeys()
} }
// JBF: Run key behaviour is selectable // JBF: Run key behaviour is selectable
int const playerRunning = (runkey_mode) ? (BUTTON(gamefunc_Run) | auto_run) : (auto_run ^ BUTTON(gamefunc_Run)); int const playerRunning = (runkey_mode) ? (buttonMap.ButtonDown(gamefunc_Run) | auto_run) : (auto_run ^ buttonMap.ButtonDown(gamefunc_Run));
int const turnAmount = playerRunning ? 12 : 8; int const turnAmount = playerRunning ? 12 : 8;
int const keyMove = playerRunning ? 12 : 6; int const keyMove = playerRunning ? 12 : 6;
constexpr int const analogTurnAmount = 12; constexpr int const analogTurnAmount = 12;
@ -202,7 +202,7 @@ void PlayerInterruptKeys()
int fvel = 0, svel = 0; int fvel = 0, svel = 0;
fix16_t q16avel = 0, q16horz = 0; fix16_t q16avel = 0, q16horz = 0;
if (BUTTON(gamefunc_Strafe)) if (buttonMap.ButtonDown(gamefunc_Strafe))
{ {
static int strafeyaw; static int strafeyaw;
@ -228,12 +228,12 @@ void PlayerInterruptKeys()
svel -= info.dx * keyMove / analogExtent; svel -= info.dx * keyMove / analogExtent;
fvel -= info.dz * keyMove / analogExtent; fvel -= info.dz * keyMove / analogExtent;
if (BUTTON(gamefunc_Strafe)) if (buttonMap.ButtonDown(gamefunc_Strafe))
{ {
if (BUTTON(gamefunc_Turn_Left)) if (buttonMap.ButtonDown(gamefunc_Turn_Left))
svel -= -keyMove; svel -= -keyMove;
if (BUTTON(gamefunc_Turn_Right)) if (buttonMap.ButtonDown(gamefunc_Turn_Right))
svel -= keyMove; svel -= keyMove;
} }
else else
@ -241,14 +241,14 @@ void PlayerInterruptKeys()
static int turn = 0; static int turn = 0;
static int counter = 0; static int counter = 0;
// normal, non strafing movement // normal, non strafing movement
if (BUTTON(gamefunc_Turn_Left)) if (buttonMap.ButtonDown(gamefunc_Turn_Left))
{ {
turn -= 2; turn -= 2;
if (turn < -turnAmount) if (turn < -turnAmount)
turn = -turnAmount; turn = -turnAmount;
} }
else if (BUTTON(gamefunc_Turn_Right)) else if (buttonMap.ButtonDown(gamefunc_Turn_Right))
{ {
turn += 2; turn += 2;
@ -274,16 +274,16 @@ void PlayerInterruptKeys()
q16avel += fix16_from_int(turn<<2); q16avel += fix16_from_int(turn<<2);
} }
if (BUTTON(gamefunc_Strafe_Left)) if (buttonMap.ButtonDown(gamefunc_Strafe_Left))
svel += keyMove; svel += keyMove;
if (BUTTON(gamefunc_Strafe_Right)) if (buttonMap.ButtonDown(gamefunc_Strafe_Right))
svel += -keyMove; svel += -keyMove;
if (BUTTON(gamefunc_Move_Forward)) if (buttonMap.ButtonDown(gamefunc_Move_Forward))
fvel += keyMove; fvel += keyMove;
if (BUTTON(gamefunc_Move_Backward)) if (buttonMap.ButtonDown(gamefunc_Move_Backward))
fvel += -keyMove; fvel += -keyMove;
fvel = clamp(fvel, -12, 12); fvel = clamp(fvel, -12, 12);
@ -312,7 +312,7 @@ void PlayerInterruptKeys()
inita &= kAngleMask; inita &= kAngleMask;
if (BUTTON(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
{ {
nXVel = Cos(inita) * 12; nXVel = Cos(inita) * 12;
nYVel = Sin(inita) * 12; nYVel = Sin(inita) * 12;
@ -324,12 +324,12 @@ void PlayerInterruptKeys()
} }
// loc_18E60 // loc_18E60
if (BUTTON(gamefunc_Move_Forward)) if (buttonMap.ButtonDown(gamefunc_Move_Forward))
{ {
lPlayerXVel += nXVel; lPlayerXVel += nXVel;
lPlayerYVel += nYVel; lPlayerYVel += nYVel;
} }
else if (BUTTON(gamefunc_Move_Backward)) else if (buttonMap.ButtonDown(gamefunc_Move_Backward))
{ {
lPlayerXVel -= nXVel; lPlayerXVel -= nXVel;
lPlayerYVel -= nYVel; lPlayerYVel -= nYVel;
@ -346,10 +346,10 @@ void PlayerInterruptKeys()
} }
if (mouseaiming) if (mouseaiming)
aimmode = BUTTON(gamefunc_Mouseview); aimmode = buttonMap.ButtonDown(gamefunc_Mouseview);
else else
{ {
CONTROL_ClearButton(gamefunc_Mouseview); buttonMap.ClearButton(gamefunc_Mouseview);
aimmode = !aimmode; aimmode = !aimmode;
} }
@ -371,7 +371,7 @@ void PlayerInterruptKeys()
} }
else else
{ {
if (BUTTON(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
{ {
lPlayerXVel += Cos(inita) * ((-info.mousey) >> 7); lPlayerXVel += Cos(inita) * ((-info.mousey) >> 7);
lPlayerYVel += Sin(inita) * ((-info.mousey) >> 7); lPlayerYVel += Sin(inita) * ((-info.mousey) >> 7);
@ -385,33 +385,33 @@ void PlayerInterruptKeys()
} }
// loc_18FD4 // loc_18FD4
if (BUTTON(gamefunc_Strafe_Left)) if (buttonMap.ButtonDown(gamefunc_Strafe_Left))
{ {
lPlayerXVel += nYVel / 4; lPlayerXVel += nYVel / 4;
lPlayerYVel -= nXVel / 4; lPlayerYVel -= nXVel / 4;
} }
else if (BUTTON(gamefunc_Strafe_Right)) else if (buttonMap.ButtonDown(gamefunc_Strafe_Right))
{ {
lPlayerXVel -= nYVel / 4; lPlayerXVel -= nYVel / 4;
lPlayerYVel += nXVel / 4; lPlayerYVel += nXVel / 4;
} }
else else
{ {
if (BUTTON(gamefunc_Strafe)) if (buttonMap.ButtonDown(gamefunc_Strafe))
{ {
if (BUTTON(gamefunc_Turn_Left)) if (buttonMap.ButtonDown(gamefunc_Turn_Left))
{ {
lPlayerXVel += nYVel; lPlayerXVel += nYVel;
lPlayerYVel -= nXVel; lPlayerYVel -= nXVel;
} }
else if (BUTTON(gamefunc_Turn_Right)) else if (buttonMap.ButtonDown(gamefunc_Turn_Right))
{ {
lPlayerXVel -= nYVel; lPlayerXVel -= nYVel;
lPlayerYVel += nXVel; lPlayerYVel += nXVel;
} }
else else
{ {
if (BUTTON(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
{ {
lPlayerXVel -= Sin(inita) * (info.dyaw >> 5); lPlayerXVel -= Sin(inita) * (info.dyaw >> 5);
lPlayerYVel += Sin(inita + 512) * (info.dyaw >> 5); lPlayerYVel += Sin(inita + 512) * (info.dyaw >> 5);
@ -426,11 +426,11 @@ void PlayerInterruptKeys()
else else
{ {
// normal, non strafing movement // normal, non strafing movement
if (BUTTON(gamefunc_Turn_Left)) if (buttonMap.ButtonDown(gamefunc_Turn_Left))
{ {
nPlayerDAng -= 2; nPlayerDAng -= 2;
if (BUTTON(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
{ {
if (nPlayerDAng < -12) if (nPlayerDAng < -12)
nPlayerDAng = -12; nPlayerDAng = -12;
@ -440,11 +440,11 @@ void PlayerInterruptKeys()
nPlayerDAng = -8; nPlayerDAng = -8;
} }
} }
else if (BUTTON(gamefunc_Turn_Right)) else if (buttonMap.ButtonDown(gamefunc_Turn_Right))
{ {
nPlayerDAng += 2; nPlayerDAng += 2;
if (BUTTON(gamefunc_Run)) if (buttonMap.ButtonDown(gamefunc_Run))
{ {
if (nPlayerDAng > 12) if (nPlayerDAng > 12)
nPlayerDAng = 12; nPlayerDAng = 12;
@ -1050,7 +1050,7 @@ void DoKenTest()
} }
if (nextspritesect[i] == i) { if (nextspritesect[i] == i) {
bail2dos("ERROR in Ken's linked list!\n"); I_Error("ERROR in Ken's linked list!\n");
} }
} }
} }
@ -3084,7 +3084,7 @@ do_default_b:
if (nPlayer == nLocalPlayer) if (nPlayer == nLocalPlayer)
{ {
// TODO - tidy / consolidate repeating blocks of code here? // TODO - tidy / consolidate repeating blocks of code here?
if (BUTTON(gamefunc_Look_Up)) if (buttonMap.ButtonDown(gamefunc_Look_Up))
{ {
bLockPan = kFalse; bLockPan = kFalse;
if (nVertPan[nPlayer] < F16(180)) { if (nVertPan[nPlayer] < F16(180)) {
@ -3094,7 +3094,7 @@ do_default_b:
bPlayerPan = kTrue; bPlayerPan = kTrue;
nDestVertPan[nPlayer] = nVertPan[nPlayer]; nDestVertPan[nPlayer] = nVertPan[nPlayer];
} }
else if (BUTTON(gamefunc_Look_Down)) else if (buttonMap.ButtonDown(gamefunc_Look_Down))
{ {
bLockPan = kFalse; bLockPan = kFalse;
if (nVertPan[nPlayer] > F16(4)) { if (nVertPan[nPlayer] > F16(4)) {
@ -3104,14 +3104,14 @@ do_default_b:
bPlayerPan = kTrue; bPlayerPan = kTrue;
nDestVertPan[nPlayer] = nVertPan[nPlayer]; nDestVertPan[nPlayer] = nVertPan[nPlayer];
} }
else if (BUTTON(gamefunc_Look_Straight)) else if (buttonMap.ButtonDown(gamefunc_Look_Straight))
{ {
bLockPan = kFalse; bLockPan = kFalse;
bPlayerPan = kFalse; bPlayerPan = kFalse;
nVertPan[nPlayer] = F16(92); nVertPan[nPlayer] = F16(92);
nDestVertPan[nPlayer] = F16(92); nDestVertPan[nPlayer] = F16(92);
} }
else if (BUTTON(gamefunc_Aim_Up)) else if (buttonMap.ButtonDown(gamefunc_Aim_Up))
{ {
bLockPan = kTrue; bLockPan = kTrue;
if (nVertPan[nPlayer] < F16(180)) { if (nVertPan[nPlayer] < F16(180)) {
@ -3121,7 +3121,7 @@ do_default_b:
bPlayerPan = kTrue; bPlayerPan = kTrue;
nDestVertPan[nPlayer] = nVertPan[nPlayer]; nDestVertPan[nPlayer] = nVertPan[nPlayer];
} }
else if (BUTTON(gamefunc_Aim_Down)) else if (buttonMap.ButtonDown(gamefunc_Aim_Down))
{ {
bLockPan = kTrue; bLockPan = kTrue;
if (nVertPan[nPlayer] > F16(4)) { if (nVertPan[nPlayer] > F16(4)) {

View file

@ -322,7 +322,7 @@ void BuildTail()
tailspr[i] = nTailSprite; tailspr[i] = nTailSprite;
if (nTailSprite < 0) { if (nTailSprite < 0) {
bail2dos("Can't create queen's tail!\n"); I_Error("Can't create queen's tail!\n");
} }
sprite[nTailSprite].lotag = runlist_HeadRun() + 1; sprite[nTailSprite].lotag = runlist_HeadRun() + 1;

View file

@ -23,7 +23,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "player.h" #include "player.h"
#include "move.h" #include "move.h"
#include "sequence.h" #include "sequence.h"
#include "input.h" #include "ps_input.h"
#include "gun.h" #include "gun.h"
#include "bullet.h" #include "bullet.h"
#include <string.h> #include <string.h>
@ -162,7 +162,7 @@ void FuncRa(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Ra\n", a & 0x7F0000); Printf("unknown msg %d for Ra\n", a & 0x7F0000);
return; return;
} }

View file

@ -191,7 +191,7 @@ void FuncRat(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Rathead\n", nMessage); Printf("unknown msg %d for Rathead\n", nMessage);
return; return;
} }

View file

@ -145,7 +145,7 @@ void FuncRex(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Rex\n", a & 0x7F0000); Printf("unknown msg %d for Rex\n", a & 0x7F0000);
return; return;
} }

View file

@ -150,7 +150,7 @@ void FuncRoach(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Roach\n", a & 0x7F0000); Printf("unknown msg %d for Roach\n", a & 0x7F0000);
return; return;
} }

View file

@ -347,7 +347,7 @@ void runlist_PushMoveRun(int eax)
int runlist_PopMoveRun() int runlist_PopMoveRun()
{ {
if (nStackCount <= 0) { if (nStackCount <= 0) {
bail2dos("PopMoveRun() called inappropriately\n"); I_Error("PopMoveRun() called inappropriately\n");
} }
nStackCount--; nStackCount--;

View file

@ -142,7 +142,7 @@ void FuncScorp(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Scorp\n", a & 0x7F0000); Printf("unknown msg %d for Scorp\n", a & 0x7F0000);
return; return;
} }

View file

@ -198,7 +198,7 @@ int seq_ReadSequence(const char *seqName)
return 0; return 0;
} }
else { else {
bail2dos("Not enough sequences available! Increase array!\n"); I_Error("Not enough sequences available! Increase array!\n");
} }
} }
@ -225,7 +225,7 @@ int seq_ReadSequence(const char *seqName)
return 0; return 0;
} }
else { else {
bail2dos("Not enough frames available! Increase FRAMEMAX!\n"); I_Error("Not enough frames available! Increase FRAMEMAX!\n");
} }
} }
@ -251,7 +251,7 @@ int seq_ReadSequence(const char *seqName)
return 0; return 0;
} }
else { else {
bail2dos("Not enough chunks available! Increase CHUNKMAX!\n"); I_Error("Not enough chunks available! Increase CHUNKMAX!\n");
} }
} }

View file

@ -219,7 +219,7 @@ void FuncSoul(int pA, int, int nRun)
return; return;
default: default:
DebugOut("unknown msg %d for Soul\n", nMessage); Printf("unknown msg %d for Soul\n", nMessage);
} }
} }
@ -239,7 +239,7 @@ void FuncSet(int a, int nDamage, int nRun)
{ {
default: default:
{ {
DebugOut("unknown msg %d for Set\n", nMessage); Printf("unknown msg %d for Set\n", nMessage);
return; return;
} }

View file

@ -24,7 +24,7 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#include "runlist.h" #include "runlist.h"
#include "sequence.h" #include "sequence.h"
#include "bullet.h" #include "bullet.h"
#include "input.h" #include "ps_input.h"
#include "anims.h" #include "anims.h"
#include "lighting.h" #include "lighting.h"
#include "sound.h" #include "sound.h"
@ -419,7 +419,7 @@ SEARCH_ENEMY:
default: default:
{ {
DebugOut("unknown msg %x for bullet\n", a & 0x7F0000); Printf("unknown msg %x for bullet\n", a & 0x7F0000);
break; break;
} }
} }

View file

@ -350,9 +350,9 @@ void InitFX(void)
if (FX_Init(NumVoices, NumChannels, MixRate, initdata) != FX_Ok) if (FX_Init(NumVoices, NumChannels, MixRate, initdata) != FX_Ok)
{ {
DebugOut("Error initializing sound card!\n"); Printf("Error initializing sound card!\n");
initprintf("Error initializing sound card!\n"); initprintf("Error initializing sound card!\n");
DebugOut("ERROR: %s\n", FX_ErrorString(FX_Error)); Printf("ERROR: %s\n", FX_ErrorString(FX_Error));
return; return;
} }
@ -491,7 +491,7 @@ int LoadSound(const char *sound)
} }
if (i >= kMaxSounds) if (i >= kMaxSounds)
bail2dos("Too many sounds being loaded... increase array size\n"); I_Error("Too many sounds being loaded... increase array size\n");
strncpy(szSoundName[i], sound, kMaxSoundNameLen); strncpy(szSoundName[i], sound, kMaxSoundNameLen);
@ -515,14 +515,14 @@ int LoadSound(const char *sound)
SoundLen[i] = nSize; SoundLen[i] = nSize;
g_cache.allocateBlock((intptr_t*)&SoundBuf[i], nSize, &SoundLock[i]); g_cache.allocateBlock((intptr_t*)&SoundBuf[i], nSize, &SoundLock[i]);
if (!SoundBuf[i]) if (!SoundBuf[i])
bail2dos("Error allocating buf '%s' to %lld (size=%ld)!\n", buffer, (intptr_t)&SoundBuf[i], nSize); I_Error("Error allocating buf '%s' to %lld (size=%ld)!\n", buffer, (intptr_t)&SoundBuf[i], nSize);
if (kread(hVoc, SoundBuf[i], nSize) != nSize) if (kread(hVoc, SoundBuf[i], nSize) != nSize)
bail2dos("Error reading '%s'!\n", buffer); I_Error("Error reading '%s'!\n", buffer);
} }
else else
{ {
bail2dos("Unable to open sound '%s'!\n", buffer); I_Error("Unable to open sound '%s'!\n", buffer);
SoundBuf[i] = NULL; SoundBuf[i] = NULL;
SoundLen[i] = 0; SoundLen[i] = 0;
//return hVoc; //return hVoc;
@ -552,7 +552,7 @@ void LoadFX(void)
{ {
StaticSound[i] = LoadSound(SoundFiles[i]); StaticSound[i] = LoadSound(SoundFiles[i]);
if (StaticSound[i] < 0) if (StaticSound[i] < 0)
bail2dos("error loading static sound #%d ('%.8s')\n", i, SoundFiles[i]); I_Error("error loading static sound #%d ('%.8s')\n", i, SoundFiles[i]);
} }
} }

View file

@ -429,7 +429,7 @@ case_3:
default: default:
{ {
DebugOut("unknown msg %d for Spider\n", a & 0x7F0000); Printf("unknown msg %d for Spider\n", a & 0x7F0000);
break; break;
} }
} }

View file

@ -152,7 +152,7 @@ void RefreshStatus()
{ {
short nLives = nPlayerLives[nLocalPlayer]; short nLives = nPlayerLives[nLocalPlayer];
if (nLives < 0 || nLives > kMaxPlayerLives) { if (nLives < 0 || nLives > kMaxPlayerLives) {
bail2dos("illegal value for nPlayerLives #%d\n", nLocalPlayer); I_Error("illegal value for nPlayerLives #%d\n", nLocalPlayer);
} }
// draws the red dots that indicate the lives amount // draws the red dots that indicate the lives amount

View file

@ -97,7 +97,7 @@ void InitSwitch()
int BuildSwReady(int nChannel, short nLink) int BuildSwReady(int nChannel, short nLink)
{ {
if (SwitchCount <= 0 || nLink < 0) { if (SwitchCount <= 0 || nLink < 0) {
bail2dos("Too many switch readys!\n"); I_Error("Too many switch readys!\n");
return -1; return -1;
} }
@ -149,7 +149,7 @@ int BuildSwPause(int nChannel, int nLink, int ebx)
} }
if (SwitchCount <= 0 || nLink < 0) { if (SwitchCount <= 0 || nLink < 0) {
bail2dos("Too many switches!\n"); I_Error("Too many switches!\n");
return -1; return -1;
} }
@ -240,7 +240,7 @@ void FuncSwPause(int a, int, int nRun)
int BuildSwStepOn(int nChannel, int nLink, int nSector) int BuildSwStepOn(int nChannel, int nLink, int nSector)
{ {
if (SwitchCount <= 0 || nLink < 0 || nSector < 0) if (SwitchCount <= 0 || nLink < 0 || nSector < 0)
bail2dos("Too many switches!\n"); I_Error("Too many switches!\n");
int nSwitch = --SwitchCount; int nSwitch = --SwitchCount;
@ -309,7 +309,7 @@ void FuncSwStepOn(int a, int, int nRun)
int BuildSwNotOnPause(int nChannel, int nLink, int nSector, int ecx) int BuildSwNotOnPause(int nChannel, int nLink, int nSector, int ecx)
{ {
if (SwitchCount <= 0 || nLink < 0 || nSector < 0) if (SwitchCount <= 0 || nLink < 0 || nSector < 0)
bail2dos("Too many switches!\n"); I_Error("Too many switches!\n");
int nSwitch = --SwitchCount; int nSwitch = --SwitchCount;
@ -399,7 +399,7 @@ void FuncSwNotOnPause(int a, int, int nRun)
int BuildSwPressSector(int nChannel, int nLink, int nSector, int ecx) int BuildSwPressSector(int nChannel, int nLink, int nSector, int ecx)
{ {
if (SwitchCount <= 0 || nLink < 0 || nSector < 0) if (SwitchCount <= 0 || nLink < 0 || nSector < 0)
bail2dos("Too many switches!\n"); I_Error("Too many switches!\n");
int nSwitch = --SwitchCount; int nSwitch = --SwitchCount;
@ -471,7 +471,7 @@ void FuncSwPressSector(int a, int, int nRun)
int BuildSwPressWall(short nChannel, short nLink, short nWall) int BuildSwPressWall(short nChannel, short nLink, short nWall)
{ {
if (SwitchCount <= 0 || nLink < 0 || nWall < 0) { if (SwitchCount <= 0 || nLink < 0 || nWall < 0) {
bail2dos("Too many switches!\n"); I_Error("Too many switches!\n");
} }
SwitchCount--; SwitchCount--;

View file

@ -28,6 +28,9 @@ CRC
RR_CRC 0x19D9BC79 RR_CRC 0x19D9BC79
RRRA_CRC 0x958018C6 RRRA_CRC 0x958018C6
BLOOD_CRC 0xA8FDDA84 BLOOD_CRC 0xA8FDDA84
POWERSLAVE_CRC 0x303CBD89
EXHUMED_CRC 0xE3B172F1
} }
@ -372,3 +375,23 @@ grpinfo
defname "sw.def" defname "sw.def"
gamefilter "ShadowWarrior.ShadowWarrior" gamefilter "ShadowWarrior.ShadowWarrior"
} }
grpinfo
{
name "Powerslave"
flags GAMEFLAG_POWERSLAVE
crc POWERSLAVE_CRC
size 27020745
defname "exhumed.def"
gamefilter "Exhumed.Powerslave"
}
grpinfo
{
name "Exhumed"
flags GAMEFLAG_EXHUMED
crc EXHUMED_CRC
size 27108170
defname "exhumed.def"
gamefilter "Exhumed.Exhumed"
}

View file

@ -0,0 +1,66 @@
W "+Move_Forward"
KP8 "+Move_Forward"
S "+Move_Backward"
KP2 "+Move_Backward"
leftarrow "+Turn_Left"
KP4 "+Turn_Left"
rightarrow "+Turn_Right"
KP6 "+Turn_Right"
LAlt "+Strafe"
RAlt "+Strafe"
RCtrl "+Fire"
E "+Open"
LShift "+Run"
RShift "+Run"
Space "+Jump"
/ "+Jump"
LCtrl "+Crouch"
PgUp "+Look_Up"
KP9 "+Look_Up"
PgDn "+Look_Down"
KP3 "+Look_Down"
Ins "+Look_Left"
KP0 "+Look_Left"
Del "+Look_Right"
KP. "+Look_Right"
A "+Strafe_Left"
D "+Strafe_Right"
Home "+Aim_Up"
KP7 "+Aim_Up"
End "+Aim_Down"
KP1 "+Aim_Down"
1 "+Weapon_1"
2 "+Weapon_2"
3 "+Weapon_3"
4 "+Weapon_4"
5 "+Weapon_5"
6 "+Weapon_6"
7 "+Weapon_7"
Enter "+Inventory"
KP-Enter "+Inventory"
[ "+Inventory_Left"
] "+Inventory_Right"
Backspace "+Turn_Around"
T "+Send_Message"
Tab "+Map"
- "+Shrink_Screen"
KP- "+Shrink_Screen"
= "+Enlarge_Screen"
KP+ "+Enlarge_Screen"
KP5 "+Center_View"
Scroll "+Holster_Weapon"
Y "+Show_Opponents_Weapon"
F "+Map_Follow_Mode"
K "+See_Coop_View"
' "+Next_Weapon"
; "+Previous_Weapon"
` "toggleconsole"
Capslock "+AutoRun"
X "+Last_Used_Weapon"
F6 "+Quick_Save"
F9 "+Quick_Load"
F7 "+Third_Person_View"
C "+Toggle_Crouch"
Mouse1 "+Fire"
Mouse2 "+Strafe"
Mouse3 "+Move_Forward"

View file

@ -0,0 +1,64 @@
uparrow "+Move_Forward"
KP8 "+Move_Forward"
downarrow "+Move_Backward"
KP2 "+Move_Backward"
leftarrow "+Turn_Left"
KP4 "+Turn_Left"
rightarrow "+Turn_Right"
KP6 "+Turn_Right"
LAlt "+Strafe"
RAlt "+Strafe"
LCtrl "+Fire"
RCtrl "+Fire"
Space "+Open"
LShift "+Run"
RShift "+Run"
A "+Jump"
KP- "+Jump"
Z "+Crouch"
PgUp "+Look_Up"
PgDn "+Look_Down"
Ins "+Look_Left"
Del "+Look_Right"
, "+Strafe_Left"
KP7 "+Strafe_Left"
. "+Strafe_Right"
KP9 "+Strafe_Right"
Home "+Aim_Up"
End "+Aim_Down"
1 "+Weapon_1"
2 "+Weapon_2"
3 "+Weapon_3"
4 "+Weapon_4"
5 "+Weapon_5"
6 "+Weapon_6"
7 "+Weapon_7"
Enter "+Inventory"
KP-Enter "+Inventory"
[ "+Inventory_Left"
] "+Inventory_Right"
Backspace "+Turn_Around"
T "+Send_Message"
Tab "+Map"
- "+Shrink_Screen"
= "+Enlarge_Screen"
//Scroll "+Holster_Weapon"
//W "+Show_Opponents_Weapon"
F "+Map_Follow_Mode"
K "+See_Coop_View"
U "+Mouse_Aiming"
I "+Toggle_Crosshair"
//R "+Steroids"
//Q "+Quick_Kick"
' "+Next_Weapon"
; "+Previous_Weapon"
` "toggleconsole"
Capslock "+AutoRun"
F6 "+Quick_Save"
F9 "+Quick_Load"
F7 "+Third_Person_View"
Mouse1 "+Fire"
Mouse2 "+Open"
Mouse3 "+Run"
MWheelUp "+Previous_Weapon"
MWheelDown "+Next_Weapon"

View file

@ -0,0 +1,69 @@
uparrow "+Move_Forward"
KP8 "+Move_Forward"
downarrow "+Move_Backward"
KP2 "+Move_Backward"
leftarrow "+Turn_Left"
KP4 "+Turn_Left"
rightarrow "+Turn_Right"
KP6 "+Turn_Right"
LAlt "+Strafe"
RAlt "+Strafe"
LCtrl "+Fire"
RCtrl "+Fire"
Space "+Open"
LShift "+Run"
RShift "+Run"
A "+Jump"
/ "+Jump"
Z "+Crouch"
PgUp "+Look_Up"
KP9 "+Look_Up"
PgDn "+Look_Down"
KP3 "+Look_Down"
Ins "+Look_Left"
KP0 "+Look_Left"
Del "+Look_Right"
KP. "+Look_Right"
, "+Strafe_Left"
. "+Strafe_Right"
Home "+Aim_Up"
KP7 "+Aim_Up"
End "+Aim_Down"
KP1 "+Aim_Down"
1 "+Weapon_1"
2 "+Weapon_2"
3 "+Weapon_3"
4 "+Weapon_4"
5 "+Weapon_5"
6 "+Weapon_6"
7 "+Weapon_7"
Enter "+Inventory"
KP-Enter "+Inventory"
[ "+Inventory_Left"
] "+Inventory_Right"
Backspace "+Turn_Around"
T "+Send_Message"
Tab "+Map"
- "+Shrink_Screen"
KP- "+Shrink_Screen"
= "+Enlarge_Screen"
KP+ "+Enlarge_Screen"
KP5 "+Center_View"
//Scroll "+Holster_Weapon"
//W "+Show_Opponents_Weapon"
F "+Map_Follow_Mode"
K "+See_Coop_View"
U "+Mouse_Aiming"
I "+Toggle_Crosshair"
//R "+Steroids"
//` "+Quick_Kick"
' "+Next_Weapon"
; "+Previous_Weapon"
` "toggleconsole"
Capslock "+AutoRun"
F6 "+Quick_Save"
F9 "+Quick_Load"
F7 "+Third_Person_View"
Mouse1 "+Fire"
Mouse2 "+Strafe"
Mouse3 "+Move_Forward"