chiark / gitweb /
net-util: match - allow globbing
authorTom Gundersen <teg@jklm.no>
Thu, 20 Feb 2014 21:55:42 +0000 (22:55 +0100)
committerTom Gundersen <teg@jklm.no>
Thu, 20 Feb 2014 22:26:52 +0000 (23:26 +0100)
For now support globbing for interface name and path.

src/shared/net-util.c

index 06c50b593ee3652e8818b561264c3aabe74fe38c..6008a41dae847c0a94af59babafb088a096001f1 100644 (file)
@@ -22,6 +22,7 @@
 #include <netinet/ether.h>
 #include <linux/if.h>
 #include <arpa/inet.h>
 #include <netinet/ether.h>
 #include <linux/if.h>
 #include <arpa/inet.h>
+#include <fnmatch.h>
 
 #include "net-util.h"
 #include "log.h"
 
 #include "net-util.h"
 #include "log.h"
@@ -56,7 +57,7 @@ bool net_match_config(const struct ether_addr *match_mac,
         if (match_mac && (!dev_mac || memcmp(match_mac, ether_aton(dev_mac), ETH_ALEN)))
                 return 0;
 
         if (match_mac && (!dev_mac || memcmp(match_mac, ether_aton(dev_mac), ETH_ALEN)))
                 return 0;
 
-        if (match_path && !streq_ptr(match_path, dev_path))
+        if (match_path && (!dev_path || fnmatch(match_path, dev_path, 0)))
                 return 0;
 
         if (match_driver && !streq_ptr(match_driver, dev_driver))
                 return 0;
 
         if (match_driver && !streq_ptr(match_driver, dev_driver))
@@ -65,7 +66,7 @@ bool net_match_config(const struct ether_addr *match_mac,
         if (match_type && !streq_ptr(match_type, dev_type))
                 return 0;
 
         if (match_type && !streq_ptr(match_type, dev_type))
                 return 0;
 
-        if (match_name && !streq_ptr(match_name, dev_name))
+        if (match_name && (!dev_path || fnmatch(match_name, dev_name, 0)))
                 return 0;
 
         return 1;
                 return 0;
 
         return 1;