]> code.citadel.org Git - citadel.git/blobdiff - citadel/config.c
* setup.c: updated to use new built-in daemonization
[citadel.git] / citadel / config.c
index f5d4750e5f9744d56e0424f73885e45f4f70ad72..e1728a524be21810b06255bba0a3613c03752cb8 100644 (file)
@@ -20,8 +20,6 @@
 #include "config.h"
 
 struct config config;
-char ctdl_home_directory[PATH_MAX] = CTDLDIR;
-int home_specified = 0;
 
 /*
  * get_config() is called during the initialization of any program which
@@ -39,32 +37,27 @@ void get_config(void) {
                        "Error: %s\n",
                        (home_specified ? ctdl_home_directory : CTDLDIR),
                        strerror(errno));
-               exit(1);
+               exit(CTDLEXIT_HOME);
        }
-       cfp = fopen(
-#ifndef HAVE_ETC_DIR
-                               "."
-#else
-                               ETC_DIR
-#endif
-                               "/citadel.config", "rb");
+       cfp = fopen(file_citadel_config, "rb");
        if (cfp == NULL) {
                fprintf(stderr, "This program could not be started.\n"
-                       "Unable to open %s/citadel.config\n"
-                       "Error: %s\n",
-                       (home_specified ? ctdl_home_directory : CTDLDIR),
-                       strerror(errno));
-               exit(1);
+                               "Unable to open %s\n"
+                               "Error: %s\n",
+                               file_citadel_config,
+                               strerror(errno));
+               exit(CTDLEXIT_CONFIG);
        }
        fread((char *) &config, sizeof(struct config), 1, cfp);
        if (fstat(fileno(cfp), &st)) {
-               perror("citadel.config");
-               exit(1);
+               perror(file_citadel_config);
+               exit(CTDLEXIT_CONFIG);
        }
 #ifndef __CYGWIN__
        if (st.st_uid != CTDLUID || st.st_mode != (S_IFREG | S_IRUSR | S_IWUSR)) {
-               fprintf(stderr, "check the permissions on citadel.config\n");
-               exit(1);
+               fprintf(stderr, "check the permissions on %s\n", file_citadel_config);
+               //              fprintf(stderr, "check the permissions on citadel.config\n");
+               exit(CTDLEXIT_CONFIG);
        }
 #endif
        fclose(cfp);
@@ -79,7 +72,7 @@ void get_config(void) {
                        "        Data files are currently at %d.%02d\n",
                        (config.c_setup_level / 100),
                        (config.c_setup_level % 100));
-               exit(1);
+               exit(CTDLEXIT_OOD);
        }
 
         /* Default maximum message length is 10 megabytes.  This is site
@@ -118,14 +111,8 @@ void put_config(void)
 {
        FILE *cfp;
 
-       if ((cfp = fopen(
-#ifndef HAVE_ETC_DIR
-                                        "."
-#else
-                                        ETC_DIR
-#endif
-                                        "/citadel.config", "rb+")) == NULL)
-               perror("citadel.config");
+       if ((cfp = fopen(file_citadel_config, "rb+")) == NULL)
+               perror(file_citadel_config);
        else {
                fwrite((char *) &config, sizeof(struct config), 1, cfp);
                fclose(cfp);