mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
- making more things compile.
This commit is contained in:
parent
6280b0b516
commit
40772d9f0c
50 changed files with 402 additions and 2116 deletions
|
@ -408,6 +408,8 @@ FStringCVar* const CombatMacros[] = { &combatmacro0, &combatmacro1, &combatmacro
|
||||||
void CONFIG_ReadCombatMacros()
|
void CONFIG_ReadCombatMacros()
|
||||||
{
|
{
|
||||||
FScanner sc;
|
FScanner sc;
|
||||||
|
try
|
||||||
|
{
|
||||||
sc.Open("demolition/combatmacros.txt");
|
sc.Open("demolition/combatmacros.txt");
|
||||||
for (auto s : CombatMacros)
|
for (auto s : CombatMacros)
|
||||||
{
|
{
|
||||||
|
@ -416,6 +418,11 @@ void CONFIG_ReadCombatMacros()
|
||||||
*s = sc.String;
|
*s = sc.String;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
catch (const std::runtime_error &)
|
||||||
|
{
|
||||||
|
// We do not want this to error out. Just ignore if it fails.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//==========================================================================
|
//==========================================================================
|
||||||
//
|
//
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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";
|
||||||
|
|
||||||
|
|
|
@ -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)));
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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++)
|
int CONFIG_ReadSetup(void)
|
||||||
{
|
{
|
||||||
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()
|
|
||||||
{
|
|
||||||
char tempbuf[1024];
|
|
||||||
|
|
||||||
CONTROL_ClearAssignments();
|
|
||||||
CONFIG_SetDefaults();
|
CONFIG_SetDefaults();
|
||||||
|
if (ScreenBPP < 8) ScreenBPP = 32;
|
||||||
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;
|
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
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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,21 +566,11 @@ 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);
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
|
|
@ -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
|
|
|
@ -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"
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)) {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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--;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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--;
|
||||||
|
|
|
@ -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"
|
||||||
|
}
|
||||||
|
|
66
wadsrc/static/filter/exhumed/demolition/defbinds.txt
Normal file
66
wadsrc/static/filter/exhumed/demolition/defbinds.txt
Normal 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"
|
64
wadsrc/static/filter/exhumed/demolition/leftbinds.txt
Normal file
64
wadsrc/static/filter/exhumed/demolition/leftbinds.txt
Normal 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"
|
69
wadsrc/static/filter/exhumed/demolition/origbinds.txt
Normal file
69
wadsrc/static/filter/exhumed/demolition/origbinds.txt
Normal 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"
|
Loading…
Reference in a new issue