#endif
#include <stdio.h>
-#ifdef HAVE_UNISTD_H
-#include <unistd.h>
-#endif
#ifdef HAVE_STDLIB_H
#include <stdlib.h>
#else /* Not STDC_HEADERS */
#else
#include <strings.h>
#endif
-#include <getopt.h>
-#include <errno.h>
#include <err.h>
+#include <errno.h>
+#include <getopt.h>
-#include "dhcpd-pools.h"
#include "defaults.h"
+#include "dhcpd-pools.h"
int main(int argc, char **argv)
{
case 'v':
/* Print version */
print_version();
- return (EXIT_SUCCESS);
case 'h':
/* Print help */
usage(EXIT_SUCCESS);
/* Do the job */
prepare_memory();
- parse_config(true, config.dhcpdconf_file, shared_net_names,
- shared_net_names + strlen(shared_net_names) + 1,
- shared_networks);
+ parse_config(true, config.dhcpdconf_file, shared_networks);
parse_leases();
prepare_data();
}
free(tmp_ranges);
output_analysis();
- /* After fopen in ouput ioctl does like /dev/null which
- * cause ENOTTY, and clean_up will see that without this
- * reset. At least linux does this, and possibly some
- * other systems. There's a report from FreeBSD 8.0 which
- * matches quite well with the symptom. */
- if (errno == 25)
- errno = 0;
clean_up();
return (EXIT_SUCCESS);
/* Global allocations, counter resets etc */
int prepare_memory()
{
+ RANGES = 64;
num_ranges = num_shared_networks = 0;
shared_networks =
safe_malloc(sizeof(struct shared_network_t) * SHARED_NETWORKS);
- shared_net_names =
- safe_malloc(sizeof(char) * SHARED_NETWORKS_NAMES);
ranges = safe_malloc(sizeof(struct range_t) * RANGES);
macaddr = NULL;
/* First shared network entry is all networks */
- strcpy(shared_net_names, "All networks");
+ shared_networks->name = safe_strdup("All networks");
+
return 0;
}