summaryrefslogtreecommitdiff
path: root/app/xfs/os/config.c
diff options
context:
space:
mode:
Diffstat (limited to 'app/xfs/os/config.c')
-rw-r--r--app/xfs/os/config.c44
1 files changed, 40 insertions, 4 deletions
diff --git a/app/xfs/os/config.c b/app/xfs/os/config.c
index e5dbc4801..1abf2afff 100644
--- a/app/xfs/os/config.c
+++ b/app/xfs/os/config.c
@@ -49,6 +49,8 @@ in this Software without prior written authorization from The Open Group.
*/
/* $XFree86: xc/programs/xfs/os/config.c,v 3.15 2002/05/31 18:46:12 dawes Exp $ */
+#include <xfs-config.h>
+
#include <stdio.h>
#include <stdlib.h>
#include <ctype.h>
@@ -66,6 +68,15 @@ in this Software without prior written authorization from The Open Group.
#include <X11/fonts/fontutil.h>
#include "difs.h"
+static const char * const default_config_files[] = {
+#ifdef DEFAULT_CONFIG_FILE
+ DEFAULT_CONFIG_FILE,
+#else
+ "/usr/lib/X11/fs/config",
+#endif
+ NULL
+};
+
extern int portFromCmdline;
static char *font_catalogue = NULL;
@@ -285,6 +296,10 @@ SetConfigValues(void)
int err,
num;
+ if (font_catalogue == NULL) {
+ FatalError("font catalogue is missing/empty\n");
+ }
+
err = SetFontCatalogue(font_catalogue, &num);
if (err != FSSuccess) {
FatalError("element #%d (starting at 0) of font path is bad or has a bad font:\n\"%s\"\n",
@@ -315,12 +330,14 @@ char *__XFSRedirRoot(char *fname)
}
#endif
+/* If argument is NULL, uses first file found from default_config_files */
int
-ReadConfigFile(char *filename)
+ReadConfigFile(const char *filename)
{
FILE *fp;
int ret;
int len;
+ int i;
char *data;
data = (char *) fsalloc(CONFIG_MAX_FILESIZE);
@@ -328,12 +345,31 @@ ReadConfigFile(char *filename)
ErrorF(ConfigErrors[CONFIG_ERR_MEMORY], filename);
return FSBadAlloc;
}
+ if (filename != NULL) {
#ifdef __UNIXOS2__
- filename = __XFSRedirRoot(filename);
+ filename = __XFSRedirRoot(filename);
#endif
- if ((fp = fopen(filename, "r")) == NULL) {
+ fp = fopen(filename, "r");
+ if (fp == NULL) {
+ ErrorF(ConfigErrors[CONFIG_ERR_OPEN], filename);
+ }
+ } else {
+ for (i = 0; default_config_files[i] != NULL; i++) {
+ filename = default_config_files[i];
+#ifdef __UNIXOS2__
+ filename = __XFSRedirRoot(filename);
+#endif
+ if ((fp = fopen(filename, "r")) != NULL)
+ break;
+ }
+ if (fp == NULL) {
+ for (i = 0; default_config_files[i] != NULL; i++) {
+ ErrorF(ConfigErrors[CONFIG_ERR_OPEN], default_config_files[i]);
+ }
+ }
+ }
+ if (fp == NULL) {
fsfree(data);
- ErrorF(ConfigErrors[CONFIG_ERR_OPEN], filename);
return FSBadName;
}
ret = fread(data, sizeof(char), CONFIG_MAX_FILESIZE, fp);