chiark / gitweb /
udevadm hwdb: discard extra leading whitespaces in hwdb
authorPeter Hutterer <peter.hutterer@who-t.net>
Thu, 27 Nov 2014 05:19:44 +0000 (15:19 +1000)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Fri, 28 Nov 2014 19:30:50 +0000 (14:30 -0500)
Currently a property in the form of
  FOO=bar
is stored as " FOO=bar", i.e. the property name contains a leading space.
That's quite hard to spot.

This patch discards all extra whitespaces but the first one which is required
by libudev's hwdb_add_property.

[zj: modify the check a bit]

https://bugs.freedesktop.org/show_bug.cgi?id=82311

src/udev/udevadm-hwdb.c

index fa137c1cc2727112232a7b81562a6fa5f69627fe..a5870d1cee3e091ba5bbbd0d940127acd062b519 100644 (file)
@@ -428,6 +428,10 @@ static int insert_data(struct trie *trie, struct udev_list *match_list,
         value[0] = '\0';
         value++;
 
+        /* libudev requires properties to start with a space */
+        while (isblank(line[0]) && isblank(line[1]))
+                line++;
+
         if (line[0] == '\0' || value[0] == '\0') {
                 log_error("Error, empty key or value '%s' in '%s':", line, filename);
                 return -EINVAL;