Pino Toscano
2016-May-26  15:40 UTC
[Libguestfs] [PATCH] osinfo: use guestfs_int_version_from_x_y to parse the os version
Make use of the common version code, and avoid a separate regexp.
---
 src/osinfo.c | 17 +++++++----------
 1 file changed, 7 insertions(+), 10 deletions(-)
diff --git a/src/osinfo.c b/src/osinfo.c
index 4a4cbfc..f4e2c71 100644
--- a/src/osinfo.c
+++ b/src/osinfo.c
@@ -65,8 +65,6 @@
 #include "guestfs.h"
 #include "guestfs-internal.h"
 
-COMPILE_REGEXP (re_major_minor, "(\\d+)\\.(\\d+)", 0)
-
 gl_lock_define_initialized (static, osinfo_db_lock);
 static ssize_t osinfo_db_size = 0; /* 0 = unread, -1 = error, >= 1 =
#records */
 static struct osinfo *osinfo_db = NULL;
@@ -436,17 +434,16 @@ static int
 parse_version (guestfs_h *g, xmlNodePtr node, struct osinfo *osinfo)
 {
   CLEANUP_FREE char *content = NULL;
-  CLEANUP_FREE char *major = NULL, *minor = NULL;
 
   content = (char *) xmlNodeGetContent (node);
   if (content) {
-    if (match2 (g, content, re_major_minor, &major, &minor)) {
-      osinfo->major_version = guestfs_int_parse_unsigned_int (g, major);
-      if (osinfo->major_version == -1)
-        return -1;
-      osinfo->minor_version = guestfs_int_parse_unsigned_int (g, minor);
-      if (osinfo->minor_version == -1)
-        return -1;
+    struct version version;
+    int res = guestfs_int_version_from_x_y (g, &version, content);
+    if (res < 0)
+      return -1;
+    else if (res > 0) {
+      osinfo->major_version = version.v_major;
+      osinfo->minor_version = version.v_minor;
     }
   }
 
-- 
2.5.5
Richard W.M. Jones
2016-May-26  15:49 UTC
Re: [Libguestfs] [PATCH] osinfo: use guestfs_int_version_from_x_y to parse the os version
On Thu, May 26, 2016 at 05:40:10PM +0200, Pino Toscano wrote:> Make use of the common version code, and avoid a separate regexp. > --- > src/osinfo.c | 17 +++++++---------- > 1 file changed, 7 insertions(+), 10 deletions(-) > > diff --git a/src/osinfo.c b/src/osinfo.c > index 4a4cbfc..f4e2c71 100644 > --- a/src/osinfo.c > +++ b/src/osinfo.c > @@ -65,8 +65,6 @@ > #include "guestfs.h" > #include "guestfs-internal.h" > > -COMPILE_REGEXP (re_major_minor, "(\\d+)\\.(\\d+)", 0) > - > gl_lock_define_initialized (static, osinfo_db_lock); > static ssize_t osinfo_db_size = 0; /* 0 = unread, -1 = error, >= 1 = #records */ > static struct osinfo *osinfo_db = NULL; > @@ -436,17 +434,16 @@ static int > parse_version (guestfs_h *g, xmlNodePtr node, struct osinfo *osinfo) > { > CLEANUP_FREE char *content = NULL; > - CLEANUP_FREE char *major = NULL, *minor = NULL; > > content = (char *) xmlNodeGetContent (node); > if (content) { > - if (match2 (g, content, re_major_minor, &major, &minor)) { > - osinfo->major_version = guestfs_int_parse_unsigned_int (g, major); > - if (osinfo->major_version == -1) > - return -1; > - osinfo->minor_version = guestfs_int_parse_unsigned_int (g, minor); > - if (osinfo->minor_version == -1) > - return -1; > + struct version version; > + int res = guestfs_int_version_from_x_y (g, &version, content); > + if (res < 0) > + return -1; > + else if (res > 0) { > + osinfo->major_version = version.v_major; > + osinfo->minor_version = version.v_minor; > } > }ACK. Rich. -- Richard Jones, Virtualization Group, Red Hat http://people.redhat.com/~rjones Read my programming and virtualization blog: http://rwmj.wordpress.com libguestfs lets you edit virtual machines. Supports shell scripting, bindings from many languages. http://libguestfs.org
Reasonably Related Threads
- [PATCH] lib: qemu: use guestfs_int_version_from_x_y for qemu version parsing
- [PATCH 2/2] inspect: switch to version struct for os major/minor version
- [PATCH] osinfo: parse also single-digit version numbers
- [PATCH 0/2] src: introduce an helper version struct
- [PATCH v2 0/2] src: introduce an helper version struct