Allow #include depth.

This commit is contained in:
Themaister 2011-10-17 20:09:57 +02:00
parent 80925ffc11
commit cce4b7d20c

View File

@ -39,6 +39,7 @@
#endif #endif
#endif #endif
#define MAX_INCLUDE_DEPTH 16
struct entry_list struct entry_list
{ {
@ -59,12 +60,12 @@ struct config_file
char *path; char *path;
struct entry_list *entries; struct entry_list *entries;
struct entry_list *tail; struct entry_list *tail;
bool recursive; unsigned include_depth;
struct include_list *includes; struct include_list *includes;
}; };
static config_file_t *config_file_new_internal(const char *path, bool recursive); static config_file_t *config_file_new_internal(const char *path, unsigned depth);
static char *getaline(FILE *file) static char *getaline(FILE *file)
{ {
@ -238,9 +239,7 @@ static void add_sub_conf(config_file_t *conf, char *line)
} }
#endif #endif
printf("Path = %s\n", real_path); config_file_t *sub_conf = config_file_new_internal(real_path, conf->include_depth + 1);
config_file_t *sub_conf = config_file_new_internal(real_path, true);
if (!sub_conf) if (!sub_conf)
{ {
free(path); free(path);
@ -261,7 +260,7 @@ static bool parse_line(config_file_t *conf, struct entry_list *list, char *line)
*comment = '\0'; *comment = '\0';
// Starting line with # and include includes config files. :) // Starting line with # and include includes config files. :)
if ((comment == line) && !conf->recursive) if ((comment == line) && (conf->include_depth < MAX_INCLUDE_DEPTH))
{ {
comment++; comment++;
if (strstr(comment, "include ") == comment) if (strstr(comment, "include ") == comment)
@ -270,6 +269,8 @@ static bool parse_line(config_file_t *conf, struct entry_list *list, char *line)
return false; return false;
} }
} }
else if (conf->include_depth >= MAX_INCLUDE_DEPTH)
fprintf(stderr, "!!! #include depth exceeded for config! Might be a cycle.\n");
// Skips to first character. // Skips to first character.
while (isspace(*line)) while (isspace(*line))
@ -303,7 +304,7 @@ static bool parse_line(config_file_t *conf, struct entry_list *list, char *line)
return true; return true;
} }
static config_file_t *config_file_new_internal(const char *path, bool recursive) static config_file_t *config_file_new_internal(const char *path, unsigned depth)
{ {
struct config_file *conf = calloc(1, sizeof(*conf)); struct config_file *conf = calloc(1, sizeof(*conf));
if (!conf) if (!conf)
@ -319,7 +320,7 @@ static config_file_t *config_file_new_internal(const char *path, bool recursive)
return NULL; return NULL;
} }
conf->recursive = recursive; conf->include_depth = depth;
FILE *file = fopen(path, "r"); FILE *file = fopen(path, "r");
if (!file) if (!file)
@ -363,7 +364,7 @@ static config_file_t *config_file_new_internal(const char *path, bool recursive)
config_file_t *config_file_new(const char *path) config_file_t *config_file_new(const char *path)
{ {
return config_file_new_internal(path, false); return config_file_new_internal(path, 0);
} }
void config_file_free(config_file_t *conf) void config_file_free(config_file_t *conf)