Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sbin/umbctl Fix and improve parsing of configuration files



details:   https://anonhg.NetBSD.org/src/rev/96c0bd0c1c66
branches:  trunk
changeset: 1010067:96c0bd0c1c66
user:      khorben <khorben%NetBSD.org@localhost>
date:      Wed May 13 21:44:30 2020 +0000

description:
Fix and improve parsing of configuration files

XXX pull-up to netbsd-9

diffstat:

 sbin/umbctl/umbctl.c |  25 +++++++++++++++++++++----
 1 files changed, 21 insertions(+), 4 deletions(-)

diffs (61 lines):

diff -r ff456a404298 -r 96c0bd0c1c66 sbin/umbctl/umbctl.c
--- a/sbin/umbctl/umbctl.c      Wed May 13 21:34:01 2020 +0000
+++ b/sbin/umbctl/umbctl.c      Wed May 13 21:44:30 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: umbctl.c,v 1.3 2020/03/22 07:45:02 khorben Exp $ */
+/* $NetBSD: umbctl.c,v 1.4 2020/05/13 21:44:30 khorben Exp $ */
 /*
  * Copyright (c) 2018 Pierre Pronchery <khorben%defora.org@localhost>
  *
@@ -179,12 +179,15 @@
 /* umbctl_file */
 static int _umbctl_file(char const * ifname, char const * filename, int verbose)
 {
+       int ret = 0;
        int fd;
        struct ifreq ifr;
        struct umb_info umbi;
        struct umb_parameter umbp;
        FILE * fp;
        char buf[512];
+       size_t len;
+       int i;
        int eof;
        char * tokens[3] = { buf, NULL, NULL };
        char * p;
@@ -197,18 +200,32 @@
                if(buf[0] == '#')
                        continue;
                buf[sizeof(buf) - 1] = '\0';
-               if((p = strstr(buf, "=")) != NULL)
+               if((len = strlen(buf)) > 0)
+               {
+                       if(buf[len - 1] != '\n')
+                       {
+                               ret = _error(2, "%s: %s", filename,
+                                               "Line too long");
+                               while((i = fgetc(fp)) != EOF && i != '\n');
+                               continue;
+                       }
+                       else
+                               buf[len - 1] = '\0';
+               }
+               if((p = strchr(buf, '=')) != NULL)
                {
                        tokens[1] = p + 1;
                        *p = '\0';
                } else
                        tokens[1] = NULL;
-               if(_umbctl_set(ifname, &umbp, (p != NULL) ? 2 : 1, tokens) != 0)
-                       break;
+               ret |= _umbctl_set(ifname, &umbp, (p != NULL) ? 2 : 1, tokens)
+                       ? 2 : 0;
        }
        eof = feof(fp);
        if(fclose(fp) != 0 || !eof)
                return _error(2, "%s: %s", filename, strerror(errno));
+       if(ret != 0)
+               return ret;
        if((fd = _umbctl_socket()) < 0)
                return 2;
        memset(&ifr, 0, sizeof(ifr));



Home | Main Index | Thread Index | Old Index