From 3df6a01f980f7832263d2bdb3ff161aabbd7aed9 Mon Sep 17 00:00:00 2001 From: Florian Forster Date: Wed, 20 Jan 2010 18:09:28 +0100 Subject: [PATCH] swap plugin: Put parsing of Linux 2.6 and <2.6 files into one loop. --- src/swap.c | 47 +++++++++++++++++++++-------------------------- 1 file changed, 21 insertions(+), 26 deletions(-) diff --git a/src/swap.c b/src/swap.c index 78bf87a3..e467818d 100644 --- a/src/swap.c +++ b/src/swap.c @@ -193,7 +193,7 @@ static int swap_read (void) char *fields[8]; int numfields; - unsigned int old_kernel=0; + _Bool old_kernel=0; derive_t swap_used = 0; derive_t swap_cached = 0; @@ -257,36 +257,32 @@ static int swap_read (void) old_kernel = 1; } - if ( old_kernel ) - while (fgets (buffer, 1024, fh) != NULL) - { - if (strncasecmp (buffer, "page",4) == 0) - { - numfields = strsplit(buffer,fields,3); - if ( numfields < 3 ) - continue; - swap_in = (derive_t) atoll(fields[1]); - swap_out = (derive_t) atoll(fields[2]); - } - } - else - while (fgets (buffer, 1024, fh) != NULL) + while (fgets (buffer, 1024, fh) != NULL) + { + numfields = strsplit (buffer, fields, STATIC_ARRAY_SIZE (fields)); + + if (!old_kernel) { - derive_t *val = NULL; - if (strncasecmp (buffer, "pswpin", 6) == 0) - val = &swap_in; - else if (strncasecmp (buffer, "pswpout", 7) == 0) - val = &swap_out; - else + if (numfields != 2) continue; - numfields = strsplit (buffer, fields, 8); - - if (numfields < 2) + if (strcasecmp ("pswpin", fields[0]) != 0) + strtoderive (fields[1], &swap_in); + else if (strcasecmp ("pswpout", fields[0]) == 0) + strtoderive (fields[1], &swap_out); + } + else /* if (old_kernel) */ + { + if (numfields != 3) continue; - *val = (derive_t) atoll (fields[1]); + if (strcasecmp ("page", fields[0]) == 0) + { + strtoderive (fields[1], &swap_in); + strtoderive (fields[2], &swap_out); + } } + } /* while (fgets) */ if (fclose (fh)) { @@ -300,7 +296,6 @@ static int swap_read (void) swap_submit ("cached", swap_cached, DS_TYPE_GAUGE); swap_submit ("in", swap_in, DS_TYPE_DERIVE); swap_submit ("out", swap_out, DS_TYPE_DERIVE); - /* #endif KERNEL_LINUX */ #elif HAVE_LIBKSTAT -- 2.30.2