Commit bf64e60e authored by Juliusz Chroboczek's avatar Juliusz Chroboczek

Allow reading of multiple config files.

parent 5ebf4632
...@@ -101,7 +101,8 @@ main(int argc, char **argv) ...@@ -101,7 +101,8 @@ main(int argc, char **argv)
struct sockaddr_in6 sin6; struct sockaddr_in6 sin6;
int rc, fd, i, opt; int rc, fd, i, opt;
time_t expiry_time, source_expiry_time, kernel_dump_time; time_t expiry_time, source_expiry_time, kernel_dump_time;
const char *config_file = NULL; const char **config_files = NULL;
int num_config_files = 0;
void *vrc; void *vrc;
unsigned int seed; unsigned int seed;
struct interface *ifp; struct interface *ifp;
...@@ -232,7 +233,13 @@ main(int argc, char **argv) ...@@ -232,7 +233,13 @@ main(int argc, char **argv)
goto usage; goto usage;
break; break;
case 'c': case 'c':
config_file = optarg; config_files = realloc(config_files,
(num_config_files + 1) * sizeof(char*));
if(config_files == NULL) {
fprintf(stderr, "Couldn't allocate config file.\n");
exit(1);
}
config_files[num_config_files++] = optarg;
break; break;
case 'C': case 'C':
rc = parse_config_from_string(optarg); rc = parse_config_from_string(optarg);
...@@ -256,24 +263,27 @@ main(int argc, char **argv) ...@@ -256,24 +263,27 @@ main(int argc, char **argv)
} }
} }
if(!config_file) { if(num_config_files == 0) {
if(access("/etc/babeld.conf", F_OK) >= 0) if(access("/etc/babeld.conf", F_OK) >= 0) {
config_file = "/etc/babeld.conf"; config_files = malloc(sizeof(char*));
if(config_files == NULL) {
fprintf(stderr, "Couldn't allocate config file.\n");
exit(1);
}
config_files[num_config_files++] = "/etc/babeld.conf";
} }
if(config_file) { }
for(i = 0; i < num_config_files; i++) {
int line; int line;
rc = parse_config_from_file(config_file, &line); rc = parse_config_from_file(config_files[i], &line);
if(rc < 0) { if(rc < 0) {
fprintf(stderr, fprintf(stderr,
"Couldn't parse configuration from file %s " "Couldn't parse configuration from file %s "
"(error at line %d).\n", "(error at line %d).\n",
config_file, line); config_files[i], line);
exit(1); exit(1);
} }
} else {
if(access("/etc/babel.conf", F_OK) >= 0)
fprintf(stderr,
"Warning: /etc/babel.conf exists, it will be ignored.\n");
} }
if(default_wireless_hello_interval <= 0) if(default_wireless_hello_interval <= 0)
......
...@@ -120,7 +120,8 @@ specified multiple times in order to export routes from more than one ...@@ -120,7 +120,8 @@ specified multiple times in order to export routes from more than one
table. table.
.TP .TP
.BI \-c " filename" .BI \-c " filename"
Specify the name of the configuration file. The default is Specify the name of the configuration file. This flag can be repeated
multiple times. The default is
.BR /etc/babeld.conf . .BR /etc/babeld.conf .
.TP .TP
.BI \-C " statement" .BI \-C " statement"
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment