shithub: choc

Download patch

ref: 3ae824b5b4c0f92a3ed3fe5a7274bbba6337e2ee
parent: 7d03bfc3f1cc2e871ea4efe94b4377bfec4ae253
author: Simon Howard <fraggle@gmail.com>
date: Mon Oct 23 13:48:38 EDT 2006

Move MakeDirectory function into m_misc.c. Move configdir related code
into m_misc.c.

Subversion-branch: /trunk/chocolate-doom
Subversion-revision: 715

--- a/src/d_main.c
+++ b/src/d_main.c
@@ -38,14 +38,6 @@
 #include <stdlib.h>
 #include <string.h>
 
-#ifdef _WIN32
-#include <io.h>
-#else
-#include <sys/stat.h>
-#include <sys/types.h>
-#endif
-
-
 #include "config.h"
 #include "deh_main.h"
 #include "doomdef.h"
@@ -102,11 +94,6 @@
 //
 void D_DoomLoop (void);
 
-// Location where all configuration data is stored - 
-// default.cfg, savegames, etc.
-
-char *          configdir;
-
 // Location where savegames are stored
 
 char *          savegamedir;
@@ -1142,64 +1129,7 @@
     }
 }
 
-static void 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.
-//
-
-static void SetConfigDir(void)
-{
-    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
-
-        MakeDirectory(configdir);
-        
-
-    }
-    else
-    {
-#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\\");
-        }
-        else
-#endif
-        {
-            configdir = strdup("");
-        }
-    }
-}
-
-// 
 // SetSaveGameDir
 //
 // Chooses the directory used to store saved games.
@@ -1222,7 +1152,7 @@
         savegamedir = malloc(strlen(configdir) + 30);
         sprintf(savegamedir, "%ssavegames", configdir);
 
-        MakeDirectory(savegamedir);
+        M_MakeDirectory(savegamedir);
 
         // Find what subdirectory to use for savegames
         //
@@ -1243,7 +1173,7 @@
                 strcat(savegamedir, "/");
                 strcat(savegamedir, iwads[i].name);
                 strcat(savegamedir, "/");
-                MakeDirectory(savegamedir);
+                M_MakeDirectory(savegamedir);
                 break;
             }
         }
@@ -1418,7 +1348,7 @@
     
     // find which dir to use for config files
 
-    SetConfigDir();
+    M_SetConfigDir();
     
     // turbo option
     if ( (p=M_CheckParm ("-turbo")) )
--- a/src/doomstat.h
+++ b/src/doomstat.h
@@ -255,7 +255,6 @@
 //
 
 // File handling stuff.
-extern  char *          configdir;
 extern  char *          savegamedir;
 extern	char		basedefault[1024];
 extern  FILE*		debugfile;
--- a/src/m_misc.c
+++ b/src/m_misc.c
@@ -109,9 +109,22 @@
     return x;
 }
 
+//
+// Create a directory
+//
 
+void M_MakeDirectory(char *path)
+{
+#ifdef _WIN32
+    mkdir(path);
+#else
+    mkdir(path, 0755);
+#endif
+}
 
 
+
+
 //
 // M_WriteFile
 //
@@ -171,8 +184,12 @@
 // DEFAULTS
 //
 
-// locations of config files
+// Location where all configuration data is stored - 
+// default.cfg, savegames, etc.
 
+char *          configdir;
+
+
 int		usemouse = 1;
 int		usejoystick = 0;
 
@@ -593,6 +610,54 @@
     LoadDefaultCollection(&doom_defaults);
     LoadDefaultCollection(&extra_defaults);
 }
+
+// 
+// SetConfigDir:
+//
+// Sets the location of the configuration directory, where configuration
+// files are stored - default.cfg, chocolate-doom.cfg, savegames, etc.
+//
+
+void M_SetConfigDir(void)
+{
+    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
+    {
+#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("");
+        }
+    }
+}
+
 
 
 //
--- a/src/m_misc.h
+++ b/src/m_misc.h
@@ -53,7 +53,11 @@
 
 void M_SaveDefaults (void);
 
+void M_SetConfigDir(void);
 
+void M_MakeDirectory(char *dir);
+
+
 int
 M_DrawText
 ( int		x,
@@ -61,5 +65,6 @@
   boolean	direct,
   char*		string );
 
+extern char *configdir;
 
 #endif