summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSimon Howard2008-11-21 18:03:06 +0000
committerSimon Howard2008-11-21 18:03:06 +0000
commitae18d8c4b6f7f918aa5ec496ca32899793cbe41e (patch)
treeed15c8dab41695f3b899590c4efbfec91a4426ee
parent9646b03b13d875289ce0270cacab67657684bd58 (diff)
downloadchocolate-doom-ae18d8c4b6f7f918aa5ec496ca32899793cbe41e.tar.gz
chocolate-doom-ae18d8c4b6f7f918aa5ec496ca32899793cbe41e.tar.bz2
chocolate-doom-ae18d8c4b6f7f918aa5ec496ca32899793cbe41e.zip
Move setup/ into src/ and merge with main codebase. Remove duplicated
code. Split out I_Endoom to separate i_endoom.c file. Subversion-branch: /branches/raven-branch Subversion-revision: 1384
-rw-r--r--configure.in4
-rw-r--r--setup/configfile.c599
-rw-r--r--setup/configfile.h42
-rw-r--r--src/Makefile.am45
-rw-r--r--src/d_dedicated.c23
-rw-r--r--src/doom/d_main.c11
-rw-r--r--src/heretic/d_main.c12
-rw-r--r--src/hexen/h2_main.c10
-rw-r--r--src/i_endoom.c (renamed from setup/m_argv.c)66
-rw-r--r--src/i_endoom.h (renamed from setup/m_argv.h)21
-rw-r--r--src/i_system.c59
-rw-r--r--src/i_system.h5
-rw-r--r--src/i_timer.c5
-rw-r--r--src/i_timer.h3
-rw-r--r--src/i_video.h3
-rw-r--r--src/m_config.c25
-rw-r--r--src/m_config.h1
-rw-r--r--src/setup-res.rc.in (renamed from setup/setup-res.rc.in)0
-rw-r--r--src/setup/.gitignore (renamed from setup/.gitignore)0
-rw-r--r--src/setup/Makefile.am (renamed from setup/Makefile.am)29
-rw-r--r--src/setup/compatibility.c (renamed from setup/compatibility.c)0
-rw-r--r--src/setup/compatibility.h (renamed from setup/compatibility.h)0
-rw-r--r--src/setup/display.c (renamed from setup/display.c)0
-rw-r--r--src/setup/display.h (renamed from setup/display.h)0
-rw-r--r--src/setup/execute.c (renamed from setup/execute.c)7
-rw-r--r--src/setup/execute.h (renamed from setup/execute.h)0
-rw-r--r--src/setup/joystick.c (renamed from setup/joystick.c)0
-rw-r--r--src/setup/joystick.h (renamed from setup/joystick.h)0
-rw-r--r--src/setup/keyboard.c (renamed from setup/keyboard.c)0
-rw-r--r--src/setup/keyboard.h (renamed from setup/keyboard.h)0
-rw-r--r--src/setup/mainmenu.c (renamed from setup/mainmenu.c)14
-rw-r--r--src/setup/mouse.c (renamed from setup/mouse.c)0
-rw-r--r--src/setup/mouse.h (renamed from setup/mouse.h)0
-rw-r--r--src/setup/multiplayer.c (renamed from setup/multiplayer.c)5
-rw-r--r--src/setup/multiplayer.h (renamed from setup/multiplayer.h)0
-rw-r--r--src/setup/setup-manifest.xml (renamed from setup/setup-manifest.xml)0
-rw-r--r--src/setup/setup_icon.c (renamed from setup/setup_icon.c)0
-rw-r--r--src/setup/sound.c (renamed from setup/sound.c)0
-rw-r--r--src/setup/sound.h (renamed from setup/sound.h)0
-rw-r--r--src/setup/txt_joybinput.c (renamed from setup/txt_joybinput.c)0
-rw-r--r--src/setup/txt_joybinput.h (renamed from setup/txt_joybinput.h)0
-rw-r--r--src/setup/txt_keyinput.c (renamed from setup/txt_keyinput.c)0
-rw-r--r--src/setup/txt_keyinput.h (renamed from setup/txt_keyinput.h)0
-rw-r--r--src/setup/txt_mouseinput.c (renamed from setup/txt_mouseinput.c)0
-rw-r--r--src/setup/txt_mouseinput.h (renamed from setup/txt_mouseinput.h)0
45 files changed, 161 insertions, 828 deletions
diff --git a/configure.in b/configure.in
index 5703560e..f4b6202a 100644
--- a/configure.in
+++ b/configure.in
@@ -79,15 +79,15 @@ AC_OUTPUT([
Makefile
textscreen/Makefile
textscreen/examples/Makefile
-setup/Makefile
man/Makefile
src/Makefile
src/doom/Makefile
src/heretic/Makefile
src/hexen/Makefile
+src/setup/Makefile
pcsound/Makefile
src/resource.rc
+src/setup-res.rc
src/doom-screensaver.desktop
-setup/setup-res.rc
])
diff --git a/setup/configfile.c b/setup/configfile.c
deleted file mode 100644
index 3f75d7f1..00000000
--- a/setup/configfile.c
+++ /dev/null
@@ -1,599 +0,0 @@
-// Emacs style mode select -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright(C) 1993-1996 Id Software, Inc.
-// Copyright(C) 2005 Simon Howard
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// 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., 59 Temple Place - Suite 330, Boston, MA
-// 02111-1307, USA.
-//
-//
-// DESCRIPTION:
-// Configuration file load/save code.
-//
-//-----------------------------------------------------------------------------
-
-
-#include <stdio.h>
-#include <stdlib.h>
-#include <ctype.h>
-#include <string.h>
-
-// for mkdir:
-
-#ifdef _WIN32
-#include <io.h>
-#else
-#include <sys/stat.h>
-#include <sys/types.h>
-#endif
-
-#include "config.h"
-
-#include "doomfeatures.h"
-#include "doomkeys.h"
-#include "doomtype.h"
-#include "d_englsh.h"
-
-#include "m_argv.h"
-
-#include "compatibility.h"
-#include "display.h"
-#include "joystick.h"
-#include "keyboard.h"
-#include "mouse.h"
-#include "multiplayer.h"
-#include "sound.h"
-
-char *configdir;
-
-//
-// Create a directory
-//
-
-void M_MakeDirectory(char *path)
-{
-#ifdef _WIN32
- mkdir(path);
-#else
- mkdir(path, 0755);
-#endif
-}
-
-
-//
-// SetConfigDir:
-//
-// Sets the location of the configuration directory, where configuration
-// files are stored - default.cfg, chocolate-doom.cfg, savegames, etc.
-//
-
-void M_SetConfigDir(void)
-{
-#ifndef _WIN32
- // Ignore the HOME environment variable on Windows - just behave
- // like Vanilla Doom.
-
- char *homedir;
-
- homedir = getenv("HOME");
-
- if (homedir != NULL)
- {
- // put all configuration in a config directory off the
- // homedir
-
- configdir = malloc(strlen(homedir) + strlen(PACKAGE_TARNAME) + 5);
-
- sprintf(configdir, "%s/.%s/", homedir, PACKAGE_TARNAME);
-
- // make the directory if it doesnt already exist
-
- M_MakeDirectory(configdir);
- }
- else
-#endif /* #ifndef _WIN32 */
- {
-#ifdef _WIN32
- // when given the -cdrom option, save config+savegames in
- // c:\doomdata. This only applies under Windows.
-
- if (M_CheckParm("-cdrom") > 0)
- {
- printf(D_CDROM);
- configdir = strdup("c:\\doomdata\\");
-
- M_MakeDirectory(configdir);
- }
- else
-#endif
- {
- configdir = strdup("");
- }
- }
-}
-
-
-
-//
-// DEFAULTS
-//
-
-// These are options that are not controlled by setup.
-
-static int showMessages = 1;
-static int screenblocks = 9;
-static int detailLevel = 0;
-static int usegamma = 0;
-
-// dos specific options: these are unused but should be maintained
-// so that the config file can be shared between chocolate
-// doom and doom.exe
-
-static int snd_sbport = 0;
-static int snd_sbirq = 0;
-static int snd_sbdma = 0;
-static int snd_mport = 0;
-
-typedef enum
-{
- DEFAULT_INT,
- DEFAULT_STRING,
- DEFAULT_FLOAT,
- DEFAULT_KEY,
-} default_type_t;
-
-typedef struct
-{
- // Name of the variable
- char * name;
-
- // Pointer to the location in memory of the variable
- void * location;
-
- // Type of the variable
- default_type_t type;
-
- // If this is a key value, the original integer scancode we read from
- // the config file before translating it to the internal key value.
- // If zero, we didn't read this value from a config file.
- int untranslated;
-
- // The value we translated the scancode into when we read the
- // config file on startup. If the variable value is different from
- // this, it has been changed and needs to be converted; otherwise,
- // use the 'untranslated' value.
- int original_translated;
-} default_t;
-
-typedef struct
-{
- default_t *defaults;
- int numdefaults;
- char *filename;
-} default_collection_t;
-
-static default_t doom_defaults_list[] =
-{
- {"mouse_sensitivity", &mouseSensitivity, DEFAULT_INT, 0, 0},
- {"sfx_volume",&sfxVolume, DEFAULT_INT, 0, 0},
- {"music_volume",&musicVolume, DEFAULT_INT, 0, 0},
- {"show_messages",&showMessages, DEFAULT_INT, 0, 0},
-
- {"key_right",&key_right, DEFAULT_KEY, 0, 0},
- {"key_left",&key_left, DEFAULT_KEY, 0, 0},
- {"key_up",&key_up, DEFAULT_KEY, 0, 0},
- {"key_down",&key_down, DEFAULT_KEY, 0, 0},
- {"key_strafeleft",&key_strafeleft, DEFAULT_KEY, 0, 0},
- {"key_straferight",&key_straferight, DEFAULT_KEY, 0, 0},
-
- {"key_fire",&key_fire, DEFAULT_KEY, 0, 0},
- {"key_use",&key_use, DEFAULT_KEY, 0, 0},
- {"key_strafe",&key_strafe, DEFAULT_KEY, 0, 0},
- {"key_speed",&key_speed, DEFAULT_KEY, 0, 0},
-
- {"use_mouse",&usemouse, DEFAULT_INT, 0, 0},
- {"mouseb_fire",&mousebfire, DEFAULT_INT, 0, 0},
- {"mouseb_strafe",&mousebstrafe, DEFAULT_INT, 0, 0},
- {"mouseb_forward",&mousebforward, DEFAULT_INT, 0, 0},
-
- {"use_joystick",&usejoystick, DEFAULT_INT, 0, 0},
- {"joyb_fire",&joybfire, DEFAULT_INT, 0, 0},
- {"joyb_strafe",&joybstrafe, DEFAULT_INT, 0, 0},
- {"joyb_use",&joybuse, DEFAULT_INT, 0, 0},
- {"joyb_speed",&joybspeed, DEFAULT_INT, 0, 0},
-
- {"screenblocks",&screenblocks, DEFAULT_INT, 0, 0},
- {"detaillevel",&detailLevel, DEFAULT_INT, 0, 0},
-
- {"snd_channels",&numChannels, DEFAULT_INT, 0, 0},
-
- {"snd_musicdevice", &snd_musicdevice, DEFAULT_INT, 0, 0},
- {"snd_sfxdevice", &snd_sfxdevice, DEFAULT_INT, 0, 0},
- {"snd_sbport", &snd_sbport, DEFAULT_INT, 0, 0},
- {"snd_sbirq", &snd_sbirq, DEFAULT_INT, 0, 0},
- {"snd_sbdma", &snd_sbdma, DEFAULT_INT, 0, 0},
- {"snd_mport", &snd_mport, DEFAULT_INT, 0, 0},
-
- {"usegamma", &usegamma, DEFAULT_INT, 0, 0},
-
- {"chatmacro0", &chat_macros[0], DEFAULT_STRING, 0, 0 },
- {"chatmacro1", &chat_macros[1], DEFAULT_STRING, 0, 0 },
- {"chatmacro2", &chat_macros[2], DEFAULT_STRING, 0, 0 },
- {"chatmacro3", &chat_macros[3], DEFAULT_STRING, 0, 0 },
- {"chatmacro4", &chat_macros[4], DEFAULT_STRING, 0, 0 },
- {"chatmacro5", &chat_macros[5], DEFAULT_STRING, 0, 0 },
- {"chatmacro6", &chat_macros[6], DEFAULT_STRING, 0, 0 },
- {"chatmacro7", &chat_macros[7], DEFAULT_STRING, 0, 0 },
- {"chatmacro8", &chat_macros[8], DEFAULT_STRING, 0, 0 },
- {"chatmacro9", &chat_macros[9], DEFAULT_STRING, 0, 0 },
-};
-
-static default_collection_t doom_defaults =
-{
- doom_defaults_list,
- arrlen(doom_defaults_list),
- NULL,
-};
-
-static default_t extra_defaults_list[] =
-{
- {"autoadjust_video_settings", &autoadjust_video_settings, DEFAULT_INT, 0, 0},
- {"fullscreen", &fullscreen, DEFAULT_INT, 0, 0},
- {"aspect_ratio_correct", &aspect_ratio_correct, DEFAULT_INT, 0, 0},
- {"startup_delay", &startup_delay, DEFAULT_INT, 0, 0},
- {"screen_width", &screen_width, DEFAULT_INT, 0, 0},
- {"screen_height", &screen_height, DEFAULT_INT, 0, 0},
- {"grabmouse", &grabmouse, DEFAULT_INT, 0, 0},
- {"novert", &novert, DEFAULT_INT, 0, 0},
- {"mouse_acceleration", &mouse_acceleration, DEFAULT_FLOAT, 0, 0},
- {"mouse_threshold", &mouse_threshold, DEFAULT_INT, 0, 0},
- {"snd_samplerate", &snd_samplerate, DEFAULT_INT, 0, 0},
- {"show_endoom", &show_endoom, DEFAULT_INT, 0, 0},
- {"vanilla_savegame_limit", &vanilla_savegame_limit, DEFAULT_INT, 0, 0},
- {"vanilla_demo_limit", &vanilla_demo_limit, DEFAULT_INT, 0, 0},
- {"vanilla_keyboard_mapping", &vanilla_keyboard_mapping, DEFAULT_INT, 0, 0},
-#ifdef FEATURE_MULTIPLAYER
- {"player_name", &net_player_name, DEFAULT_STRING, 0, 0},
-#endif
- {"video_driver", &video_driver, DEFAULT_STRING, 0, 0},
- {"joystick_index", &joystick_index, DEFAULT_INT, 0, 0},
- {"joystick_x_axis", &joystick_x_axis, DEFAULT_INT, 0, 0},
- {"joystick_x_invert", &joystick_x_invert, DEFAULT_INT, 0, 0},
- {"joystick_y_axis", &joystick_y_axis, DEFAULT_INT, 0, 0},
- {"joystick_y_invert", &joystick_y_invert, DEFAULT_INT, 0, 0},
- {"joyb_strafeleft", &joybstrafeleft, DEFAULT_INT, 0, 0},
- {"joyb_straferight", &joybstraferight, DEFAULT_INT, 0, 0},
- {"dclick_use", &dclick_use, DEFAULT_INT, 0, 0},
- {"mouseb_strafeleft", &mousebstrafeleft, DEFAULT_INT, 0, 0},
- {"mouseb_straferight", &mousebstraferight, DEFAULT_INT, 0, 0},
- {"mouseb_use", &mousebuse, DEFAULT_INT, 0, 0},
- {"mouseb_backward", &mousebbackward, DEFAULT_INT, 0, 0},
- {"use_libsamplerate", &use_libsamplerate, DEFAULT_INT, 0, 0},
-};
-
-static default_collection_t extra_defaults =
-{
- extra_defaults_list,
- arrlen(extra_defaults_list),
- NULL,
-};
-
-static int scantokey[128] =
-{
- 0 , 27, '1', '2', '3', '4', '5', '6',
- '7', '8', '9', '0', '-', '=', KEY_BACKSPACE, 9,
- 'q', 'w', 'e', 'r', 't', 'y', 'u', 'i',
- 'o', 'p', '[', ']', 13, KEY_RCTRL, 'a', 's',
- 'd', 'f', 'g', 'h', 'j', 'k', 'l', ';',
- '\'', '`', KEY_RSHIFT,'\\', 'z', 'x', 'c', 'v',
- 'b', 'n', 'm', ',', '.', '/', KEY_RSHIFT,KEYP_MULTIPLY,
- KEY_RALT, ' ', KEY_CAPSLOCK,KEY_F1, KEY_F2, KEY_F3, KEY_F4, KEY_F5,
- KEY_F6, KEY_F7, KEY_F8, KEY_F9, KEY_F10, KEY_PAUSE,KEY_SCRLCK,KEY_HOME,
- KEY_UPARROW,KEY_PGUP,KEYP_MINUS,KEY_LEFTARROW,KEYP_5,KEY_RIGHTARROW,KEYP_PLUS,KEY_END,
- KEY_DOWNARROW,KEY_PGDN,KEY_INS,KEY_DEL,0, 0, 0, KEY_F11,
- KEY_F12, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0,
- 0, 0, 0, 0, 0, 0, 0, 0
-};
-
-
-static void SaveDefaultCollection(default_collection_t *collection)
-{
- default_t *defaults;
- int i, v;
- FILE *f;
-
- f = fopen (collection->filename, "w");
- if (!f)
- return; // can't write the file, but don't complain
-
- defaults = collection->defaults;
-
- for (i=0 ; i<collection->numdefaults ; i++)
- {
- int chars_written;
-
- // Print the name and line up all values at 30 characters
-
- chars_written = fprintf(f, "%s ", defaults[i].name);
-
- for (; chars_written < 30; ++chars_written)
- fprintf(f, " ");
-
- // Print the value
-
- switch (defaults[i].type)
- {
- case DEFAULT_KEY:
-
- // use the untranslated version if we can, to reduce
- // the possibility of screwing up the user's config
- // file
-
- v = * (int *) defaults[i].location;
-
- if (defaults[i].untranslated
- && v == defaults[i].original_translated)
- {
- // Has not been changed since the last time we
- // read the config file.
-
- v = defaults[i].untranslated;
- }
- else
- {
- // search for a reverse mapping back to a scancode
- // in the scantokey table
-
- int s;
-
- for (s=0; s<128; ++s)
- {
- if (scantokey[s] == v)
- {
- v = s;
- break;
- }
- }
- }
-
- fprintf(f, "%i", v);
- break;
-
- case DEFAULT_INT:
- fprintf(f, "%i", * (int *) defaults[i].location);
- break;
-
- case DEFAULT_FLOAT:
- fprintf(f, "%f", * (float *) defaults[i].location);
- break;
-
- case DEFAULT_STRING:
- fprintf(f,"\"%s\"", * (char **) (defaults[i].location));
- break;
- }
-
- fprintf(f, "\n");
- }
-
- fclose (f);
-}
-
-// Parses integer values in the configuration file
-
-static int ParseIntParameter(char *strparm)
-{
- int parm;
-
- if (strparm[0] == '0' && strparm[1] == 'x')
- sscanf(strparm+2, "%x", &parm);
- else
- sscanf(strparm, "%i", &parm);
-
- return parm;
-}
-
-static void LoadDefaultCollection(default_collection_t *collection)
-{
- default_t *defaults = collection->defaults;
- int i;
- FILE* f;
- char defname[80];
- char strparm[100];
-
- // read the file in, overriding any set defaults
- f = fopen(collection->filename, "r");
-
- if (!f)
- {
- // File not opened, but don't complain
-
- return;
- }
-
- while (!feof(f))
- {
- if (fscanf (f, "%79s %[^\n]\n", defname, strparm) != 2)
- {
- // This line doesn't match
-
- continue;
- }
-
- // Strip off trailing non-printable characters (\r characters
- // from DOS text files)
-
- while (strlen(strparm) > 0 && !isprint(strparm[strlen(strparm)-1]))
- {
- strparm[strlen(strparm)-1] = '\0';
- }
-
- // Find the setting in the list
-
- for (i=0; i<collection->numdefaults; ++i)
- {
- default_t *def = &collection->defaults[i];
- char *s;
- int intparm;
-
- if (strcmp(defname, def->name) != 0)
- {
- // not this one
- continue;
- }
-
- // parameter found
-
- switch (def->type)
- {
- case DEFAULT_STRING:
- s = strdup(strparm + 1);
- s[strlen(s) - 1] = '\0';
- * (char **) def->location = s;
- break;
-
- case DEFAULT_INT:
- * (int *) def->location = ParseIntParameter(strparm);
- break;
-
- case DEFAULT_KEY:
-
- // translate scancodes read from config
- // file (save the old value in untranslated)
-
- intparm = ParseIntParameter(strparm);
- defaults[i].untranslated = intparm;
- intparm = scantokey[intparm];
-
- defaults[i].original_translated = intparm;
- * (int *) def->location = intparm;
- break;
-
- case DEFAULT_FLOAT:
- * (float *) def->location = atof(strparm);
- break;
- }
-
- // finish
-
- break;
- }
- }
-
- fclose (f);
-}
-
-//
-// M_SaveDefaults
-//
-
-void M_SaveDefaults (void)
-{
- SaveDefaultCollection(&doom_defaults);
- SaveDefaultCollection(&extra_defaults);
-}
-
-
-//
-// M_LoadDefaults
-//
-
-void M_LoadDefaults (void)
-{
- int i;
-
- // check for a custom default file
- i = M_CheckParm ("-config");
-
- if (i && i<myargc-1)
- {
- doom_defaults.filename = myargv[i+1];
- printf (" default file: %s\n",doom_defaults.filename);
- }
- else
- {
- doom_defaults.filename = malloc(strlen(configdir) + 20);
- sprintf(doom_defaults.filename, "%sdefault.cfg", configdir);
- }
-
-// printf("saving config in %s\n", doom_defaults.filename);
-
- i = M_CheckParm("-extraconfig");
-
- if (i && i<myargc-1)
- {
- extra_defaults.filename = myargv[i+1];
- printf(" extra configuration file: %s\n",
- extra_defaults.filename);
- }
- else
- {
- extra_defaults.filename
- = malloc(strlen(configdir) + strlen(PACKAGE_TARNAME) + 10);
- sprintf(extra_defaults.filename, "%s%s.cfg",
- configdir, PACKAGE_TARNAME);
- }
-
- LoadDefaultCollection(&doom_defaults);
- LoadDefaultCollection(&extra_defaults);
-}
-
-//
-// Save normal (default.cfg) defaults to a given file
-//
-
-void M_SaveMainDefaults(char *filename)
-{
- char *main_filename;
-
- // Save the normal filename and set this one
-
- main_filename = doom_defaults.filename;
- doom_defaults.filename = filename;
-
- // Save the file
-
- SaveDefaultCollection(&doom_defaults);
-
- // Restore the normal filename
-
- doom_defaults.filename = main_filename;
-}
-
-//
-// Save extra (chocolate-doom.cfg) defaults to a given file
-//
-
-void M_SaveExtraDefaults(char *filename)
-{
- char *main_filename;
-
- // Save the normal filename and set this one
-
- main_filename = extra_defaults.filename;
- extra_defaults.filename = filename;
-
- // Save the file
-
- SaveDefaultCollection(&extra_defaults);
-
- // Restore the normal filename
-
- extra_defaults.filename = main_filename;
-}
-
diff --git a/setup/configfile.h b/setup/configfile.h
deleted file mode 100644
index f7c6156e..00000000
--- a/setup/configfile.h
+++ /dev/null
@@ -1,42 +0,0 @@
-// Emacs style mode select -*- C++ -*-
-//-----------------------------------------------------------------------------
-//
-// Copyright(C) 1993-1996 Id Software, Inc.
-// Copyright(C) 2005 Simon Howard
-//
-// This program is free software; you can redistribute it and/or
-// modify it under the terms of the GNU General Public License
-// as published by the Free Software Foundation; either version 2
-// of the License, or (at your option) any later version.
-//
-// 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., 59 Temple Place - Suite 330, Boston, MA
-// 02111-1307, USA.
-//
-// DESCRIPTION:
-//
-//
-//-----------------------------------------------------------------------------
-
-
-#ifndef __SETUP_CONFIG__
-#define __SETUP_CONFIG__
-
-extern char *configdir;
-
-void M_LoadDefaults (void);
-void M_SaveDefaults (void);
-
-void M_SetConfigDir(void);
-
-void M_SaveMainDefaults(char *filename);
-void M_SaveExtraDefaults(char *filename);
-
-#endif
-
diff --git a/src/Makefile.am b/src/Makefile.am
index 8f9f11d3..8e1e7544 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -1,22 +1,30 @@
-SUBDIRS=doom heretic hexen
+SUBDIRS=doom heretic hexen setup
gamesdir = $(prefix)/games
games_PROGRAMS = chocolate-doom \
chocolate-heretic \
chocolate-hexen \
- chocolate-server
+ chocolate-server \
+ chocolate-setup
AM_CFLAGS = -Idoom -I../textscreen -I../pcsound @SDL_CFLAGS@ @SDLMIXER_CFLAGS@ @SDLNET_CFLAGS@
+# Common source files used by absolutely everything:
+
+COMMON_SOURCE_FILES=\
+i_main.c \
+i_system.c i_system.h \
+m_argv.c m_argv.h \
+m_misc.c m_misc.h
+
+# Dedicated server (chocolate-server):
+
DEDSERV_FILES=\
d_dedicated.c \
d_mode.c d_mode.h \
-i_main.c \
i_timer.c i_timer.h \
-m_argv.c m_argv.h \
-m_misc.c m_misc.h \
net_common.c net_common.h \
net_dedicated.c net_dedicated.h \
net_io.c net_io.h \
@@ -26,10 +34,12 @@ net_server.c net_server.h \
net_structrw.c net_structrw.h \
z_native.c z_zone.h
-chocolate_server_SOURCES=$(DEDSERV_FILES)
+chocolate_server_SOURCES=$(COMMON_SOURCE_FILES) $(DEDSERV_FILES)
chocolate_server_LDADD = @LDFLAGS@ @SDL_LIBS@ @SDLNET_LIBS@
-MAIN_SOURCE_FILES=\
+# Source files used by the game binaries (chocolate-doom, etc.)
+
+GAME_SOURCE_FILES=\
d_event.c d_event.h \
doomkeys.h \
doomfeatures.h \
@@ -38,22 +48,19 @@ d_iwad.c d_iwad.h \
d_mode.c d_mode.h \
d_ticcmd.h \
i_cdmus.c i_cdmus.h \
-i_main.c \
+i_endoom.c i_endoom.h \
i_joystick.c i_joystick.h \
i_scale.c i_scale.h \
i_swap.h \
i_sound.c i_sound.h \
-i_system.c i_system.h \
i_timer.c i_timer.h \
i_video.c i_video.h \
i_videohr.c i_videohr.h \
-m_argv.c m_argv.h \
m_bbox.c m_bbox.h \
m_cheat.c m_cheat.h \
m_config.c m_config.h \
m_controls.c m_controls.h \
m_fixed.c m_fixed.h \
-m_misc.c m_misc.h \
md5.c md5.h \
memio.c memio.h \
tables.c tables.h \
@@ -65,7 +72,7 @@ w_file.c w_file.h \
w_file_stdc.c \
w_file_posix.c \
w_file_win32.c \
-z_zone.c z_zone.h
+z_zone.c z_zone.h
# source files needed for FEATURE_DEHACKED
@@ -101,7 +108,8 @@ i_sdlsound.c \
i_sdlmusic.c \
mus2mid.c mus2mid.h
-SOURCE_FILES = $(MAIN_SOURCE_FILES) \
+SOURCE_FILES = $(COMMON_SOURCE_FILES) \
+ $(GAME_SOURCE_FILES) \
$(FEATURE_DEHACKED_SOURCE_FILES) \
$(FEATURE_WAD_MERGE_SOURCE_FILES) \
$(FEATURE_SOUND_SOURCE_FILES)
@@ -138,6 +146,17 @@ endif
chocolate_hexen_LDADD = hexen/libhexen.a $(EXTRA_LIBS)
+# Source files needed for chocolate-setup:
+
+SETUP_FILES= \
+m_config.c m_config.h \
+z_native.c z_zone.h
+
+chocolate_setup_SOURCES=$(SETUP_FILES) $(COMMON_SOURCE_FILES)
+chocolate_setup_LDADD = setup/libsetup.a \
+ ../textscreen/libtextscreen.a \
+ @LDFLAGS@ @SDL_LIBS@ @SDLNET_LIBS@
+
EXTRA_DIST = \
icon.c \
doom-screensaver.desktop.in
diff --git a/src/d_dedicated.c b/src/d_dedicated.c
index 158fa40c..defe8083 100644
--- a/src/d_dedicated.c
+++ b/src/d_dedicated.c
@@ -43,29 +43,6 @@ void NET_CL_Run(void)
// In a standalone dedicated server, we don't have a client.
}
-//
-// I_Error
-//
-// We have our own I_Error function for the dedicated server.
-// The normal one does extra things like shutdown graphics, etc.
-
-void I_Error (char *error, ...)
-{
- va_list argptr;
-
- // Message first.
- va_start(argptr,error);
- fprintf(stderr, "Error: ");
- vfprintf(stderr,error,argptr);
- fprintf(stderr, "\n");
- va_end(argptr);
-
- fflush(stderr);
-
- exit(-1);
-}
-
-
void D_DoomMain(void)
{
printf(PACKAGE_NAME " standalone dedicated server\n");
diff --git a/src/doom/d_main.c b/src/doom/d_main.c
index 419e871c..91224e88 100644
--- a/src/doom/d_main.c
+++ b/src/doom/d_main.c
@@ -60,6 +60,8 @@
#include "m_menu.h"
#include "p_saveg.h"
+#include "i_endoom.h"
+#include "i_joystick.h"
#include "i_system.h"
#include "i_timer.h"
#include "i_video.h"
@@ -346,7 +348,10 @@ void D_BindVariables(void)
{
int i;
- I_BindVariables();
+ I_BindVideoVariables();
+ I_BindJoystickVariables();
+ I_BindSoundVariables();
+
M_BindBaseControls();
#ifdef FEATURE_MULTIPLAYER
NET_BindVariables();
@@ -1674,7 +1679,9 @@ void D_DoomMain (void)
P_Init ();
printf (DEH_String("I_Init: Setting up machine state.\n"));
- I_Init ();
+ I_CheckIsScreensaver();
+ I_InitTimer();
+ I_InitJoystick();
#ifdef FEATURE_MULTIPLAYER
printf ("NET_Init: Initialise network subsystem.\n");
diff --git a/src/heretic/d_main.c b/src/heretic/d_main.c
index 2ac92b44..b8edd430 100644
--- a/src/heretic/d_main.c
+++ b/src/heretic/d_main.c
@@ -34,7 +34,11 @@
#include "ct_chat.h"
#include "doomdef.h"
#include "d_iwad.h"
+#include "i_endoom.h"
+#include "i_joystick.h"
+#include "i_sound.h"
#include "i_system.h"
+#include "i_timer.h"
#include "i_video.h"
#include "m_argv.h"
#include "m_config.h"
@@ -744,7 +748,9 @@ void D_BindVariables(void)
extern int snd_Channels;
int i;
- I_BindVariables();
+ I_BindVideoVariables();
+ I_BindJoystickVariables();
+ I_BindSoundVariables();
M_BindBaseControls();
M_BindHereticControls();
@@ -975,7 +981,9 @@ void D_DoomMain(void)
IncThermo();
tprintf("I_Init: Setting up machine state.\n", 1);
- I_Init();
+ I_CheckIsScreensaver();
+ I_InitTimer();
+ I_InitJoystick();
IncThermo();
tprintf("S_Init: Setting up sound.\n", 1);
diff --git a/src/hexen/h2_main.c b/src/hexen/h2_main.c
index f1d6ca90..f7bc665e 100644
--- a/src/hexen/h2_main.c
+++ b/src/hexen/h2_main.c
@@ -42,7 +42,9 @@
#include "d_mode.h"
#include "m_misc.h"
#include "s_sound.h"
+#include "i_joystick.h"
#include "i_system.h"
+#include "i_timer.h"
#include "m_argv.h"
#include "m_config.h"
#include "m_controls.h"
@@ -154,7 +156,9 @@ void D_BindVariables(void)
{
int i;
- I_BindVariables();
+ I_BindVideoVariables();
+ I_BindJoystickVariables();
+ I_BindSoundVariables();
M_BindBaseControls();
M_BindHereticControls();
M_BindHexenControls();
@@ -296,7 +300,9 @@ void D_DoomMain(void)
ST_Message("SN_InitSequenceScript: Registering sound sequences.\n");
SN_InitSequenceScript();
ST_Message("I_Init: Setting up machine state.\n");
- I_Init();
+ I_CheckIsScreensaver();
+ I_InitTimer();
+ I_InitJoystick();
S_Init();
S_Start();
diff --git a/setup/m_argv.c b/src/i_endoom.c
index ae9ab917..b943e47c 100644
--- a/setup/m_argv.c
+++ b/src/i_endoom.c
@@ -1,9 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// Copyright(C) 1993-1996 Id Software, Inc.
-// Copyright(C) 2005 Simon Howard
-// Copyright(C) 2008 "GhostlyDeath" (ghostlydeath@gmail.com)
+// Copyright(C) 2005-8 Simon Howard
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
@@ -21,45 +19,53 @@
// 02111-1307, USA.
//
// DESCRIPTION:
+// Exit text-mode ENDOOM screen.
//
//-----------------------------------------------------------------------------
+#include "doomtype.h"
+#include "i_video.h"
+#include "txt_main.h"
-#include <string.h>
+//
+// Displays the text mode ending screen after the game quits
+//
-int myargc;
-char** myargv;
+void I_Endoom(byte *endoom_data)
+{
+ unsigned char *screendata;
-// From doomdef.h -- no need to include it all!
-#ifdef _WIN32
-#define snprintf _snprintf
-#define vsnprintf _vsnprintf
-#define strcasecmp stricmp
-#define strncasecmp strnicmp
-#else
-#include <strings.h>
-#endif
+ // Set up text mode screen
-//
-// M_CheckParm
-// Checks for the given parameter
-// in the program's command line arguments.
-// Returns the argument number (1 to argc-1)
-// or 0 if not present
-int M_CheckParm (char *check)
-{
- int i;
+ TXT_Init();
+
+ // Make sure the new window has the right title and icon
+
+ I_SetWindowTitle("Exit screen");
+ I_SetWindowIcon();
+
+ // Write the data to the screen memory
+
+ screendata = TXT_GetScreenData();
+ memcpy(screendata, endoom_data, 4000);
- for (i = 1;i<myargc;i++)
+ // Wait for a keypress
+
+ while (true)
{
- if ( !strcasecmp(check, myargv[i]) )
- return i;
- }
+ TXT_UpdateScreen();
- return 0;
-}
+ if (TXT_GetChar() >= 0)
+ {
+ break;
+ }
+ TXT_Sleep(0);
+ }
+ // Shut down text mode screen
+ TXT_Shutdown();
+}
diff --git a/setup/m_argv.h b/src/i_endoom.h
index bd1518b9..b4fa34dd 100644
--- a/setup/m_argv.h
+++ b/src/i_endoom.h
@@ -20,23 +20,18 @@
// 02111-1307, USA.
//
// DESCRIPTION:
-// Nil.
-//
+// Exit text-mode ENDOOM screen.
+//
//-----------------------------------------------------------------------------
-#ifndef __M_ARGV__
-#define __M_ARGV__
+#ifndef __I_ENDOOM__
+#define __I_ENDOOM__
-//
-// MISC
-//
-extern int myargc;
-extern char** myargv;
-
-// Returns the position of the given parameter
-// in the arg list (0 if not found).
-int M_CheckParm (char* check);
+// Display the Endoom screen on shutdown. Pass a pointer to the
+// ENDOOM lump.
+void I_Endoom(byte *data);
#endif
+
diff --git a/src/i_system.c b/src/i_system.c
index 77c06436..1003075f 100644
--- a/src/i_system.c
+++ b/src/i_system.c
@@ -51,7 +51,6 @@
#include "i_video.h"
#include "i_system.h"
-#include "txt_main.h"
#include "w_wad.h"
#include "z_zone.h"
@@ -178,53 +177,21 @@ boolean I_ConsoleStdout(void)
//
// I_Init
//
+/*
void I_Init (void)
{
I_CheckIsScreensaver();
I_InitTimer();
I_InitJoystick();
}
-
-//
-// Displays the text mode ending screen after the game quits
-//
-
-void I_Endoom(byte *endoom_data)
+void I_BindVariables(void)
{
- unsigned char *screendata;
-
- // Set up text mode screen
-
- TXT_Init();
-
- // Make sure the new window has the right title and icon
-
- I_SetWindowTitle("Exit screen");
- I_SetWindowIcon();
-
- // Write the data to the screen memory
-
- screendata = TXT_GetScreenData();
- memcpy(screendata, endoom_data, 4000);
-
- // Wait for a keypress
-
- while (true)
- {
- TXT_UpdateScreen();
-
- if (TXT_GetChar() >= 0)
- {
- break;
- }
-
- TXT_Sleep(0);
- }
-
- // Shut down text mode screen
-
- TXT_Shutdown();
+ I_BindVideoVariables();
+ I_BindJoystickVariables();
+ I_BindSoundVariables();
}
+*/
+
//
// I_Quit
@@ -247,11 +214,6 @@ void I_Quit (void)
exit(0);
}
-void I_WaitVBL(int count)
-{
- I_Sleep((count * 1000) / 70);
-}
-
//
// I_Error
//
@@ -314,10 +276,3 @@ void I_Error (char *error, ...)
exit(-1);
}
-void I_BindVariables(void)
-{
- I_BindVideoVariables();
- I_BindJoystickVariables();
- I_BindSoundVariables();
-}
-
diff --git a/src/i_system.h b/src/i_system.h
index 2af3aa33..b34f61e4 100644
--- a/src/i_system.h
+++ b/src/i_system.h
@@ -80,11 +80,6 @@ void I_AtExit(atexit_func_t func, boolean run_if_error);
void I_BindVariables(void);
-// Display the Endoom screen on shutdown. Pass a pointer to the
-// ENDOOM lump.
-
-void I_Endoom(byte *data);
-
// Print startup banner copyright message.
void I_PrintStartupBanner(char *gamedescription);
diff --git a/src/i_timer.c b/src/i_timer.c
index 8ae68b82..ef97b7b7 100644
--- a/src/i_timer.c
+++ b/src/i_timer.c
@@ -73,6 +73,11 @@ void I_Sleep(int ms)
SDL_Delay(ms);
}
+void I_WaitVBL(int count)
+{
+ I_Sleep((count * 1000) / 70);
+}
+
void I_InitTimer(void)
{
diff --git a/src/i_timer.h b/src/i_timer.h
index 85816064..17390884 100644
--- a/src/i_timer.h
+++ b/src/i_timer.h
@@ -43,5 +43,8 @@ void I_Sleep(int ms);
// Initialise timer
void I_InitTimer(void);
+// Wait for vertical retrace or pause a bit.
+void I_WaitVBL(int count);
+
#endif
diff --git a/src/i_video.h b/src/i_video.h
index 5af31e92..1c668474 100644
--- a/src/i_video.h
+++ b/src/i_video.h
@@ -85,9 +85,6 @@ void I_SetPalette (byte* palette);
void I_UpdateNoBlit (void);
void I_FinishUpdate (void);
-// Wait for vertical retrace or pause a bit.
-void I_WaitVBL(int count);
-
void I_ReadScreen (byte* scr);
void I_BeginRead (void);
diff --git a/src/m_config.c b/src/m_config.c
index 4f92d09e..a4db1c98 100644
--- a/src/m_config.c
+++ b/src/m_config.c
@@ -981,6 +981,31 @@ void M_SaveDefaults (void)
}
//
+// Save defaults to alternate filenames
+//
+
+void M_SaveDefaultsAlternate(char *main, char *extra)
+{
+ char *orig_main;
+ char *orig_extra;
+
+ // Temporarily change the filenames
+
+ orig_main = doom_defaults.filename;
+ orig_extra = extra_defaults.filename;
+
+ doom_defaults.filename = main;
+ extra_defaults.filename = extra;
+
+ M_SaveDefaults();
+
+ // Restore normal filenames
+
+ doom_defaults.filename = orig_main;
+ extra_defaults.filename = orig_extra;
+}
+
+//
// M_LoadDefaults
//
diff --git a/src/m_config.h b/src/m_config.h
index 16468b5d..6f2bb894 100644
--- a/src/m_config.h
+++ b/src/m_config.h
@@ -30,6 +30,7 @@
void M_LoadDefaults(void);
void M_SaveDefaults(void);
+void M_SaveDefaultsAlternate(char *main, char *extra);
void M_SetConfigDir(void);
void M_BindVariable(char *name, void *variable);
void M_SetConfigFilenames(char *main_config, char *extra_config);
diff --git a/setup/setup-res.rc.in b/src/setup-res.rc.in
index dc25135a..dc25135a 100644
--- a/setup/setup-res.rc.in
+++ b/src/setup-res.rc.in
diff --git a/setup/.gitignore b/src/setup/.gitignore
index e2da8a59..e2da8a59 100644
--- a/setup/.gitignore
+++ b/src/setup/.gitignore
diff --git a/setup/Makefile.am b/src/setup/Makefile.am
index f845f853..6028eab7 100644
--- a/setup/Makefile.am
+++ b/src/setup/Makefile.am
@@ -1,18 +1,13 @@
-gamesdir = $(prefix)/games
+AM_CFLAGS = @SDL_CFLAGS@ -I../../textscreen -I.. -DINSTALL_DIR="\"$(gamesdir)\""
-AM_CFLAGS = @SDL_CFLAGS@ -I../textscreen -I../src -DINSTALL_DIR="\"$(gamesdir)\""
+noinst_LIBRARIES = libsetup.a
-games_PROGRAMS = chocolate-setup
-
-chocolate_setup_LDADD = ../textscreen/libtextscreen.a @LDFLAGS@ @SDL_LIBS@
SOURCE_FILES = \
compatibility.c compatibility.h \
- configfile.c configfile.h \
display.c display.h \
joystick.c joystick.h \
keyboard.c keyboard.h \
- m_argv.c m_argv.h \
mainmenu.c \
mouse.c mouse.h \
multiplayer.c multiplayer.h \
@@ -22,25 +17,9 @@ SOURCE_FILES = \
txt_keyinput.c txt_keyinput.h \
txt_mouseinput.c txt_mouseinput.h
+libsetup_a_SOURCES = $(SOURCE_FILES)
+
EXTRA_DIST= \
setup_icon.c \
setup-manifest.xml
-if HAVE_WINDRES
-chocolate_setup_SOURCES=$(SOURCE_FILES) setup-res.rc
-else
-chocolate_setup_SOURCES=$(SOURCE_FILES)
-endif
-
-.rc.o:
- $(WINDRES) $^ -o $@
-%.o : %.rc
- $(WINDRES) $^ -o $@
-
-if HAVE_PYTHON
-
-setup_icon.c : ../data/setup.ico
- ../data/convert-icon $^ $@
-
-endif
-
diff --git a/setup/compatibility.c b/src/setup/compatibility.c
index bebf5a87..bebf5a87 100644
--- a/setup/compatibility.c
+++ b/src/setup/compatibility.c
diff --git a/setup/compatibility.h b/src/setup/compatibility.h
index 1d46b174..1d46b174 100644
--- a/setup/compatibility.h
+++ b/src/setup/compatibility.h
diff --git a/setup/display.c b/src/setup/display.c
index 5e9d4fcf..5e9d4fcf 100644
--- a/setup/display.c
+++ b/src/setup/display.c
diff --git a/setup/display.h b/src/setup/display.h
index f0c76184..f0c76184 100644
--- a/setup/display.h
+++ b/src/setup/display.h
diff --git a/setup/execute.c b/src/setup/execute.c
index b5b8a7c6..9846cd20 100644
--- a/setup/execute.c
+++ b/src/setup/execute.c
@@ -38,9 +38,9 @@
#include "textscreen.h"
#include "config.h"
-#include "configfile.h"
#include "execute.h"
#include "m_argv.h"
+#include "m_config.h"
#ifdef _WIN32
#define DOOM_BINARY PACKAGE_TARNAME ".exe"
@@ -221,7 +221,7 @@ static void TestCallback(TXT_UNCAST_ARG(widget), TXT_UNCAST_ARG(data))
char *extra_cfg;
txt_window_t *testwindow;
txt_label_t *label;
-
+
testwindow = TXT_NewWindow("Starting Doom");
label = TXT_NewLabel("Starting Doom to test the\n"
@@ -235,8 +235,7 @@ static void TestCallback(TXT_UNCAST_ARG(widget), TXT_UNCAST_ARG(data))
main_cfg = TempFile("tmp.cfg");
extra_cfg = TempFile("extratmp.cfg");
- M_SaveMainDefaults(main_cfg);
- M_SaveExtraDefaults(extra_cfg);
+ M_SaveDefaultsAlternate(main_cfg, extra_cfg);
// Run with the -testcontrols parameter
diff --git a/setup/execute.h b/src/setup/execute.h
index 24711a16..24711a16 100644
--- a/setup/execute.h
+++ b/src/setup/execute.h
diff --git a/setup/joystick.c b/src/setup/joystick.c
index 69c0e508..69c0e508 100644
--- a/setup/joystick.c
+++ b/src/setup/joystick.c
diff --git a/setup/joystick.h b/src/setup/joystick.h
index 39cf0bf4..39cf0bf4 100644
--- a/setup/joystick.h
+++ b/src/setup/joystick.h
diff --git a/setup/keyboard.c b/src/setup/keyboard.c
index 3a7ccb8f..3a7ccb8f 100644
--- a/setup/keyboard.c
+++ b/src/setup/keyboard.c
diff --git a/setup/keyboard.h b/src/setup/keyboard.h
index 6442e1e4..6442e1e4 100644
--- a/setup/keyboard.h
+++ b/src/setup/keyboard.h
diff --git a/setup/mainmenu.c b/src/setup/mainmenu.c
index d4dfe0db..1585c96b 100644
--- a/setup/mainmenu.c
+++ b/src/setup/mainmenu.c
@@ -18,6 +18,7 @@
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
// 02111-1307, USA.
//
+
#include <stdlib.h>
#include "config.h"
@@ -25,8 +26,8 @@
#include "execute.h"
-#include "configfile.h"
#include "m_argv.h"
+#include "m_config.h"
#include "setup_icon.c"
@@ -42,7 +43,8 @@ static void DoQuit(void *widget, void *dosave)
{
if (dosave != NULL)
{
- M_SaveDefaults();
+ // DANGER: this is broken. Do not save.
+// M_SaveDefaults();
}
exit(0);
@@ -140,6 +142,7 @@ static void InitConfig(void)
SetChatMacroDefaults();
SetPlayerNameDefault();
+ M_SetConfigFilenames("default.cfg", "chocolate-doom.cfg");
M_SetConfigDir();
M_LoadDefaults();
}
@@ -207,14 +210,9 @@ static void RunGUI(void)
TXT_GUIMainLoop();
}
-int main(int argc, char *argv[])
+void D_DoomMain(void)
{
- myargc = argc;
- myargv = argv;
-
InitConfig();
RunGUI();
-
- return 0;
}
diff --git a/setup/mouse.c b/src/setup/mouse.c
index 49266d48..49266d48 100644
--- a/setup/mouse.c
+++ b/src/setup/mouse.c
diff --git a/setup/mouse.h b/src/setup/mouse.h
index f0a39ade..f0a39ade 100644
--- a/setup/mouse.h
+++ b/src/setup/mouse.h
diff --git a/setup/multiplayer.c b/src/setup/multiplayer.c
index cbc76dde..b1f1d67b 100644
--- a/setup/multiplayer.c
+++ b/src/setup/multiplayer.c
@@ -22,15 +22,14 @@
#include <stdlib.h>
#include <string.h>
-#include "d_englsh.h"
+#include "doom/d_englsh.h"
#include "textscreen.h"
#include "doomtype.h"
-#include "configfile.h"
-
#include "execute.h"
#include "multiplayer.h"
+#include "m_config.h"
#define NUM_WADS 10
#define NUM_EXTRA_PARAMS 10
diff --git a/setup/multiplayer.h b/src/setup/multiplayer.h
index b9871ed5..b9871ed5 100644
--- a/setup/multiplayer.h
+++ b/src/setup/multiplayer.h
diff --git a/setup/setup-manifest.xml b/src/setup/setup-manifest.xml
index 74dd5493..74dd5493 100644
--- a/setup/setup-manifest.xml
+++ b/src/setup/setup-manifest.xml
diff --git a/setup/setup_icon.c b/src/setup/setup_icon.c
index 1c18c56f..1c18c56f 100644
--- a/setup/setup_icon.c
+++ b/src/setup/setup_icon.c
diff --git a/setup/sound.c b/src/setup/sound.c
index 72414c83..72414c83 100644
--- a/setup/sound.c
+++ b/src/setup/sound.c
diff --git a/setup/sound.h b/src/setup/sound.h
index 170dda0a..170dda0a 100644
--- a/setup/sound.h
+++ b/src/setup/sound.h
diff --git a/setup/txt_joybinput.c b/src/setup/txt_joybinput.c
index 1e132962..1e132962 100644
--- a/setup/txt_joybinput.c
+++ b/src/setup/txt_joybinput.c
diff --git a/setup/txt_joybinput.h b/src/setup/txt_joybinput.h
index b2920b88..b2920b88 100644
--- a/setup/txt_joybinput.h
+++ b/src/setup/txt_joybinput.h
diff --git a/setup/txt_keyinput.c b/src/setup/txt_keyinput.c
index b7e68f44..b7e68f44 100644
--- a/setup/txt_keyinput.c
+++ b/src/setup/txt_keyinput.c
diff --git a/setup/txt_keyinput.h b/src/setup/txt_keyinput.h
index 4952a970..4952a970 100644
--- a/setup/txt_keyinput.h
+++ b/src/setup/txt_keyinput.h
diff --git a/setup/txt_mouseinput.c b/src/setup/txt_mouseinput.c
index 05c89b39..05c89b39 100644
--- a/setup/txt_mouseinput.c
+++ b/src/setup/txt_mouseinput.c
diff --git a/setup/txt_mouseinput.h b/src/setup/txt_mouseinput.h
index 57c258eb..57c258eb 100644
--- a/setup/txt_mouseinput.h
+++ b/src/setup/txt_mouseinput.h