summaryrefslogtreecommitdiff
path: root/src/hexen
diff options
context:
space:
mode:
Diffstat (limited to 'src/hexen')
-rw-r--r--src/hexen/h2_main.c224
-rw-r--r--src/hexen/p_setup.c13
2 files changed, 142 insertions, 95 deletions
diff --git a/src/hexen/h2_main.c b/src/hexen/h2_main.c
index 7b7a8168..33d345e8 100644
--- a/src/hexen/h2_main.c
+++ b/src/hexen/h2_main.c
@@ -63,16 +63,6 @@
#define CT_KEY_PLAYER8 'p' // Purple
#define CT_KEY_ALL 't'
-// TYPES -------------------------------------------------------------------
-
-typedef struct
-{
- char *name;
- void (*func) (char **args, int tag);
- int requiredArgs;
- int tag;
-} execOpt_t;
-
// EXTERNAL FUNCTION PROTOTYPES --------------------------------------------
void R_ExecuteSetViewSize(void);
@@ -99,10 +89,6 @@ static void PageDrawer(void);
static void HandleArgs(void);
static void CheckRecordFrom(void);
static void DrawAndBlit(void);
-static void ExecOptionSCRIPTS(char **args, int tag);
-static void ExecOptionSKILL(char **args, int tag);
-static void ExecOptionPLAYDEMO(char **args, int tag);
-static void ExecOptionTestControls(char **args, int tag);
static void CreateSavePath(void);
static void WarpCheck(void);
@@ -142,15 +128,6 @@ static int demosequence;
static int pagetic;
static char *pagename;
-static execOpt_t ExecOptions[] = {
- {"-scripts", ExecOptionSCRIPTS, 1, 0},
- {"-skill", ExecOptionSKILL, 1, 0},
- {"-playdemo", ExecOptionPLAYDEMO, 1, 0},
- {"-timedemo", ExecOptionPLAYDEMO, 1, 0},
- {"-testcontrols", ExecOptionTestControls, 0, 0},
- {NULL, NULL, 0, 0} // Terminator
-};
-
// CODE --------------------------------------------------------------------
void D_BindVariables(void)
@@ -397,23 +374,30 @@ void D_DoomMain(void)
H2_GameLoop(); // Never returns
}
- p = M_CheckParm("-playdemo");
- if (p && p < myargc - 1)
+ p = M_CheckParmWithArgs("-playdemo", 1);
+ if (p)
{
singledemo = true; // Quit after one demo
G_DeferedPlayDemo(myargv[p + 1]);
H2_GameLoop(); // Never returns
}
- p = M_CheckParm("-timedemo");
- if (p && p < myargc - 1)
+ p = M_CheckParmWithArgs("-timedemo", 1);
+ if (p)
{
G_TimeDemo(myargv[p + 1]);
H2_GameLoop(); // Never returns
}
- p = M_CheckParm("-loadgame");
- if (p && p < myargc - 1)
+ //!
+ // @arg <s>
+ // @vanilla
+ //
+ // Load the game in savegame slot s.
+ //
+
+ p = M_CheckParmWithArgs("-loadgame", 1);
+ if (p)
{
G_LoadGame(atoi(myargv[p + 1]));
}
@@ -444,29 +428,141 @@ void D_DoomMain(void)
static void HandleArgs(void)
{
int p;
- execOpt_t *opt;
+
+ //!
+ // @vanilla
+ //
+ // Disable monsters.
+ //
nomonsters = M_ParmExists("-nomonsters");
+
+ //!
+ // @vanilla
+ //
+ // Monsters respawn after being killed.
+ //
+
respawnparm = M_ParmExists("-respawn");
+
+ //!
+ // @vanilla
+ // @category net
+ //
+ // In deathmatch mode, change a player's class each time the
+ // player respawns.
+ //
+
randomclass = M_ParmExists("-randclass");
+
+ //!
+ // @vanilla
+ //
+ // Take screenshots when F1 is pressed.
+ //
+
ravpic = M_ParmExists("-ravpic");
+
+ //!
+ // @vanilla
+ //
+ // Don't allow artifacts to be used when the run key is held down.
+ //
+
artiskip = M_ParmExists("-artiskip");
+
debugmode = M_ParmExists("-debug");
+
+ //!
+ // @vanilla
+ // @category net
+ //
+ // Start a deathmatch game.
+ //
+
deathmatch = M_ParmExists("-deathmatch");
+ // currently broken or unused:
cmdfrag = M_ParmExists("-cmdfrag");
// Check WAD file command line options
W_ParseCommandLine();
- // Process command line options
- for (opt = ExecOptions; opt->name != NULL; opt++)
+ //!
+ // @vanilla
+ // @arg <path>
+ //
+ // Development option to specify path to level scripts.
+ //
+
+ p = M_CheckParmWithArgs("-scripts", 1);
+
+ if (p)
{
- p = M_CheckParm(opt->name);
- if (p && p < myargc - opt->requiredArgs)
+ sc_FileScripts = true;
+ sc_ScriptsDir = myargv[p+1];
+ }
+
+ //!
+ // @arg <skill>
+ // @vanilla
+ //
+ // Set the game skill, 1-5 (1: easiest, 5: hardest). A skill of
+ // 0 disables all monsters.
+ //
+
+ p = M_CheckParmWithArgs("-skill", 1);
+
+ if (p)
+ {
+ startskill = myargv[p+1][0] - '1';
+ autostart = true;
+ }
+
+ //!
+ // @arg <demo>
+ // @category demo
+ // @vanilla
+ //
+ // Play back the demo named demo.lmp.
+ //
+
+ p = M_CheckParmWithArgs("-playdemo", 1);
+
+ if (!p)
+ {
+ //!
+ // @arg <demo>
+ // @category demo
+ // @vanilla
+ //
+ // Play back the demo named demo.lmp, determining the framerate
+ // of the screen.
+ //
+
+ p = M_CheckParmWithArgs("-timedemo", 1);
+ }
+
+ if (p)
+ {
+ char file[256];
+
+ strncpy(file, myargv[p+1], sizeof(file));
+ file[sizeof(file) - 6] = '\0';
+
+ if (strcasecmp(file + strlen(file) - 4, ".lmp") != 0)
{
- opt->func(&myargv[p], opt->tag);
+ strcat(file, ".lmp");
}
+
+ W_AddFile(file);
+ ST_Message("Playing demo %s.\n", file);
+ }
+
+ if (M_ParmExists("-testcontrols"))
+ {
+ autostart = true;
+ testcontrols = true;
}
}
@@ -510,64 +606,6 @@ static void WarpCheck(void)
//==========================================================================
//
-// ExecOptionSKILL
-//
-//==========================================================================
-
-static void ExecOptionSKILL(char **args, int tag)
-{
- startskill = args[1][0] - '1';
- autostart = true;
-}
-
-//==========================================================================
-//
-// ExecOptionPLAYDEMO
-//
-//==========================================================================
-
-static void ExecOptionPLAYDEMO(char **args, int tag)
-{
- char file[256];
-
- strcpy(file, args[1]);
-
- if (strcasecmp(file + strlen(file) - 4, ".lmp") != 0)
- {
- strcat(file, ".lmp");
- }
-
- W_AddFile(file);
- ST_Message("Playing demo %s.\n", file);
-}
-
-//==========================================================================
-//
-// ExecOptionTestControls
-//
-//==========================================================================
-
-static void ExecOptionTestControls(char **args, int tag)
-{
- autostart = true;
- testcontrols = true;
-}
-
-//==========================================================================
-//
-// ExecOptionSCRIPTS
-//
-//==========================================================================
-
-static void ExecOptionSCRIPTS(char **args, int tag)
-{
- sc_FileScripts = true;
- sc_ScriptsDir = args[1];
-}
-
-
-//==========================================================================
-//
// H2_GameLoop
//
//==========================================================================
diff --git a/src/hexen/p_setup.c b/src/hexen/p_setup.c
index 1d7c943a..57c4ab8c 100644
--- a/src/hexen/p_setup.c
+++ b/src/hexen/p_setup.c
@@ -747,8 +747,17 @@ void P_SetupLevel(int episode, int map, int playermask, skill_t skill)
P_RemoveMobj(mobj);
}
}
- parm = M_CheckParm("-timer");
- if (parm && parm < myargc - 1)
+
+ //!
+ // @arg <n>
+ // @category net
+ // @vanilla
+ //
+ // For multiplayer games: exit each level after n minutes.
+ //
+
+ parm = M_CheckParmWithArgs("-timer", 1);
+ if (parm)
{
TimerGame = atoi(myargv[parm + 1]) * 35 * 60;
}