udev-rules: report rule parsing errors from get_key
authorDave Reisner <dreisner@archlinux.org>
Mon, 29 Jul 2013 22:18:43 +0000 (18:18 -0400)
committerDave Reisner <dreisner@archlinux.org>
Tue, 30 Jul 2013 01:51:58 +0000 (21:51 -0400)
src/udev/udev-rules.c

index 769b670..e4facd7 100644 (file)
@@ -1066,8 +1066,15 @@ static int add_rule(struct udev_rules *rules, char *line,
                 char *value;
                 enum operation_type op;
 
-                if (get_key(rules->udev, &linepos, &key, &op, &value) != 0)
+                if (get_key(rules->udev, &linepos, &key, &op, &value) != 0) {
+                        /* If we aren't at the end of the line, this is a parsing error.
+                         * Make a best effort to describe where the problem is. */
+                        if (*linepos != '\n')
+                                log_error("invalid key/value pair in file %s on line %u,"
+                                                "starting at character %lu\n",
+                                                filename, lineno, linepos - line + 1);
                         break;
+                }
 
                 if (streq(key, "ACTION")) {
                         if (op > OP_MATCH_MAX) {