diff options
author | Elliott Hughes <enh@google.com> | 2019-10-29 22:50:30 -0700 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2019-11-03 19:03:07 -0600 |
commit | 3ead70e503b2809a250a70d161d525213f5328d8 (patch) | |
tree | d433896cf33abe4d37449e03d0080fb90691dfa9 | |
parent | dde512ac8001f5dc45de52fd82ccf6a8e5d4a138 (diff) | |
download | toybox-3ead70e503b2809a250a70d161d525213f5328d8.tar.gz |
ip: remove get_line().
-rw-r--r-- | toys/pending/ip.c | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/toys/pending/ip.c b/toys/pending/ip.c index 82e18fdb..cc86c19f 100644 --- a/toys/pending/ip.c +++ b/toys/pending/ip.c @@ -181,11 +181,13 @@ static void send_nlmesg(int type, int flags, int family, // Parse /etc/iproute2/RPDB_tables and prepare list. static void parseRPDB(char *fname, struct arglist **list, int32_t size) { - char *line; - int fd = open(fname, O_RDONLY); + FILE *fp = fopen(fname, "r"); + char *line = 0; + size_t l = 0; + ssize_t len; - if (fd < 0) return; - for (; (line = get_line(fd)); free(line)) { + if (!fp) return; + while ((len = getline(&line, &l, fp)) > 0) { char *ptr = line; int32_t idx; @@ -195,10 +197,8 @@ static void parseRPDB(char *fname, struct arglist **list, int32_t size) (sscanf(ptr, "0x%x %s #", &idx, toybuf) != 2) && (sscanf(ptr, "%d %s\n", &idx, toybuf) != 2) && (sscanf(ptr, "%d %s #", &idx, toybuf) != 2)) { - error_msg("Corrupted '%s' file", fname); - xclose(fd); - free(line); - return; + error_msg("corrupt %s", fname); + break; } if (idx >= 0 && idx < size) { int index = idx & (size-1); @@ -208,7 +208,8 @@ static void parseRPDB(char *fname, struct arglist **list, int32_t size) list[index]->name = xstrdup(toybuf); } } - xclose(fd); + free(line); + fclose(fp); } static void free_alist(struct arglist **list) |