X-Git-Url: http://git.asbjorn.biz/?p=debian%2Fdhcpd-pools.git;a=blobdiff_plain;f=src%2Fgetdata.c;fp=src%2Fgetdata.c;h=133485583e462d4f6f1e8f614d0b5eaed6a10524;hp=c57d2c73813533f6691962fbc9d6c30e60edc807;hb=b492802dfa7bf928bbafe74194ca4f154c70f743;hpb=f6880ed5f48e1591007246760a64cfc33d5f1eb4 diff --git a/src/getdata.c b/src/getdata.c index c57d2c7..1334855 100644 --- a/src/getdata.c +++ b/src/getdata.c @@ -386,9 +386,14 @@ char *parse_config(int is_include, char *config_file, range_p->backups = 0; range_p->shared_net = shared_p; num_ranges++; - if (RANGES < num_ranges) { - errx(EXIT_FAILURE, - "parse_config: increase default.h RANGES and recompile."); + if (RANGES < num_ranges + 1) { + RANGES *= 2; + ranges = + safe_realloc(ranges, + sizeof(struct + range_t) * + RANGES); + range_p = ranges + num_ranges; } newclause = true; break; @@ -429,13 +434,14 @@ char *parse_config(int is_include, char *config_file, errx(EXIT_FAILURE, "parse_config: increase default.h SHARED_NETWORKS_NAMES and recompile"); } - if (SHARED_NETWORKS < num_shared_networks) { - /* FIXME: make this go + if (SHARED_NETWORKS < + num_shared_networks + 2) { + /* FIXME: make this * away by reallocationg * more space. */ errx(EXIT_FAILURE, "parse_config: increase default.h SHARED_NETWORKS and recompile"); - } + } argument = 0; braces_shared = braces; break;