From 762f1747436ce8dd76556a8ff007af24b7b2c646 Mon Sep 17 00:00:00 2001 From: Christoph Oelckers Date: Mon, 28 Oct 2019 22:19:50 +0100 Subject: [PATCH] - moved the command line parser out of the game frontends. Some part are not done yet, and the file system data is currently ignored - there's no way to properly set this up with the file system code Build came with. --- source/blood/src/asound.cpp | 2 +- source/blood/src/blood.cpp | 277 +--------------- source/blood/src/blood.h | 1 - source/blood/src/config.cpp | 1 - source/blood/src/config.h | 1 - source/blood/src/gamedefs.h | 44 --- source/blood/src/menu.cpp | 4 +- source/blood/src/osdcmd.cpp | 2 +- source/blood/src/sfx.cpp | 6 +- source/blood/src/sound.cpp | 8 +- source/build/src/common.cpp | 14 + source/build/src/sdlayer.cpp | 4 - source/common/gamecontrol.cpp | 158 +++++++++- source/common/gamecontrol.h | 43 +++ source/common/utility/m_argv.cpp | 27 +- source/common/utility/m_argv.h | 2 + source/duke3d/src/cmdline.cpp | 522 +------------------------------ source/duke3d/src/cmdline.h | 4 - source/duke3d/src/config.cpp | 13 + source/duke3d/src/game.cpp | 21 +- source/duke3d/src/gamedefs.h | 39 --- source/duke3d/src/global.cpp | 3 - source/duke3d/src/global.h | 1 - source/duke3d/src/menus.cpp | 2 +- source/duke3d/src/osdcmds.cpp | 2 +- source/duke3d/src/premap.cpp | 2 +- source/duke3d/src/savegame.cpp | 2 +- source/duke3d/src/screens.cpp | 4 +- source/duke3d/src/sector.cpp | 2 +- source/duke3d/src/sounds.cpp | 6 +- source/rr/src/cmdline.cpp | 496 +---------------------------- source/rr/src/cmdline.h | 4 - source/rr/src/game.cpp | 21 +- source/rr/src/gamedefs.h | 43 --- source/rr/src/global.cpp | 2 - source/rr/src/global.h | 1 - source/rr/src/menus.cpp | 24 +- source/rr/src/osdcmds.cpp | 2 +- source/rr/src/premap.cpp | 2 +- source/rr/src/savegame.cpp | 2 +- source/rr/src/screens.cpp | 6 +- source/rr/src/sector.cpp | 2 +- source/rr/src/sounds.cpp | 6 +- source/sw/src/game.cpp | 11 +- source/sw/src/menus.cpp | 4 +- source/sw/src/serp.cpp | 3 +- source/sw/src/sounds.cpp | 8 +- source/sw/src/sumo.cpp | 9 +- source/sw/src/zilla.cpp | 3 +- 49 files changed, 337 insertions(+), 1529 deletions(-) delete mode 100644 source/blood/src/gamedefs.h diff --git a/source/blood/src/asound.cpp b/source/blood/src/asound.cpp index c8c791401..8072e8884 100644 --- a/source/blood/src/asound.cpp +++ b/source/blood/src/asound.cpp @@ -54,7 +54,7 @@ int nAmbChannels = 0; void ambProcess(void) { - if (!snd_enabled) + if (!SoundEnabled()) return; for (int nSprite = headspritestat[kStatAmbience]; nSprite >= 0; nSprite = nextspritestat[nSprite]) { diff --git a/source/blood/src/blood.cpp b/source/blood/src/blood.cpp index 7154e0276..6b5489e2e 100644 --- a/source/blood/src/blood.cpp +++ b/source/blood/src/blood.cpp @@ -31,7 +31,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "fx_man.h" #include "common.h" #include "common_game.h" -#include "gamedefs.h" #include "asound.h" #include "db.h" @@ -87,7 +86,6 @@ BEGIN_BLD_NS extern const char* G_DefaultDefFile(void); extern const char* G_DefFile(void); -char SetupFilename[BMAX_PATH] = SETUPFILENAME; int32_t gNoSetup = 0, gCommandSetup = 0; INPUT_MODE gInputMode; @@ -1088,167 +1086,36 @@ void ProcessFrame(void) } } + +#if 0 SWITCH switches[] = { - { "?", 0, 0 }, - { "help", 0, 0 }, { "broadcast", 1, 0 }, - { "map", 2, 1 }, { "masterslave", 3, 0 }, - //{ "net", 4, 1 }, - { "nodudes", 5, 1 }, - { "playback", 6, 1 }, { "record", 7, 1 }, { "robust", 8, 0 }, - { "setupfile", 9, 1 }, { "skill", 10, 1 }, - //{ "nocd", 11, 0 }, - //{ "8250", 12, 0 }, { "ini", 13, 1 }, - { "noaim", 14, 0 }, { "f", 15, 1 }, { "control", 16, 1 }, { "vector", 17, 1 }, - { "quick", 18, 0 }, - //{ "getopt", 19, 1 }, - //{ "auto", 20, 1 }, - { "pname", 21, 1 }, { "noresend", 22, 0 }, { "silentaim", 23, 0 }, - { "nodemo", 25, 0 }, { "art", 26, 1 }, - { "snd", 27, 1 }, - { "rff", 28, 1 }, -#ifdef USE_QHEAP - { "maxalloc", 29, 1 }, -#endif - { "server", 30, 1 }, { "client", 31, 1 }, { "noautoload", 32, 0 }, - { "usecwd", 33, 0 }, - { "cachesize", 34, 1 }, - { "g", 35, 1 }, - { "grp", 35, 1 }, - { "game_dir", 36, 1 }, - { "cfg", 9, 1 }, - { "setup", 37, 0 }, - { "nosetup", 38, 0 }, - { "port", 39, 1 }, - { "h", 40, 1 }, - { "mh", 41, 1 }, - { "j", 42, 1 }, - { "c", 43, 1 }, - { "conf", 43, 1 }, - { "game", 44, 1 }, - { "noconsole", 43, 0 }, { NULL, 0, 0 } }; - -void PrintHelp(void) -{ - char tempbuf[128]; - static char const s[] = "Usage: " APPBASENAME " [files] [options]\n" - "Example: " APPBASENAME " -usecwd -cfg myconfig.cfg -map nukeland.map\n\n" - "Files can be of type [grp|zip|map|def]\n" - "\n" - "-art [file.art]\tSpecify an art base file name\n" - "-cachesize #\tSet cache size in kB\n" - "-cfg [file.cfg]\tUse an alternate configuration file\n" - "-client [host]\tConnect to a multiplayer game\n" - "-game_dir [dir]\tSpecify game data directory\n" - "-g [file.grp]\tLoad additional game data\n" - "-h [file.def]\tLoad an alternate definitions file\n" - "-ini [file.ini]\tSpecify an INI file name (default is blood.ini)\n" - "-j [dir]\t\tAdd a directory to " APPNAME "'s search list\n" - "-map [file.map]\tLoad an external map file\n" - "-mh [file.def]\tInclude an additional definitions module\n" - "-noautoload\tDisable loading from autoload directory\n" - "-nodemo\t\tNo Demos\n" - "-nodudes\tNo monsters\n" - "-playback\tPlay back a demo\n" - "-pname\t\tOverride player name setting from config file\n" - "-record\t\tRecord demo\n" - "-rff\t\tSpecify an RFF file for Blood game resources\n" - "-server [players]\tStart a multiplayer server\n" -#ifdef STARTUP_SETUP_WINDOW - "-setup/nosetup\tEnable or disable startup window\n" #endif - "-skill\t\tSet player handicap; Range:0..4; Default:2; (NOT difficulty level.)\n" - "-snd\t\tSpecify an RFF Sound file name\n" - "-usecwd\t\tRead data and configuration from current directory\n" - ; -#ifdef WM_MSGBOX_WINDOW - Bsnprintf(tempbuf, sizeof(tempbuf), APPNAME " %s", s_buildRev); - wm_msgbox(tempbuf, s); -#else - initprintf("%s\n", s); -#endif -#if 0 - puts("Blood Command-line Options:"); - // NUKE-TODO: - puts("-? This help"); - //puts("-8250 Enforce obsolete UART I/O"); - //puts("-auto Automatic Network start. Implies -quick"); - //puts("-getopt Use network game options from file. Implies -auto"); - puts("-broadcast Set network to broadcast packet mode"); - puts("-masterslave Set network to master/slave packet mode"); - //puts("-net Net mode game"); - //puts("-noaim Disable auto-aiming"); - //puts("-nocd Disable CD audio"); - puts("-nodudes No monsters"); - puts("-nodemo No Demos"); - puts("-robust Robust network sync checking"); - puts("-skill Set player handicap; Range:0..4; Default:2; (NOT difficulty level.)"); - puts("-quick Skip Intro screens and get right to the game"); - puts("-pname Override player name setting from config file"); - puts("-map Specify a user map"); - puts("-playback Play back a demo"); - puts("-record Record a demo"); - puts("-art Specify an art base file name"); - puts("-snd Specify an RFF Sound file name"); - puts("-RFF Specify an RFF file for Blood game resources"); - puts("-ini Specify an INI file name (default is blood.ini)"); -#endif - exit(0); -} void ParseOptions(void) { + // Stuff for later. +#if 0 int option; while ((option = GetOptions(switches)) != -1) { switch (option) { - case -3: - //ThrowError("Invalid argument: %s", OptFull); - //fallthrough__; - break; // do not error out - this isn't the only code reading the args anymore. - case 29: -#ifdef USE_QHEAP - if (OptArgc < 1) - ThrowError("Missing argument"); - nMaxAlloc = atoi(OptArgv[0]); - if (!nMaxAlloc) - nMaxAlloc = 0x2000000; - break; -#endif - case 0: - PrintHelp(); - break; - //case 19: - // byte_148eec = 1; - //case 20: - // if (OptArgc < 1) - // ThrowError("Missing argument"); - // strncpy(byte_148ef0, OptArgv[0], 13); - // byte_148ef0[12] = 0; - // bQuickStart = 1; - // byte_148eeb = 1; - // if (gGameOptions.gameType == 0) - // gGameOptions.gameType = 2; - // break; - case 25: - bNoDemo = 1; - break; case 18: bQuickStart = 1; break; @@ -1273,12 +1140,6 @@ void ParseOptions(void) else gPacketMode = PACKETMODE_1; break; - case 4: - //if (OptArgc < 1) - // ThrowError("Missing argument"); - //if (gGameOptions.nGameType == 0) - // gGameOptions.nGameType = 2; - break; case 30: if (OptArgc < 1) ThrowError("Missing argument"); @@ -1291,9 +1152,6 @@ void ParseOptions(void) gNetMode = NETWORK_CLIENT; strncpy(gNetAddress, OptArgv[0], sizeof(gNetAddress)-1); break; - case 14: - cl_autoaim = 0; - break; case 22: bNoResend = 0; break; @@ -1318,41 +1176,6 @@ void ParseOptions(void) case 8: gRobust = 1; break; - case 13: - if (OptArgc < 1) - ThrowError("Missing argument"); - levelOverrideINI(OptArgv[0]); - bNoDemo = 1; - break; - case 26: - if (OptArgc < 1) - ThrowError("Missing argument"); - pUserTiles = (char*)malloc(strlen(OptArgv[0])+1); - if (!pUserTiles) - return; - strcpy(pUserTiles, OptArgv[0]); - break; - case 27: - if (OptArgc < 1) - ThrowError("Missing argument"); - pUserSoundRFF = (char*)malloc(strlen(OptArgv[0])+1); - if (!pUserSoundRFF) - return; - strcpy(pUserSoundRFF, OptArgv[0]); - break; - case 28: - if (OptArgc < 1) - ThrowError("Missing argument"); - pUserRFF = (char*)malloc(strlen(OptArgv[0])+1); - if (!pUserRFF) - return; - strcpy(pUserRFF, OptArgv[0]); - break; - case 9: - if (OptArgc < 1) - ThrowError("Missing argument"); - strcpy(SetupFilename, OptArgv[0]); - break; case 10: if (OptArgc < 1) ThrowError("Missing argument"); @@ -1371,94 +1194,9 @@ void ParseOptions(void) else if (gPacketMode == PACKETMODE_3) gSyncRate = 1; break; - case -2: - { - const char *k = strrchr(OptFull, '.'); - if (k) - { - if (!Bstrcasecmp(k, ".map")) - { - strcpy(gUserMapFilename, OptFull); - bAddUserMap = 1; - bNoDemo = 1; - } - else if (!Bstrcasecmp(k, ".grp") || !Bstrcasecmp(k, ".zip") || !Bstrcasecmp(k, ".pk3") || !Bstrcasecmp(k, ".pk4")) - { - G_AddGroup(OptFull); - } - else if (!Bstrcasecmp(k, ".def")) - { - clearDefNamePtr(); - g_defNamePtr = dup_filename(OptFull); - initprintf("Using DEF file \"%s\".\n", g_defNamePtr); - continue; - } - } - else - { - strcpy(gUserMapFilename, OptFull); - bAddUserMap = 1; - bNoDemo = 1; - } - break; - } - case 11: - //bNoCDAudio = 1; - break; - case 32: - break; - case 33: - break; - case 34: - { - if (OptArgc < 1) - ThrowError("Missing argument"); - // No longer supported. - break; - } - case 35: - if (OptArgc < 1) - ThrowError("Missing argument"); - G_AddGroup(OptArgv[0]); - break; - case 36: - if (OptArgc < 1) - ThrowError("Missing argument"); - Bstrncpyz(g_modDir, OptArgv[0], sizeof(g_modDir)); - G_AddPath(OptArgv[0]); - break; - case 37: - gCommandSetup = true; - break; - case 38: - gNoSetup = true; - gCommandSetup = false; - break; - case 39: - if (OptArgc < 1) - ThrowError("Missing argument"); - gNetPort = strtoul(OptArgv[0], NULL, 0); - break; - case 40: - if (OptArgc < 1) - ThrowError("Missing argument"); - G_AddDef(OptArgv[0]); - break; - case 41: - if (OptArgc < 1) - ThrowError("Missing argument"); - G_AddDefModule(OptArgv[0]); - break; - case 42: - if (OptArgc < 1) - ThrowError("Missing argument"); - G_AddPath(OptArgv[0]); - break; - case 43: // conf, noconsole - case 44: - break; } } +#endif #if 0 if (bAddUserMap) { @@ -1507,6 +1245,8 @@ int app_main(int argc, char const * const * argv) PrintBuildInfo(); memcpy(&gGameOptions, &gSingleGameOptions, sizeof(GAMEOPTIONS)); + gGameOptions.nMonsterSettings = userConfig.nomonsters; + bQuickStart = userConfig.nologo; ParseOptions(); G_ExtInit(); @@ -1526,9 +1266,6 @@ int app_main(int argc, char const * const * argv) Bexit(2); } - if (Bstrcmp(SetupFilename, SETUPFILENAME)) - initprintf("Using config file \"%s\".\n", SetupFilename); - ScanINIFiles(); #ifdef STARTUP_SETUP_WINDOW diff --git a/source/blood/src/blood.h b/source/blood/src/blood.h index d0a906abd..a4b05fda3 100644 --- a/source/blood/src/blood.h +++ b/source/blood/src/blood.h @@ -52,7 +52,6 @@ enum INPUT_MODE { }; extern INPUT_MODE gInputMode; -extern char SetupFilename[BMAX_PATH]; extern int32_t gNoSetup; extern short BloodVersion; extern int gNetPlayers; diff --git a/source/blood/src/config.cpp b/source/blood/src/config.cpp index 3e12336c3..6fea5fa4c 100644 --- a/source/blood/src/config.cpp +++ b/source/blood/src/config.cpp @@ -34,7 +34,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "gamecontrol.h" #include "blood.h" #include "config.h" -#include "gamedefs.h" #include "globals.h" #include "screen.h" #include "sound.h" diff --git a/source/blood/src/config.h b/source/blood/src/config.h index 1d31b3f26..7913c2f23 100644 --- a/source/blood/src/config.h +++ b/source/blood/src/config.h @@ -27,7 +27,6 @@ Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. #include "keyboard.h" #include "control.h" #include "_control.h" -#include "gamedefs.h" #include "hash.h" #include "gamecvars.h" #include "gamecontrol.h" diff --git a/source/blood/src/gamedefs.h b/source/blood/src/gamedefs.h deleted file mode 100644 index 73d5e4661..000000000 --- a/source/blood/src/gamedefs.h +++ /dev/null @@ -1,44 +0,0 @@ -//------------------------------------------------------------------------- -/* -Copyright (C) 2010-2019 EDuke32 developers and contributors -Copyright (C) 2019 Nuke.YKT - -This file is part of NBlood. - -NBlood 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. -*/ -//------------------------------------------------------------------------- - -//**************************************************************************** -// -// gamedefs.h -// -// common defines between the game and the setup program -// -//**************************************************************************** - -#ifndef gamedefs_public_h_ -#define gamedefs_public_h_ - -BEGIN_BLD_NS - -// config file name -#define SETUPFILENAME APPBASENAME ".cfg" - - -END_BLD_NS - -#endif - diff --git a/source/blood/src/menu.cpp b/source/blood/src/menu.cpp index e79b6d3ee..ab1680705 100644 --- a/source/blood/src/menu.cpp +++ b/source/blood/src/menu.cpp @@ -1784,14 +1784,14 @@ void PreDrawDisplayPolymost(CGameMenuItem *pItem) void UpdateSoundToggle(CGameMenuItemZBool *pItem) { snd_enabled = pItem->at20; - if (!snd_enabled) + if (!SoundEnabled()) FX_StopAllSounds(); } void UpdateMusicToggle(CGameMenuItemZBool *pItem) { mus_enabled = pItem->at20; - if (!mus_enabled) + if (!MusicEnabled()) sndStopSong(); else { diff --git a/source/blood/src/osdcmd.cpp b/source/blood/src/osdcmd.cpp index 4a00e0e46..c22b9c14f 100644 --- a/source/blood/src/osdcmd.cpp +++ b/source/blood/src/osdcmd.cpp @@ -432,7 +432,7 @@ static int osdcmd_restartsound(osdcmdptr_t UNUSED(parm)) sndInit(); sfxInit(); - if (mus_enabled && (gGameStarted || gDemo.at1)) + if (MusicEnabled() && (gGameStarted || gDemo.at1)) sndPlaySong(gGameOptions.zLevelSong, true); return OSDCMD_OK; diff --git a/source/blood/src/sfx.cpp b/source/blood/src/sfx.cpp index c345376d9..2c7c34492 100644 --- a/source/blood/src/sfx.cpp +++ b/source/blood/src/sfx.cpp @@ -119,7 +119,7 @@ void Calc3DValues(BONKLE *pBonkle) void sfxPlay3DSound(int x, int y, int z, int soundId, int nSector) { - if (!snd_enabled || soundId < 0) return; + if (!SoundEnabled() || soundId < 0) return; DICTNODE *hRes = gSoundRes.Lookup(soundId, "SFX"); if (!hRes)return; @@ -169,7 +169,7 @@ void sfxPlay3DSound(int x, int y, int z, int soundId, int nSector) void sfxPlay3DSound(spritetype *pSprite, int soundId, int a3, int a4) { - if (!snd_enabled) + if (!SoundEnabled()) return; if (!pSprite) return; @@ -283,7 +283,7 @@ void sfxPlay3DSound(spritetype *pSprite, int soundId, int a3, int a4) // By NoOne: same as previous, but allows to set custom pitch for sound AND volume. Used by SFX gen now. void sfxPlay3DSoundCP(spritetype* pSprite, int soundId, int a3, int a4, int pitch, int volume) { - if (!snd_enabled || !pSprite || soundId < 0) return; + if (!SoundEnabled() || !pSprite || soundId < 0) return; DICTNODE* hRes = gSoundRes.Lookup(soundId, "SFX"); if (!hRes) return; diff --git a/source/blood/src/sound.cpp b/source/blood/src/sound.cpp index aaf3b745f..d11a394f3 100644 --- a/source/blood/src/sound.cpp +++ b/source/blood/src/sound.cpp @@ -81,7 +81,7 @@ int nWaveMusicHandle; int sndPlaySong(const char *songName, bool bLoop) { - if (!mus_enabled) + if (!MusicEnabled()) return 0; if (!songName || strlen(songName) == 0) return 1; @@ -245,7 +245,7 @@ void sndKillSound(SAMPLE2D *pChannel); void sndStartSample(const char *pzSound, int nVolume, int nChannel) { - if (!snd_enabled) + if (!SoundEnabled()) return; if (!strlen(pzSound)) return; @@ -267,7 +267,7 @@ void sndStartSample(const char *pzSound, int nVolume, int nChannel) void sndStartSample(unsigned int nSound, int nVolume, int nChannel, bool bLoop) { - if (!snd_enabled) + if (!SoundEnabled()) return; dassert(nChannel >= -1 && nChannel < kChannelMax); DICTNODE *hSfx = gSoundRes.Lookup(nSound, "SFX"); @@ -311,7 +311,7 @@ void sndStartSample(unsigned int nSound, int nVolume, int nChannel, bool bLoop) void sndStartWavID(unsigned int nSound, int nVolume, int nChannel) { - if (!snd_enabled) + if (!SoundEnabled()) return; dassert(nChannel >= -1 && nChannel < kChannelMax); SAMPLE2D *pChannel; diff --git a/source/build/src/common.cpp b/source/build/src/common.cpp index dea345a9f..7ad48c4bb 100644 --- a/source/build/src/common.cpp +++ b/source/build/src/common.cpp @@ -77,6 +77,20 @@ void clearDefNamePtr(void) GrowArray g_clipMapFiles; #endif +void SetClipshapes() +{ +#ifdef HAVE_CLIPSHAPE_FEATURE + // pre-form the default 10 clipmaps + for (int j = '0'; j <= '9'; ++j) + { + char clipshape[16] = "_clipshape0.map"; + + clipshape[10] = j; + g_clipMapFiles.append(Xstrdup(clipshape)); + } +#endif +} + void G_AddDef(const char *buffer) { clearDefNamePtr(); diff --git a/source/build/src/sdlayer.cpp b/source/build/src/sdlayer.cpp index 051047c34..828668a35 100644 --- a/source/build/src/sdlayer.cpp +++ b/source/build/src/sdlayer.cpp @@ -619,10 +619,6 @@ int main(int argc, char *argv[]) FString logpath = M_GetDocumentsPath() + "demolition.log"; OSD_SetLogFile(logpath); - CONFIG_ReadCombatMacros(); - - // Startup dialog must be presented here so that everything can be set up before reading the keybinds. - G_LoadConfig(currentGame); CONFIG_Init(); r = gi->app_main(buildargc, (const char**)buildargv); } diff --git a/source/common/gamecontrol.cpp b/source/common/gamecontrol.cpp index 0e4df516f..454501be4 100644 --- a/source/common/gamecontrol.cpp +++ b/source/common/gamecontrol.cpp @@ -12,9 +12,11 @@ #include "inputstate.h" #include "_control.h" #include "control.h" +#include "m_argv.h" +#include "rts.h" InputState inputState; - +void SetClipshapes(); struct GameFuncNameDesc { @@ -149,6 +151,141 @@ void SetupButtonFunctions() } +UserConfig userConfig; + +void UserConfig::ProcessOptions() +{ + // -help etc are omitted + + // -cfg / -setupfile refer to Build style config which are not supported. + if (Args->CheckParm("-cfg") || Args->CheckParm("-setupfile")) + { + initprintf("Build-format config files not supported and will be ignored\n"); + } + + auto v = Args->CheckValue("-port"); + if (v) netPort = strtol(v, nullptr, 0); + + netServerMode = Args->CheckParm("-server"); + netServerAddress = Args->CheckValue("-connect"); + netPassword = Args->CheckValue("-password"); + + v = Args->CheckValue("-addon"); + if (v) + { + auto val = strtol(v, nullptr, 0); + static const char* const addons[] = { "DUKE3D.GRP", "DUKEDC.GRP", "NWINTER.GRP", "VACATION.GRP" }; + if (val > 0 && val < 4) gamegrp = addons[val]; + else initprintf("%s: Unknown Addon\n", v); + } + else if (Args->CheckParm("-nam")) + { + gamegrp = "NAM.GRP"; + } + else if (Args->CheckParm("-napalm")) + { + gamegrp = "NAPALM.GRP"; + } + else if (Args->CheckParm("-ww2gi")) + { + gamegrp = "WW2GI.GRP"; + } + + v = Args->CheckValue("-gamegrp"); // Although it says 'grp', this will take a directory as well + if (v) + { + gamegrp = v; + } + else + { + // This is to enable the use of Doom launchers. that are limited to -iwad for specifying the game's main resource. + v = Args->CheckValue("-iwad"); + if (v) + { + gamegrp = v; + } + } + + Args->CollectFiles("-rts", ".rts"); + auto rts = Args->CheckValue("-rts"); + if (rts) RTS_Init(rts); + + Args->CollectFiles("-map", ".map"); + CommandMap = Args->CheckValue("-map"); + + static const char* defs[] = { "-def", "-h", nullptr }; + Args->CollectFiles("-def", defs, ".def"); + DefaultDef = Args->CheckValue("-def"); + + static const char* cons[] = { "-con", "-x", nullptr }; + Args->CollectFiles("-con", cons, ".con"); + DefaultCon = Args->CheckValue("-con"); + + static const char* demos[] = { "-playback", "-d", "-demo", nullptr }; + Args->CollectFiles("-demo", demos, ".dmo"); + CommandDemo = Args->CheckValue("-demo"); + + static const char* names[] = { "-pname", "-name", nullptr }; + Args->CollectFiles("-name", names, ".---"); // this shouldn't collect any file names at all so use a nonsense extension + CommandName = Args->CheckValue("-name"); + + static const char* nomos[] = { "-nomonsters", "-nodudes", nullptr }; + Args->CollectFiles("-nomonsters", nomos, ".---"); // this shouldn't collect any file names at all so use a nonsense extension + nomonsters = Args->CheckParm("-nomonsters"); + + static const char* acons[] = { "-addcon", "-mx", nullptr }; + Args->CollectFiles("-addcon", acons, ".con"); + AddCons.reset(Args->GatherFiles("-addcon")); + + static const char* adefs[] = { "-adddef", "-mh", nullptr }; + Args->CollectFiles("-adddef", adefs, ".def"); + AddDefs.reset(Args->GatherFiles("-adddef")); + + Args->CollectFiles("-art", ".art"); + AddArt.reset(Args->GatherFiles("-art")); + + CommandIni = Args->CheckValue("-ini"); + + nologo = Args->CheckParm("-nologo") || Args->CheckParm("-quick"); + nomusic = Args->CheckParm("-nomusic"); + nosound = Args->CheckParm("-nosfx"); + if (Args->CheckParm("-nosound")) nomusic = nosound = true; + if (Args->CheckParm("-setup")) setupstate = 1; + else if (Args->CheckParm("-nosetup")) setupstate = 0; + + + if (Args->CheckParm("-file")) + { + // For file loading there's two modes: + // If -file is given, all content will be processed in order and the legacy options be ignored entirely. + //This allows mixing directories and GRP files in arbitrary order. + Args->CollectFiles("-file", NULL); + AddFiles.reset(Args->GatherFiles("-file")); + } + else + { + // Trying to emulate Build. This means to treat RFF special as lowest priority, then all GRPs and then all directories. + // This is only for people depending on lauchers. Since the semantics are so crappy it is strongly recommended to + // use -file instead which gives the user full control about the order in which things are added. + // For single mods this is no problem but don't even think about loading more stuff consistently... + + static const char* grps[] = { "-g", "-grp", nullptr }; + static const char* dirs[] = { "-game_dir", "-j", nullptr }; + static const char* rffs[] = { "-rff", "-snd", nullptr }; + static const char* twostep[] = { "-rff", "-grp", nullptr }; + + // Abuse the inner workings to get the files into proper order. This is not 100% accurate but should work fine for everything that doesn't intentionally fuck things up. + Args->CollectFiles("-rff", rffs, ".rff"); + Args->CollectFiles("-grp", grps, nullptr); + Args->CollectFiles("-grp", twostep, nullptr); // The two previous calls have already brought the content in order so collecting it again gives us one list with everything. + AddFilesPre.reset(Args->GatherFiles("-grp")); + Args->CollectFiles("-game_dir", dirs, nullptr); + AddFiles.reset(Args->GatherFiles("-game_dir")); + } + + +} + //========================================================================== // // @@ -157,11 +294,26 @@ void SetupButtonFunctions() void CONFIG_Init() { + SetClipshapes(); + // This must be done before initializing any data, so doing it late in the startup process won't work. if (CONTROL_Startup(controltype_keyboardandmouse, BGetTime, gi->TicRate)) { exit(1); } + userConfig.ProcessOptions(); + + CONFIG_ReadCombatMacros(); + + // Startup dialog must be presented here so that everything can be set up before reading the keybinds. + G_LoadConfig(currentGame); + + if (userConfig.CommandName.IsNotEmpty()) + { + playername = userConfig.CommandName; + } + + int index = 0; for(auto &gf : gamefuncs) @@ -1009,10 +1161,8 @@ FString CONFIG_GetBoundKeyForLastInput(int gameFunc) { return joyname; } - - return "UNBOUND"; } - + return "UNBOUND"; } diff --git a/source/common/gamecontrol.h b/source/common/gamecontrol.h index fb3735324..5a0256415 100644 --- a/source/common/gamecontrol.h +++ b/source/common/gamecontrol.h @@ -6,8 +6,10 @@ #include "c_cvars.h" #include "zstring.h" #include "inputstate.h" +#include "gamecvars.h" extern FString currentGame; +class FArgs; extern uint8_t KeyboardKeys[NUMGAMEFUNCTIONS][2]; @@ -71,3 +73,44 @@ void CONFIG_ReadCombatMacros(); int32_t CONFIG_GetMapBestTime(char const* const mapname, uint8_t const* const mapmd4); int CONFIG_SetMapBestTime(uint8_t const* const mapmd4, int32_t tm); + +struct UserConfig +{ + FString gamegrp; + FString CommandMap; + FString DefaultDef; + FString DefaultCon; + FString CommandDemo; + FString CommandName; + FString CommandIni; + std::unique_ptr AddDefs; + std::unique_ptr AddCons; + std::unique_ptr AddFiles; + std::unique_ptr AddFilesPre; //To be added before the main directory. Only for legacy options. + std::unique_ptr AddArt; + + bool nomonsters = false; + bool nosound = false; + bool nomusic = false; + bool nologo = false; + int setupstate = -1; + + int netPort = 0; // g_netPort = Batoi(argv[i + 1]); + int netServerMode = -1; // g_networkMode = NET_SERVER; g_noSetup = g_noLogo = TRUE; + FString netServerAddress; // Net_Connect(argv[i + 1]); g_noSetup = g_noLogo = TRUE; + FString netPassword; // Bstrncpyz(g_netPassword, argv[i + 1], sizeof(g_netPassword)); + + void ProcessOptions(); +}; + +extern UserConfig userConfig; + +inline bool MusicEnabled() +{ + return mus_enabled && !userConfig.nomusic; +} + +inline bool SoundEnabled() +{ + return snd_enabled && !userConfig.nosound; +} diff --git a/source/common/utility/m_argv.cpp b/source/common/utility/m_argv.cpp index 4788b7cff..1a52d4248 100644 --- a/source/common/utility/m_argv.cpp +++ b/source/common/utility/m_argv.cpp @@ -139,7 +139,22 @@ void FArgs::FlushArgs() // //=========================================================================== -int FArgs::CheckParm(const char *check, int start) const +int stricmp(const char** check, const char* str) +{ + for (auto c = *check; c; c++) + { + if (!stricmp(c, str)) return 0; + } + return 1; // we do not care about order here. +} + +int FArgs::CheckParm(const char* check, int start) const +{ + const char* array[] = { check, nullptr }; + return CheckParm(array, start); +} + +int FArgs::CheckParm(const char** check, int start) const { for (unsigned i = start; i < Argv.Size(); ++i) { @@ -354,7 +369,13 @@ void FArgs::RemoveArg(int argindex) // //=========================================================================== -void FArgs::CollectFiles(const char *param, const char *extension) +void FArgs::CollectFiles(const char* param, const char* extension) +{ + const char* array[] = { param, nullptr }; + CollectFiles(param, array, extension); +} + +void FArgs::CollectFiles(const char *finalname, const char **param, const char *extension) { TArray work; unsigned int i; @@ -408,7 +429,7 @@ void FArgs::CollectFiles(const char *param, const char *extension) // Step 3: Add work back to Argv, as long as it's non-empty. if (work.Size() > 0) { - Argv.Push(param); + Argv.Push(finalname); AppendArgs(work.Size(), &work[0]); } } diff --git a/source/common/utility/m_argv.h b/source/common/utility/m_argv.h index 7f0ada822..ecb9b605e 100644 --- a/source/common/utility/m_argv.h +++ b/source/common/utility/m_argv.h @@ -56,11 +56,13 @@ public: void RemoveArg(int argindex); void RemoveArgs(const char *check); void SetArgs(int argc, char **argv); + void CollectFiles(const char *finalname, const char** param, const char* extension); void CollectFiles(const char *param, const char *extension); FArgs *GatherFiles(const char *param) const; void SetArg(int argnum, const char *arg); int CheckParm(const char *check, int start=1) const; // Returns the position of the given parameter in the arg list (0 if not found). + int CheckParm(const char** check, int start = 1) const; // Returns the position of the given parameter in the arg list (0 if not found). Allows checking for multiple switches int CheckParmList(const char *check, FString **strings, int start=1) const; const char *CheckValue(const char *check) const; const char *GetArg(int arg) const; diff --git a/source/duke3d/src/cmdline.cpp b/source/duke3d/src/cmdline.cpp index f24d4a8ff..02800deb1 100644 --- a/source/duke3d/src/cmdline.cpp +++ b/source/duke3d/src/cmdline.cpp @@ -32,95 +32,8 @@ BEGIN_DUKE_NS int32_t g_commandSetup = 0; int32_t g_noSetup = 0; -int32_t g_noSound = 0; -int32_t g_noMusic = 0; -const char *CommandMap = NULL; -const char *CommandName = NULL; int32_t g_fakeMultiMode = 0; -void G_ShowParameterHelp(void) -{ - static char const s[] = "Usage: " APPBASENAME " [files] [options]\n" - "Example: " APPBASENAME " -usecwd -cfg myconfig.cfg -map nukeland.map\n\n" - "Files can be of type [grp|zip|map|con|def]\n" - "\n" - "-cfg [file.cfg]\tUse an alternate configuration file\n" -#ifdef HAVE_CLIPSHAPE_FEATURE - "-clipmap [file.map]\tLoad an additional clipping map for use with clipshape\n" -#endif - "-connect [host]\tConnect to a multiplayer game\n" - "-c#\t\tMultiplayer mode #, 1 = DM, 2 = Co-op, 3 = DM(no spawn)\n" - "-d [file.edm or #]\tPlay a demo\n" - "-g [file.grp]\tLoad additional game data\n" - "-h [file.def]\tLoad an alternate definitions file\n" - "-j [dir]\t\tAdd a directory to " APPNAME "'s search list\n" - "-l#\t\tStart game on level #, see -v\n" - "-map [file.map]\tLoad an external map file\n" - "-mh [file.def]\tInclude an additional definitions module\n" - "-mx [file.con]\tInclude an additional CON script module\n" - "-m\t\tDisable enemies\n" - "-noffire\t\tDisable friendly fire\n" -#ifndef EDUKE32_STANDALONE - "-nam\t\tRun in NAM compatibility mode\n" - "-napalm\t\tRun in NAPALM compatibility mode\n" -#endif - "-rts [file.rts]\tLoad a custom Remote Ridicule sound bank\n" - "-r\t\tRecord demo\n" - "-s#\t\tStart game on skill level #\n" - "-server\t\tStart a multiplayer server\n" -#ifdef STARTUP_SETUP_WINDOW - "-setup/nosetup\tEnable or disable startup window\n" -#endif - "-t#\t\tRespawn mode: 1 = enemies, 2 = weapons, 3 = items, x = all\n" - "-usecwd\t\tRead data and configuration from current directory\n" - "-u#########\tUser's favorite weapon order (default: 3425689071)\n" - "-v#\t\tStart game on episode #, see -l\n" -#ifndef EDUKE32_STANDALONE - "-ww2gi\t\tRun in WWII GI compatibility mode\n" -#endif - "-x [game.con]\tLoad custom CON script\n" - "-#\t\tLoad and run a game from slot # (0-9)\n" - // "\n-?/--help\tDisplay this help message and exit\n" - "\nSee " APPBASENAME " -debughelp for additional parameters for debugging" - ; -#ifdef WM_MSGBOX_WINDOW - Bsnprintf(tempbuf, sizeof(tempbuf), HEAD2 " %s", s_buildRev); - wm_msgbox(tempbuf, s); -#else - initprintf("%s\n", s); -#endif -} - -void G_ShowDebugHelp(void) -{ - static char const s[] = "Usage: " APPBASENAME " [files] [options]\n" - "\n" -#if 0 - "-a\t\tUse fake player AI (fake multiplayer only)\n" -#endif - "-cachesize #\tSet cache size in kB\n" - "-game_dir [dir]\tSpecify game data directory\n" - "-gamegrp \tSelect main grp file\n" - "-name [name]\tPlayer name in multiplayer\n" - "-noautoload\tDisable loading from autoload directory\n" -#if defined RENDERTYPEWIN - "-nodinput\t\tDisable DirectInput (joystick) support\n" -#endif - "-nologo\t\tSkip intro anim\n" - "-ns\t\tDisable sound\n" - "-nm\t\tDisable music\n" - "-q#\t\tFake multiplayer with # players\n" - "-z#/-condebug\tEnable line-by-line CON compile debugging at level #\n" - "-conversion YYYYMMDD\tSelects CON script version for compatibility with older mods\n" - "-rotatesprite-no-widescreen\tStretch screen drawing from scripts to fullscreen\n" - ; -#ifdef WM_MSGBOX_WINDOW - Bsnprintf(tempbuf, sizeof(tempbuf), HEAD2 " %s", s_buildRev); - wm_msgbox(tempbuf, s); -#else - initprintf("%s\n", s); -#endif -} static void G_AddDemo(const char* param) { @@ -155,31 +68,11 @@ static void G_AddDemo(const char* param) void G_CheckCommandLine(int32_t argc, char const * const * argv) { + // stuff for later +#if 0 int16_t i = 1, j; const char *c, *k; - ud.fta_on = 1; - ud.god = 0; - ud.m_respawn_items = 0; - ud.m_respawn_monsters = 0; - ud.m_respawn_inventory = 0; - ud.warp_on = 0; - ud.cashman = 0; - ud.m_ffire = 1; - ud.m_player_skill = ud.player_skill = 2; - memcpy(g_player[0].wchoice, "\3\4\5\7\0x8\6\0\2\0x9\1", 10); - wchoice.Callback(); - -#ifdef HAVE_CLIPSHAPE_FEATURE - // pre-form the default 10 clipmaps - for (j = '0'; j<='9'; ++j) - { - char clipshape[16] = "_clipshape0.map"; - - clipshape[10] = j; - g_clipMapFiles.append(Xstrdup(clipshape)); - } -#endif if (argc > 1) { @@ -200,270 +93,12 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) { shortopt = 0; - if (!Bstrcasecmp(c+1, "?") || !Bstrcasecmp(c+1, "help") || !Bstrcasecmp(c+1, "-help")) - { - G_ShowParameterHelp(); - Bexit(EXIT_SUCCESS); - } - if (!Bstrcasecmp(c+1, "addon")) - { - if (argc > i+1) - { - g_addonNum = Batoi(argv[i+1]); - - if (g_addonNum > ADDON_NONE && g_addonNum < NUMADDONS) - g_noSetup = 1; - else g_addonNum = ADDON_NONE; - - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "debughelp") || !Bstrcasecmp(c+1, "-debughelp")) - { - G_ShowDebugHelp(); - Bexit(EXIT_SUCCESS); - } - if (!Bstrcasecmp(c+1, "grp") || !Bstrcasecmp(c+1, "g")) - { - if (argc > i+1) - { - G_AddGroup(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "game_dir")) - { - if (argc > i+1) - { - Bstrncpyz(g_modDir, argv[i+1], sizeof(g_modDir)); - G_AddPath(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "cfg")) - { - if (argc > i+1) - { - Bstrcpy(g_setupFileName, argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "gamegrp")) - { - if (argc > i+1) - { - clearGrpNamePtr(); - g_grpNamePtr = dup_filename(argv[i+1]); - i++; - } - i++; - continue; - } -#ifndef EDUKE32_STANDALONE - if (!Bstrcasecmp(c+1, "nam")) - { - g_gameType = GAMEFLAG_NAM; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "napalm")) - { - g_gameType = GAMEFLAG_NAM|GAMEFLAG_NAPALM; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "ww2gi")) - { - g_gameType = GAMEFLAG_WW2GI; - i++; - continue; - } -#endif - if (!Bstrcasecmp(c+1, "setup")) - { - g_commandSetup = TRUE; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "nosetup")) - { - g_noSetup = 1; - g_commandSetup = 0; - i++; - continue; - } -#if defined RENDERTYPEWIN - if (!Bstrcasecmp(c+1, "nodinput")) - { - initprintf("DirectInput (joystick) support disabled\n"); - di_disabled = 1; - i++; - continue; - } -#endif -#ifndef NETCODE_DISABLE - if (!Bstrcasecmp(c+1, "net")) - { - G_GameExit("EDuke32 no longer supports legacy networking.\n\n" - "If using YANG or other launchers that only support legacy netplay, download an older build of EDuke32. " - "Otherwise, run the following:\n\n" - "eduke32 -server\n\n" - "Other clients can then connect by typing \"connect [host]\" in the console.\n\n" - "EDuke32 will now close."); - } -#endif - if (!Bstrcasecmp(c+1, "port")) - { - if (argc > i+1) - { - g_netPort = Batoi(argv[i+1]); - i++; - } - i++; - continue; - } -#ifndef NETCODE_DISABLE - if (!Bstrcasecmp(c+1, "server")) - { - g_networkMode = NET_SERVER; - g_noSetup = g_noLogo = TRUE; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "dedicated")) - { - g_networkMode = NET_DEDICATED_SERVER; - g_noSetup = g_noLogo = TRUE; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "connect")) - { - if (argc > i+1) - { - Net_Connect(argv[i+1]); - g_noSetup = g_noLogo = TRUE; - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "password")) - { - if (argc > i+1) - { - Bstrncpyz(g_netPassword, argv[i+1], sizeof(g_netPassword)); - i++; - } - i++; - continue; - } -#endif - if (!Bstrcasecmp(c+1, "name")) // pname in Blood - { - if (argc > i+1) - { - CommandName = argv[i+1]; - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "map")) - { - if (argc > i+1) - { - CommandMap = argv[i+1]; - i++; - } - i++; - continue; - } if (!Bstrcasecmp(c+1, "noffire")) { ud.m_ffire = 0; i++; continue; } - if (!Bstrcasecmp(c+1, "rts")) - { - if (argc > i+1) - { - RTS_Init(argv[i+1]); - initprintf("Using RTS file \"%s\".\n", argv[i + 1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "x")) - { - if (argc > i+1) - { - G_AddCon(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "mx")) - { - if (argc > i+1) - { - G_AddConModule(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "h")) - { - if (argc > i+1) - { - G_AddDef(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "mh")) - { - if (argc > i+1) - { - G_AddDefModule(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "j")) - { - if (argc > i+1) - { - G_AddPath(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "d")) - { - if (argc > i+1) - { - G_AddDemo(argv[i+1]); - i++; - } - i++; - continue; - } #ifdef HAVE_CLIPSHAPE_FEATURE if (!Bstrcasecmp(c+1, "clipmap")) { @@ -482,53 +117,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) i++; continue; } - if (!Bstrcasecmp(c+1, "nologo")) - { - g_noLogo = 1; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "usecwd")) - { - i++; - continue; - } - if (!Bstrcasecmp(c+1, "cachesize")) - { - if (argc > i+1) - { - i++; - // No longer supported. - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "noinstancechecking")) - { - i++; - continue; - } -#if defined(RENDERTYPEWIN) && defined(USE_OPENGL) - if (!Bstrcasecmp(c+1, "forcegl")) - { - forcegl = 1; - i++; - continue; - } -#endif - // the following two dummy entries allow us to serve as a drop-in replacement for NAM on Steam - if (!Bstrcasecmp(c+1, "noconsole")) - { - i++; - continue; - } - if (!Bstrcasecmp(c+1, "conf")) - { - if (argc > i+1) - i++; - i++; - continue; - } } if ((*c == '-') @@ -557,63 +145,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) } ud.m_coop--; break; - case 'd': - { - c++; - if (*c) - G_AddDemo(c); - break; - } - case 'g': - c++; - if (*c) - G_AddGroup(c); - break; - case 'h': - c++; - if (*c) - G_AddDef(c); - break; - case 'j': - c++; - if (*c) - G_AddPath(c); - break; - case 'l': - // NOTE: Overlaid with -Lopts=... options for Lunatic, hence the check. - if (Bisdigit(c[1])) - { - ud.warp_on = 1; - c++; - ud.m_level_number = ud.level_number = ((unsigned) (Batoi(c)-1))%MAXLEVELS; - } - break; - case 'm': - if (*(c+1) != 'a' && *(c+1) != 'A') - { - ud.m_monsters_off = 1; - ud.m_player_skill = ud.player_skill = 0; - initprintf("Monsters off.\n"); - } - break; - case 'n': - c++; - if (*c == 's' || *c == 'S') - { - g_noSound = 2; - initprintf("Sound off.\n"); - } - else if (*c == 'm' || *c == 'M') - { - g_noMusic = 1; - initprintf("Music off.\n"); - } - else - { - G_ShowParameterHelp(); - Bexit(EXIT_SUCCESS); - } - break; case 'q': if (*(++c) == 0) { @@ -667,8 +198,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) } initprintf("Respawn on.\n"); break; - case 'u': - break; case 'v': c++; ud.warp_on = 1; @@ -677,11 +206,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) case 'w': cl_showcoords = 1; break; - case 'x': - c++; - if (*c) - G_AddCon(c); - break; case 'z': c++; g_scriptDebug = Batoi(c); @@ -693,53 +217,13 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) break; } } - else - { - shortopt = 0; - - k = Bstrrchr(c, '.'); - if (k) - { - if (!Bstrcasecmp(k, ".map")) - { - CommandMap = argv[i++]; - continue; - } - if (!Bstrcasecmp(k, ".grp") || !Bstrcasecmp(k, ".zip") || !Bstrcasecmp(k, ".pk3") || !Bstrcasecmp(k, ".pk4")) - { - G_AddGroup(argv[i++]); - continue; - } - if (!Bstrcasecmp(k, ".con")) - { - clearScriptNamePtr(); - g_scriptNamePtr = dup_filename(argv[i++]); - initprintf("Using CON file \"%s\".\n", g_scriptNamePtr); - continue; - } - if (!Bstrcasecmp(k, ".def")) - { - clearDefNamePtr(); - g_defNamePtr = dup_filename(argv[i++]); - initprintf("Using DEF file \"%s\".\n", g_defNamePtr); - continue; - } - if (!Bstrcasecmp(k, ".rts")) - { - RTS_Init(argv[i]); - initprintf("Using RTS file \"%s\".\n", argv[i]); - i++; - continue; - } - } - } - if (!shortopt || ignored_short_opt) initprintf("Warning: ignored application parameter \"%s\".\n", oc); i++; } while (i < argc); } +#endif } END_DUKE_NS diff --git a/source/duke3d/src/cmdline.h b/source/duke3d/src/cmdline.h index 29b46996a..77f6379fe 100644 --- a/source/duke3d/src/cmdline.h +++ b/source/duke3d/src/cmdline.h @@ -34,10 +34,6 @@ extern void G_ShowDebugHelp(void); extern int32_t g_commandSetup; extern int32_t g_noSetup; -extern int32_t g_noSound; -extern int32_t g_noMusic; -extern const char *CommandMap; -extern const char *CommandName; extern int32_t g_fakeMultiMode; END_DUKE_NS diff --git a/source/duke3d/src/config.cpp b/source/duke3d/src/config.cpp index 1221b00df..ca4e67534 100644 --- a/source/duke3d/src/config.cpp +++ b/source/duke3d/src/config.cpp @@ -102,6 +102,19 @@ void CONFIG_SetDefaults(void) ud.statusbarscale = 100; ud.team = 0; + ud.fta_on = 1; + ud.god = 0; + ud.m_respawn_items = 0; + ud.m_respawn_monsters = 0; + ud.m_respawn_inventory = 0; + ud.warp_on = 0; + ud.cashman = 0; + ud.m_ffire = 1; + ud.m_player_skill = ud.player_skill = 2; + memcpy(g_player[0].wchoice, "\3\4\5\7\0x8\6\0\2\0x9\1", 10); + wchoice.Callback(); + + VM_OnEvent(EVENT_SETDEFAULTS, g_player[myconnectindex].ps->i, myconnectindex); } diff --git a/source/duke3d/src/game.cpp b/source/duke3d/src/game.cpp index dac3af288..806080ed8 100644 --- a/source/duke3d/src/game.cpp +++ b/source/duke3d/src/game.cpp @@ -4447,7 +4447,7 @@ static int32_t g_RTSPlaying; // Returns: started playing? extern int G_StartRTS(int lumpNum, int localPlayer) { - if (!adult_lockout && snd_enabled && + if (!adult_lockout && SoundEnabled() && RTS_IsInitialized() && g_RTSPlaying == 0 && (snd_speech & (localPlayer ? 1 : 4))) { char *const pData = (char *)RTS_GetSound(lumpNum - 1); @@ -4881,7 +4881,7 @@ FAKE_F3: Menu_Change(MENU_SOUND_INGAME); } - if (KB_UnBoundKeyPressed(sc_F5) && mus_enabled) + if (KB_UnBoundKeyPressed(sc_F5) && MusicEnabled()) { map_t *const pMapInfo = &g_mapInfo[g_musicIndex]; char *const musicString = apStrings[QUOTE_MUSIC]; @@ -6034,16 +6034,7 @@ static void G_Startup(void) #endif if (g_netServer || ud.multimode > 1) G_CheckGametype(); - //errr... what??? Why does this clobber the user setting? Well, it needs to be redone anyway, preferably at a lower level. - //if (g_noSound) snd_enabled = 0; - //if (g_noMusic) mus_enabled = 0; - - if (CommandName) - { - playername = CommandName; - } - - if (CommandMap) + if (userConfig.CommandMap.IsNotEmpty()) { if (VOLUMEONE) { @@ -6056,7 +6047,7 @@ static void G_Startup(void) boardfilename[0] = '/'; boardfilename[1] = 0; - Bstrcat(boardfilename, CommandMap); + Bstrcat(boardfilename, userConfig.CommandMap); dot = Bstrrchr(boardfilename,'.'); slash = Bstrrchr(boardfilename,'/'); @@ -6302,6 +6293,7 @@ int app_main(int argc, const char * const*argv) g_skillCnt = 4; ud.multimode = 1; + ud.m_monsters_off = userConfig.nomonsters; // This needs to happen before G_CheckCommandLine() because G_GameExit() // accesses g_player[0]. @@ -6334,9 +6326,6 @@ int app_main(int argc, const char * const*argv) Bexit(2); } - if (Bstrcmp(g_setupFileName, SETUPFILENAME)) - initprintf("Using config file \"%s\".\n",g_setupFileName); - G_ScanGroups(); #ifdef STARTUP_SETUP_WINDOW diff --git a/source/duke3d/src/gamedefs.h b/source/duke3d/src/gamedefs.h index 1b21a7862..e69de29bb 100644 --- a/source/duke3d/src/gamedefs.h +++ b/source/duke3d/src/gamedefs.h @@ -1,39 +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. -*/ -//------------------------------------------------------------------------- - -//**************************************************************************** -// -// gamedefs.h -// -// common defines between the game and the setup program -// -//**************************************************************************** - -#ifndef gamedefs_public_h_ -#define gamedefs_public_h_ - -// config file name -#define SETUPFILENAME APPBASENAME ".cfg" - - -#endif - diff --git a/source/duke3d/src/global.cpp b/source/duke3d/src/global.cpp index 572789dee..6cb1673b6 100644 --- a/source/duke3d/src/global.cpp +++ b/source/duke3d/src/global.cpp @@ -134,7 +134,4 @@ int16_t g_blimpSpawnItems[15] = char CheatKeys[2] = { sc_D, sc_N }; -char g_setupFileName[BMAX_PATH] = SETUPFILENAME; - - END_DUKE_NS diff --git a/source/duke3d/src/global.h b/source/duke3d/src/global.h index 64c4d8f00..f50f685ff 100644 --- a/source/duke3d/src/global.h +++ b/source/duke3d/src/global.h @@ -163,7 +163,6 @@ extern double g_gameUpdateAvgTime; #ifndef global_c_ extern char CheatKeys[2]; extern char g_gametypeNames[MAXGAMETYPES][33]; -extern char g_setupFileName[BMAX_PATH]; extern char g_skillNames[MAXSKILLS][33]; extern char g_volumeNames[MAXVOLUMES][33]; diff --git a/source/duke3d/src/menus.cpp b/source/duke3d/src/menus.cpp index 4475d055f..fc854e1e9 100644 --- a/source/duke3d/src/menus.cpp +++ b/source/duke3d/src/menus.cpp @@ -3215,7 +3215,7 @@ static void Menu_EntryLinkActivate(MenuEntry_t *entry) FX_StopAllSounds(); S_ClearSoundLocks(); - if (mus_enabled) + if (MusicEnabled()) S_RestartMusic(); } else if (entry == &ME_SAVESETUP_CLEANUP) diff --git a/source/duke3d/src/osdcmds.cpp b/source/duke3d/src/osdcmds.cpp index f29de609a..a059cae36 100644 --- a/source/duke3d/src/osdcmds.cpp +++ b/source/duke3d/src/osdcmds.cpp @@ -380,7 +380,7 @@ static int osdcmd_restartsound(osdcmdptr_t UNUSED(parm)) FX_StopAllSounds(); S_ClearSoundLocks(); - if (mus_enabled) + if (MusicEnabled()) S_RestartMusic(); return OSDCMD_OK; diff --git a/source/duke3d/src/premap.cpp b/source/duke3d/src/premap.cpp index 3280f5ada..13ed43151 100644 --- a/source/duke3d/src/premap.cpp +++ b/source/duke3d/src/premap.cpp @@ -1319,7 +1319,7 @@ void G_NewGame(int volumeNum, int levelNum, int skillNum) gameHandleEvents(); - if (ud.skill_voice > 0 && snd_enabled) + if (ud.skill_voice > 0 && SoundEnabled()) { while (FX_SoundActive(ud.skill_voice)) gameHandleEvents(); diff --git a/source/duke3d/src/savegame.cpp b/source/duke3d/src/savegame.cpp index 9b362223b..3033874ea 100644 --- a/source/duke3d/src/savegame.cpp +++ b/source/duke3d/src/savegame.cpp @@ -2448,7 +2448,7 @@ static void postloadplayer(int32_t savegamep) else S_ContinueLevelMusic(); - if (mus_enabled) + if (MusicEnabled()) S_PauseMusic(false); g_player[myconnectindex].ps->gm = MODE_GAME; diff --git a/source/duke3d/src/screens.cpp b/source/duke3d/src/screens.cpp index d9ba0e7ee..205e3c15f 100644 --- a/source/duke3d/src/screens.cpp +++ b/source/duke3d/src/screens.cpp @@ -2198,7 +2198,7 @@ void G_BonusScreen(int32_t bonusonly) videoClearScreen(0); G_DisplayMPResultsScreen(); - if (mus_enabled) + if (MusicEnabled()) S_PlaySound(BONUSMUSIC); videoNextPage(); @@ -2239,7 +2239,7 @@ void G_BonusScreen(int32_t bonusonly) gametext_center_shade(192, "Press any key or button to continue", quotepulseshade); - if (mus_enabled) + if (MusicEnabled()) S_PlaySound(BONUSMUSIC); videoNextPage(); diff --git a/source/duke3d/src/sector.cpp b/source/duke3d/src/sector.cpp index 9d98a59d9..3ff61d41e 100644 --- a/source/duke3d/src/sector.cpp +++ b/source/duke3d/src/sector.cpp @@ -2605,7 +2605,7 @@ void P_HandleSharedKeys(int playerNum) } else { - if (mus_enabled) S_PauseMusic(false); + if (MusicEnabled()) S_PauseMusic(false); S_PauseSounds(false); diff --git a/source/duke3d/src/sounds.cpp b/source/duke3d/src/sounds.cpp index 6762953d7..d47377a49 100644 --- a/source/duke3d/src/sounds.cpp +++ b/source/duke3d/src/sounds.cpp @@ -230,7 +230,7 @@ void S_MenuSound(void) static int S_PlayMusic(const char *fn) { - if (!mus_enabled) + if (!MusicEnabled()) return 0; if (fn == NULL) @@ -664,7 +664,7 @@ int S_PlaySound3D(int num, int spriteNum, const vec3_t *pos) { int32_t j = VM_OnEventWithReturn(EVENT_SOUND, spriteNum, screenpeek, num); - if ((j == -1 && num != -1) || !snd_enabled) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) + if ((j == -1 && num != -1) || !SoundEnabled()) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) return -1; int const sndNum = j; @@ -804,7 +804,7 @@ int S_PlaySound(int num) { int sndnum = VM_OnEventWithReturn(EVENT_SOUND, g_player[screenpeek].ps->i, screenpeek, num); - if ((sndnum == -1 && num != -1) || !snd_enabled) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) + if ((sndnum == -1 && num != -1) || !SoundEnabled()) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) return -1; num = sndnum; diff --git a/source/rr/src/cmdline.cpp b/source/rr/src/cmdline.cpp index 2448327d9..6eaed9095 100644 --- a/source/rr/src/cmdline.cpp +++ b/source/rr/src/cmdline.cpp @@ -33,86 +33,8 @@ BEGIN_RR_NS int32_t g_commandSetup = 0; int32_t g_noSetup = 0; int32_t g_noSound = 0; -int32_t g_noMusic = 0; -const char *CommandMap = NULL; -const char *CommandName = NULL; int32_t g_fakeMultiMode = 0; -void G_ShowParameterHelp(void) -{ - static char const s[] = "Usage: " APPBASENAME " [files] [options]\n" - "Example: " APPBASENAME " -usecwd -cfg myconfig.cfg -map nukeland.map\n\n" - "Files can be of type [grp|zip|map|con|def]\n" - "\n" - "-cfg [file.cfg]\tUse an alternate configuration file\n" -#ifdef HAVE_CLIPSHAPE_FEATURE - "-clipmap [file.map]\tLoad an additional clipping map for use with clipshape\n" -#endif - "-connect [host]\tConnect to a multiplayer game\n" - "-c#\t\tMultiplayer mode #, 1 = DM, 2 = Co-op, 3 = DM(no spawn)\n" - "-d [file.edm or #]\tPlay a demo\n" - "-g [file.grp]\tLoad additional game data\n" - "-h [file.def]\tLoad an alternate definitions file\n" - "-j [dir]\t\tAdd a directory to " APPNAME "'s search list\n" - "-l#\t\tStart game on level #, see -v\n" - "-map [file.map]\tLoad an external map file\n" - "-mh [file.def]\tInclude an additional definitions module\n" - "-mx [file.con]\tInclude an additional CON script module\n" - "-m\t\tDisable enemies\n" - "-rts [file.rts]\tLoad a custom Remote Ridicule sound bank\n" - "-r\t\tRecord demo\n" - "-s#\t\tStart game on skill level #\n" - "-server\t\tStart a multiplayer server\n" -#ifdef STARTUP_SETUP_WINDOW - "-setup/nosetup\tEnable or disable startup window\n" -#endif - "-t#\t\tRespawn mode: 1 = enemies, 2 = weapons, 3 = items, x = all\n" - "-usecwd\t\tRead data and configuration from current directory\n" - "-u#########\tUser's favorite weapon order (default: 3425689071)\n" - "-v#\t\tStart game on episode #, see -l\n" - "-x [game.con]\tLoad custom CON script\n" - "-#\t\tLoad and run a game from slot # (0-9)\n" - // "\n-?/--help\tDisplay this help message and exit\n" - "\nSee " APPBASENAME " -debughelp for additional parameters for debugging" - ; -#ifdef WM_MSGBOX_WINDOW - Bsnprintf(tempbuf, sizeof(tempbuf), HEAD2 " %s", s_buildRev); - wm_msgbox(tempbuf, s); -#else - initprintf("%s\n", s); -#endif -} - -void G_ShowDebugHelp(void) -{ - static char const s[] = "Usage: " APPBASENAME " [files] [options]\n" - "\n" -#if 0 - "-a\t\tUse fake player AI (fake multiplayer only)\n" -#endif - "-cachesize #\tSet cache size in kB\n" - "-game_dir [dir]\tSpecify game data directory\n" - "-gamegrp \tSelect main grp file\n" - "-name [name]\tPlayer name in multiplayer\n" - "-noautoload\tDisable loading from autoload directory\n" -#if defined RENDERTYPEWIN - "-nodinput\t\tDisable DirectInput (joystick) support\n" -#endif - "-nologo\t\tSkip intro anim\n" - "-ns\t\tDisable sound\n" - "-nm\t\tDisable music\n" - "-q#\t\tFake multiplayer with # players\n" - "-z#/-condebug\tEnable line-by-line CON compile debugging at level #\n" - "-conversion YYYYMMDD\tSelects CON script version for compatibility with older mods\n" - "-rotatesprite-no-widescreen\tStretch screen drawing from scripts to fullscreen\n" - ; -#ifdef WM_MSGBOX_WINDOW - Bsnprintf(tempbuf, sizeof(tempbuf), HEAD2 " %s", s_buildRev); - wm_msgbox(tempbuf, s); -#else - initprintf("%s\n", s); -#endif -} static void G_AddDemo(const char* param) { @@ -147,31 +69,11 @@ static void G_AddDemo(const char* param) void G_CheckCommandLine(int32_t argc, char const * const * argv) { + // Stuff to sort out later. +#if 0 int16_t i = 1, j; const char *c, *k; - ud.fta_on = 1; - ud.god = 0; - ud.m_respawn_items = 0; - ud.m_respawn_monsters = 0; - ud.m_respawn_inventory = 0; - ud.warp_on = 0; - ud.cashman = 0; - ud.m_player_skill = ud.player_skill = 2; - memcpy(g_player[0].wchoice, "\3\4\5\7\0x8\6\0\2\0x9\1", 10); - wchoice.Callback(); - - -#ifdef HAVE_CLIPSHAPE_FEATURE - // pre-form the default 10 clipmaps - for (j = '0'; j<='9'; ++j) - { - char clipshape[16] = "_clipshape0.map"; - - clipshape[10] = j; - g_clipMapFiles.append(Xstrdup(clipshape)); - } -#endif if (argc > 1) { @@ -192,247 +94,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) { shortopt = 0; - if (!Bstrcasecmp(c+1, "?") || !Bstrcasecmp(c+1, "help") || !Bstrcasecmp(c+1, "-help")) - { - G_ShowParameterHelp(); - Bexit(0); - } - if (!Bstrcasecmp(c+1, "addon")) - { - if (argc > i+1) - { - g_addonNum = Batoi(argv[i+1]); - - if (g_addonNum > ADDON_NONE && g_addonNum < NUMADDONS) - g_noSetup = 1; - else g_addonNum = ADDON_NONE; - - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "debughelp") || !Bstrcasecmp(c+1, "-debughelp")) - { - G_ShowDebugHelp(); - Bexit(0); - } - if (!Bstrcasecmp(c+1, "grp") || !Bstrcasecmp(c+1, "g")) - { - if (argc > i+1) - { - G_AddGroup(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "game_dir")) - { - if (argc > i+1) - { - Bstrncpyz(g_modDir, argv[i+1], sizeof(g_modDir)); - G_AddPath(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "cfg")) - { - if (argc > i+1) - { - Bstrcpy(g_setupFileName, argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "gamegrp")) - { - if (argc > i+1) - { - clearGrpNamePtr(); - g_grpNamePtr = dup_filename(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "nam")) - { - g_gameType = GAMEFLAG_NAM; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "napalm")) - { - g_gameType = GAMEFLAG_NAM|GAMEFLAG_NAPALM; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "setup")) - { - g_commandSetup = TRUE; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "nosetup")) - { - g_noSetup = 1; - g_commandSetup = 0; - i++; - continue; - } -#ifndef NETCODE_DISABLE - if (!Bstrcasecmp(c+1, "net")) - { - G_GameExit("EDuke32 no longer supports legacy networking.\n\n" - "If using YANG or other launchers that only support legacy netplay, download an older build of EDuke32. " - "Otherwise, run the following:\n\n" - "eduke32 -server\n\n" - "Other clients can then connect by typing \"connect [host]\" in the console.\n\n" - "EDuke32 will now close."); - } -#endif - if (!Bstrcasecmp(c+1, "port")) - { - if (argc > i+1) - { - g_netPort = Batoi(argv[i+1]); - i++; - } - i++; - continue; - } -#ifndef NETCODE_DISABLE - if (!Bstrcasecmp(c+1, "server")) - { - g_networkMode = NET_SERVER; - g_noSetup = g_noLogo = TRUE; - i++; - continue; - } - //if (!Bstrcasecmp(c+1, "dedicated")) - //{ - // g_networkMode = NET_DEDICATED_SERVER; - // g_noSetup = g_noLogo = TRUE; - // i++; - // continue; - //} - if (!Bstrcasecmp(c+1, "connect")) - { - if (argc > i+1) - { - Net_Connect(argv[i+1]); - g_noSetup = g_noLogo = TRUE; - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "password")) - { - if (argc > i+1) - { - Bstrncpyz(g_netPassword, argv[i+1], sizeof(g_netPassword)); - i++; - } - i++; - continue; - } -#endif - if (!Bstrcasecmp(c+1, "name")) - { - if (argc > i+1) - { - CommandName = argv[i+1]; - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "map")) - { - if (argc > i+1) - { - CommandMap = argv[i+1]; - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "rts")) - { - if (argc > i+1) - { - RTS_Init(argv[i+1]); - initprintf("Using RTS file \"%s\".\n", argv[i + 1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "x")) - { - if (argc > i+1) - { - G_AddCon(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "mx")) - { - if (argc > i+1) - { - G_AddConModule(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "h")) - { - if (argc > i+1) - { - G_AddDef(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "mh")) - { - if (argc > i+1) - { - G_AddDefModule(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "j")) - { - if (argc > i+1) - { - G_AddPath(argv[i+1]); - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "d")) - { - if (argc > i+1) - { - G_AddDemo(argv[i+1]); - i++; - } - i++; - continue; - } #ifdef HAVE_CLIPSHAPE_FEATURE if (!Bstrcasecmp(c+1, "clipmap")) { @@ -451,53 +112,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) i++; continue; } - if (!Bstrcasecmp(c+1, "nologo")) - { - g_noLogo = 1; - i++; - continue; - } - if (!Bstrcasecmp(c+1, "usecwd")) - { - i++; - continue; - } - if (!Bstrcasecmp(c+1, "cachesize")) - { - if (argc > i+1) - { - // No longer supported. - i++; - } - i++; - continue; - } - if (!Bstrcasecmp(c+1, "noinstancechecking")) - { - i++; - continue; - } -#if defined(RENDERTYPEWIN) && defined(USE_OPENGL) - if (!Bstrcasecmp(c+1, "forcegl")) - { - forcegl = 1; - i++; - continue; - } -#endif - // the following two dummy entries allow us to serve as a drop-in replacement for NAM on Steam - if (!Bstrcasecmp(c+1, "noconsole")) - { - i++; - continue; - } - if (!Bstrcasecmp(c+1, "conf")) - { - if (argc > i+1) - i++; - i++; - continue; - } } if ((*c == '-') @@ -526,63 +140,7 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) } ud.m_coop--; break; - case 'd': - { - c++; - if (*c) - G_AddDemo(c); - break; - } - case 'g': - c++; - if (*c) - G_AddGroup(c); - break; - case 'h': - c++; - if (*c) - G_AddDef(c); - break; - case 'j': - c++; - if (*c) - G_AddPath(c); - break; - case 'l': - // NOTE: Overlaid with -Lopts=... options for Lunatic, hence the check. - if (Bisdigit(c[1])) - { - ud.warp_on = 1; - c++; - ud.m_level_number = ud.level_number = ((unsigned) (Batoi(c)-1))%MAXLEVELS; - } - break; - case 'm': - if (*(c+1) != 'a' && *(c+1) != 'A') - { - ud.m_monsters_off = 1; - ud.m_player_skill = ud.player_skill = 0; - initprintf("Monsters off.\n"); - } - break; - case 'n': - c++; - if (*c == 's' || *c == 'S') - { - g_noSound = 2; - initprintf("Sound off.\n"); - } - else if (*c == 'm' || *c == 'M') - { - g_noMusic = 1; - initprintf("Music off.\n"); - } - else - { - G_ShowParameterHelp(); - exit(-1); - } - break; + case 'q': if (*(++c) == 0) { @@ -636,8 +194,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) } initprintf("Respawn on.\n"); break; - case 'u': - break; case 'v': c++; ud.warp_on = 1; @@ -646,11 +202,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) case 'w': cl_showcoords = 1; break; - case 'x': - c++; - if (*c) - G_AddCon(c); - break; case 'z': c++; g_scriptDebug = Batoi(c); @@ -662,46 +213,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) break; } } - else - { - shortopt = 0; - - k = Bstrrchr(c, '.'); - if (k) - { - if (!Bstrcasecmp(k, ".map")) - { - CommandMap = argv[i++]; - continue; - } - if (!Bstrcasecmp(k, ".grp") || !Bstrcasecmp(k, ".zip") || !Bstrcasecmp(k, ".pk3") || !Bstrcasecmp(k, ".pk4")) - { - G_AddGroup(argv[i++]); - continue; - } - if (!Bstrcasecmp(k, ".con")) - { - clearScriptNamePtr(); - g_scriptNamePtr = dup_filename(argv[i++]); - initprintf("Using CON file \"%s\".\n", g_scriptNamePtr); - continue; - } - if (!Bstrcasecmp(k, ".def")) - { - clearDefNamePtr(); - g_defNamePtr = dup_filename(argv[i++]); - initprintf("Using DEF file \"%s\".\n", g_defNamePtr); - continue; - } - if (!Bstrcasecmp(k, ".rts")) - { - RTS_Init(argv[i]); - initprintf("Using RTS file \"%s\".\n", argv[i]); - i++; - continue; - } - } - } if (!shortopt || ignored_short_opt) initprintf("Warning: ignored application parameter \"%s\".\n", oc); @@ -709,5 +220,6 @@ void G_CheckCommandLine(int32_t argc, char const * const * argv) i++; } while (i < argc); } +#endif } END_RR_NS diff --git a/source/rr/src/cmdline.h b/source/rr/src/cmdline.h index 116d7e9fd..4525c83f4 100644 --- a/source/rr/src/cmdline.h +++ b/source/rr/src/cmdline.h @@ -33,10 +33,6 @@ extern void G_ShowDebugHelp(void); extern int32_t g_commandSetup; extern int32_t g_noSetup; -extern int32_t g_noSound; -extern int32_t g_noMusic; -extern const char *CommandMap; -extern const char *CommandName; extern int32_t g_fakeMultiMode; END_RR_NS diff --git a/source/rr/src/game.cpp b/source/rr/src/game.cpp index ae39f9454..d8bf2ff56 100644 --- a/source/rr/src/game.cpp +++ b/source/rr/src/game.cpp @@ -5961,7 +5961,7 @@ static int32_t g_RTSPlaying; // Returns: started playing? extern int G_StartRTS(int lumpNum, int localPlayer) { - if (!adult_lockout && snd_enabled && + if (!adult_lockout && SoundEnabled() && RTS_IsInitialized() && g_RTSPlaying == 0 && (snd_speech & (localPlayer ? 1 : 4))) { char *const pData = (char *)RTS_GetSound(lumpNum - 1); @@ -6394,7 +6394,7 @@ FAKE_F3: Menu_Change(MENU_SOUND_INGAME); } - if (KB_UnBoundKeyPressed(sc_F5) && mus_enabled) + if (KB_UnBoundKeyPressed(sc_F5) && MusicEnabled()) { map_t *const pMapInfo = &g_mapInfo[g_musicIndex]; char *const musicString = apStrings[QUOTE_MUSIC]; @@ -7427,17 +7427,8 @@ static void G_Startup(void) G_PostCreateGameState(); if (g_netServer || ud.multimode > 1) G_CheckGametype(); - //errr... what??? Why does this clobber the user setting? Well, it needs to be redone anyway, preferably at a lower level. - //if (g_noSound) snd_enabled = 0; - //if (g_noMusic) mus_enabled = 0; - - if (CommandName) + if (userConfig.CommandMap.IsNotEmpty()) { - playername = CommandName; - } - - if (CommandMap) - { if (VOLUMEONE) { initprintf("The -map option is available in the registered version only!\n"); @@ -7449,7 +7440,7 @@ static void G_Startup(void) boardfilename[0] = '/'; boardfilename[1] = 0; - Bstrcat(boardfilename, CommandMap); + Bstrcat(boardfilename, userConfig.CommandMap); dot = Bstrrchr(boardfilename,'.'); slash = Bstrrchr(boardfilename,'/'); @@ -7677,6 +7668,7 @@ int app_main(int argc, char const * const * argv) g_skillCnt = 4; ud.multimode = 1; + ud.m_monsters_off = userConfig.nomonsters; g_movesPerPacket = 1; bufferjitter = 1; @@ -7710,9 +7702,6 @@ int app_main(int argc, char const * const * argv) Bexit(2); } - if (Bstrcmp(g_setupFileName, SETUPFILENAME)) - initprintf("Using config file \"%s\".\n",g_setupFileName); - G_ScanGroups(); #ifdef STARTUP_SETUP_WINDOW diff --git a/source/rr/src/gamedefs.h b/source/rr/src/gamedefs.h index 4daa3b919..e69de29bb 100644 --- a/source/rr/src/gamedefs.h +++ b/source/rr/src/gamedefs.h @@ -1,43 +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. -*/ -//------------------------------------------------------------------------- - -//**************************************************************************** -// -// gamedefs.h -// -// common defines between the game and the setup program -// -//**************************************************************************** - -#ifndef gamedefs_public_h_ -#define gamedefs_public_h_ - -BEGIN_RR_NS - - -// config file name -#define SETUPFILENAME APPBASENAME ".cfg" - -END_RR_NS - -#endif - diff --git a/source/rr/src/global.cpp b/source/rr/src/global.cpp index a5f9b7671..e5a09cf09 100644 --- a/source/rr/src/global.cpp +++ b/source/rr/src/global.cpp @@ -124,6 +124,4 @@ int16_t g_blimpSpawnItems[15] = char CheatKeys[2] = { sc_D, sc_N }; -char g_setupFileName[BMAX_PATH] = SETUPFILENAME; - END_RR_NS diff --git a/source/rr/src/global.h b/source/rr/src/global.h index 64466f14e..dfa1a66a7 100644 --- a/source/rr/src/global.h +++ b/source/rr/src/global.h @@ -261,7 +261,6 @@ extern float g_gameUpdateAvgTime; #ifndef global_c_ extern char CheatKeys[2]; extern char g_gametypeNames[MAXGAMETYPES][33]; -extern char g_setupFileName[BMAX_PATH]; extern char g_skillNames[MAXSKILLS][33]; extern char g_volumeNames[MAXVOLUMES][33]; diff --git a/source/rr/src/menus.cpp b/source/rr/src/menus.cpp index 0098e5f2f..a92646658 100644 --- a/source/rr/src/menus.cpp +++ b/source/rr/src/menus.cpp @@ -3591,7 +3591,7 @@ static void Menu_EntryLinkActivate(MenuEntry_t *entry) FX_StopAllSounds(); S_ClearSoundLocks(); - if (mus_enabled) + if (MusicEnabled()) S_RestartMusic(); } else if (entry == &ME_SAVESETUP_CLEANUP) @@ -5705,7 +5705,7 @@ static void M_RunMenu_CdPlayer(Menu_t *cm, MenuMenu_t *menu, const vec2_t origin S_PlaySound(RR ? 341 : PISTOL_BODYHIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7041,7 +7041,7 @@ static void Menu_RunInput(Menu_t *cm) currentry = Menu_RunInput_Menu_Movement(menu, MM_Up); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7056,7 +7056,7 @@ static void Menu_RunInput(Menu_t *cm) currentry = Menu_RunInput_Menu_Movement(menu, MM_Down); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7068,7 +7068,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 0; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7080,7 +7080,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 1; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7092,7 +7092,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 2; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7104,7 +7104,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 3; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7116,7 +7116,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 4; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7128,7 +7128,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 5; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7140,7 +7140,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 6; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); @@ -7152,7 +7152,7 @@ static void Menu_RunInput(Menu_t *cm) menu->currentEntry = 7; S_PlaySound(RR ? 335 : KICK_HIT); - if (mus_enabled) + if (MusicEnabled()) { S_StopMusic(); S_PlayRRMusic(2+menu->currentEntry); diff --git a/source/rr/src/osdcmds.cpp b/source/rr/src/osdcmds.cpp index ad86572d0..5ff57e834 100644 --- a/source/rr/src/osdcmds.cpp +++ b/source/rr/src/osdcmds.cpp @@ -375,7 +375,7 @@ static int osdcmd_restartsound(osdcmdptr_t UNUSED(parm)) FX_StopAllSounds(); S_ClearSoundLocks(); - if (mus_enabled) + if (MusicEnabled()) S_RestartMusic(); return OSDCMD_OK; diff --git a/source/rr/src/premap.cpp b/source/rr/src/premap.cpp index 5b62c0f18..24577996b 100644 --- a/source/rr/src/premap.cpp +++ b/source/rr/src/premap.cpp @@ -1870,7 +1870,7 @@ void G_NewGame(int volumeNum, int levelNum, int skillNum) G_HandleAsync(); - if (g_skillSoundVoice >= 0 && snd_enabled) + if (g_skillSoundVoice >= 0 && SoundEnabled()) { while (FX_SoundActive(g_skillSoundVoice)) G_HandleAsync(); diff --git a/source/rr/src/savegame.cpp b/source/rr/src/savegame.cpp index 70937a3e6..4cdab7a00 100644 --- a/source/rr/src/savegame.cpp +++ b/source/rr/src/savegame.cpp @@ -1879,7 +1879,7 @@ static void postloadplayer(int32_t savegamep) S_PlayLevelMusicOrNothing(musicIdx); } - if (mus_enabled) + if (MusicEnabled()) S_PauseMusic(false); g_player[myconnectindex].ps->gm = MODE_GAME; diff --git a/source/rr/src/screens.cpp b/source/rr/src/screens.cpp index 617a29d53..e0863d3af 100644 --- a/source/rr/src/screens.cpp +++ b/source/rr/src/screens.cpp @@ -2224,7 +2224,7 @@ void G_BonusScreen(int32_t bonusonly) videoClearScreen(0); G_DisplayMPResultsScreen(); - if (mus_enabled) + if (MusicEnabled()) S_PlaySound(BONUSMUSIC); videoNextPage(); @@ -2268,7 +2268,7 @@ void G_BonusScreen(int32_t bonusonly) gametext_center_shade(192, "Press any key or button to continue", quotepulseshade); - if (mus_enabled) + if (MusicEnabled()) S_PlaySound(BONUSMUSIC); } else @@ -2818,7 +2818,7 @@ void G_BonusScreenRRRA(int32_t bonusonly) videoClearScreen(0); G_DisplayMPResultsScreen(); - if (mus_enabled) + if (MusicEnabled()) S_PlaySound(BONUSMUSIC); videoNextPage(); diff --git a/source/rr/src/sector.cpp b/source/rr/src/sector.cpp index ef5760c14..3e81b4f26 100644 --- a/source/rr/src/sector.cpp +++ b/source/rr/src/sector.cpp @@ -3653,7 +3653,7 @@ void P_HandleSharedKeys(int playerNum) } else { - if (mus_enabled) S_PauseMusic(false); + if (MusicEnabled()) S_PauseMusic(false); S_PauseSounds(false); diff --git a/source/rr/src/sounds.cpp b/source/rr/src/sounds.cpp index 933f34b00..001d83bdc 100644 --- a/source/rr/src/sounds.cpp +++ b/source/rr/src/sounds.cpp @@ -186,7 +186,7 @@ void S_MenuSound(void) static int S_PlayMusic(const char *fn, int loop) { - if (!mus_enabled) + if (!MusicEnabled()) return 0; if (fn == NULL) @@ -602,7 +602,7 @@ int S_PlaySound3D(int num, int spriteNum, const vec3_t *pos) { int32_t j; - if (!snd_enabled) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) + if (!SoundEnabled()) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) return -1; int const sndNum = num; @@ -741,7 +741,7 @@ int S_PlaySound(int num) { int sndnum; - if (!snd_enabled) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) + if (!SoundEnabled()) // check that the user returned -1, but only if -1 wasn't playing already (in which case, warn) return -1; sound_t & snd = g_sounds[num]; diff --git a/source/sw/src/game.cpp b/source/sw/src/game.cpp index d91bc72c0..00d8003d8 100644 --- a/source/sw/src/game.cpp +++ b/source/sw/src/game.cpp @@ -109,8 +109,6 @@ const char* G_DefFile(void); const char* AppProperName = "VoidSW"; const char* AppTechnicalName = "voidsw"; -#define SETUPFILENAME "voidsw.cfg" -char setupfilename[BMAX_PATH] = SETUPFILENAME; #if DEBUG #define BETA 0 @@ -2059,7 +2057,7 @@ MenuLevel(void) DSPRINTF(ds,"MenuLevel..."); MONO_PRINT(ds); - if (mus_enabled) + if (MusicEnabled()) { PlaySong(NULL, RedBookSong[0], TRUE, FALSE); } @@ -2473,7 +2471,7 @@ BonusScreen(PLAYERp pp) totalclock = ototalclock = 0; limit = synctics; - if (mus_enabled) + if (MusicEnabled()) { PlaySong(voc[DIGI_ENDLEV].name, 3, TRUE, TRUE); } @@ -2791,7 +2789,7 @@ StatScreen(PLAYERp mpp) inputState.ClearKeyStatus(KEYSC_SPACE); inputState.ClearKeyStatus(KEYSC_ENTER); - if (mus_enabled) + if (MusicEnabled()) { PlaySong(voc[DIGI_ENDLEV].name, 3, TRUE, TRUE); } @@ -3571,6 +3569,7 @@ int32_t app_main(int32_t argc, char const * const * argv) } #endif +#if 0 for (cnt = 1; cnt < argc; cnt++) { char const *arg = argv[cnt]; @@ -4007,7 +4006,7 @@ int32_t app_main(int32_t argc, char const * const * argv) G_AddDefModule(arg+1); } } - +#endif Control(argc, argv); return 0; diff --git a/source/sw/src/menus.cpp b/source/sw/src/menus.cpp index 2772d8c0c..4fdc4d90d 100644 --- a/source/sw/src/menus.cpp +++ b/source/sw/src/menus.cpp @@ -3282,7 +3282,7 @@ MNU_DoButton(MenuItem_p item, SWBOOL draw) snd_enabled = state = buttonsettings[item->button]; if (snd_enabled != last_value) { - if (!snd_enabled) + if (!SoundEnabled()) StopFX(); } break; @@ -3293,7 +3293,7 @@ MNU_DoButton(MenuItem_p item, SWBOOL draw) { SWBOOL bak; - if (mus_enabled) + if (MusicEnabled()) { bak = DemoMode; PlaySong(LevelSong, RedBookSong[Level], TRUE, TRUE); diff --git a/source/sw/src/serp.cpp b/source/sw/src/serp.cpp index 9fd192837..0e4debd0f 100644 --- a/source/sw/src/serp.cpp +++ b/source/sw/src/serp.cpp @@ -34,6 +34,7 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms #include "actor.h" #include "track.h" #include "sector.h" +#include "gamecontrol.h" BEGIN_SW_NS @@ -818,7 +819,7 @@ int DoDeathSpecial(short SpriteNum) DoMatchEverything(NULL, sp->lotag, ON); - if (!SW_SHAREWARE && mus_enabled && !alreadydid) + if (!SW_SHAREWARE && MusicEnabled() && !alreadydid) { PlaySong(0, RedBookSong[Level], TRUE, TRUE); alreadydid = TRUE; diff --git a/source/sw/src/sounds.cpp b/source/sw/src/sounds.cpp index 9143a46e3..a732f8187 100644 --- a/source/sw/src/sounds.cpp +++ b/source/sw/src/sounds.cpp @@ -408,7 +408,7 @@ extern short Level; SWBOOL PlaySong(char *song_file_name, int cdaudio_track, SWBOOL loop, SWBOOL restart) { - if (!mus_enabled) + if (!MusicEnabled()) { return FALSE; } @@ -551,7 +551,7 @@ StopSong(void) void PauseSong(SWBOOL pauseon) { - if (!mus_enabled) return; + if (!MusicEnabled()) return; if (SongType == SongTypeWave && SongVoice >= 0) { @@ -816,7 +816,7 @@ PlaySound(int num, int *x, int *y, int *z, Voc3D_Flags flags) if (Prediction) return -1; - if (!snd_enabled) + if (!SoundEnabled()) return -1; PRODUCTION_ASSERT(num >= 0 && num < DIGI_MAX); @@ -1045,7 +1045,7 @@ void PlaySoundRTS(int rts_num) char *rtsptr; int voice=-1; - if (!RTS_IsInitialized() || !snd_enabled) + if (!RTS_IsInitialized() || !SoundEnabled()) return; rtsptr = (char *)RTS_GetSound(rts_num - 1); diff --git a/source/sw/src/sumo.cpp b/source/sw/src/sumo.cpp index 4e0e7da5d..5044fadf0 100644 --- a/source/sw/src/sumo.cpp +++ b/source/sw/src/sumo.cpp @@ -37,6 +37,7 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms #include "track.h" #include "weapon.h" #include "sector.h" +#include "gamecontrol.h" BEGIN_SW_NS @@ -802,7 +803,7 @@ int DoSumoDeathMelt(short SpriteNum) u->ID = 0; DoMatchEverything(NULL, sp->lotag, ON); - if (!SW_SHAREWARE && mus_enabled && !alreadydid) + if (!SW_SHAREWARE && MusicEnabled() && !alreadydid) { PlaySong(0, RedBookSong[Level], TRUE, TRUE); alreadydid = TRUE; @@ -881,7 +882,7 @@ BossHealthMeter(void) if (i == 0 && !serpwasseen) { serpwasseen = TRUE; - if (!SW_SHAREWARE && mus_enabled) + if (!SW_SHAREWARE && MusicEnabled()) { PlaySong(0, 13, TRUE, TRUE); } @@ -889,7 +890,7 @@ BossHealthMeter(void) else if (i == 1 && !sumowasseen) { sumowasseen = TRUE; - if (!SW_SHAREWARE && mus_enabled) + if (!SW_SHAREWARE && MusicEnabled()) { PlaySong(0, 13, TRUE, TRUE); } @@ -897,7 +898,7 @@ BossHealthMeter(void) else if (i == 2 && !zillawasseen) { zillawasseen = TRUE; - if (!SW_SHAREWARE && mus_enabled) + if (!SW_SHAREWARE && MusicEnabled()) { PlaySong(0, 13, TRUE, TRUE); } diff --git a/source/sw/src/zilla.cpp b/source/sw/src/zilla.cpp index a1530e963..3045b3187 100644 --- a/source/sw/src/zilla.cpp +++ b/source/sw/src/zilla.cpp @@ -36,6 +36,7 @@ Prepared for public release: 03/28/2005 - Charlie Wiederhold, 3D Realms #include "actor.h" #include "track.h" #include "fx_man.h" +#include "gamecontrol.h" BEGIN_SW_NS @@ -777,7 +778,7 @@ int DoZillaDeathMelt(short SpriteNum) RESET(u->Flags, SPR_JUMPING|SPR_FALLING|SPR_MOVED); //DoMatchEverything(NULL, sp->lotag, ON); - if (!SW_SHAREWARE && mus_enabled && !alreadydid) + if (!SW_SHAREWARE && MusicEnabled() && !alreadydid) { PlaySong(0, RedBookSong[Level], TRUE, TRUE); alreadydid = TRUE;