Commit db3ef44c authored by Phil Sutter's avatar Phil Sutter Committed by Stephen Hemminger

lnstat: review lnstat_update()

Instead of calling rewind() and fgets() before every call to
scan_lines(), move them into scan_lines() itself.

This should also fix compat mode, as before the second call to
scan_lines() the first line was skipped unconditionally.
Signed-off-by: default avatarPhil Sutter <phil@nwl.cc>
parent fc31817d
...@@ -38,18 +38,22 @@ ...@@ -38,18 +38,22 @@
/* Read (and summarize for SMP) the different stats vars. */ /* Read (and summarize for SMP) the different stats vars. */
static int scan_lines(struct lnstat_file *lf, int i) static int scan_lines(struct lnstat_file *lf, int i)
{ {
char buf[FGETS_BUF_SIZE];
int j, num_lines = 0; int j, num_lines = 0;
for (j = 0; j < lf->num_fields; j++) for (j = 0; j < lf->num_fields; j++)
lf->fields[j].values[i] = 0; lf->fields[j].values[i] = 0;
while(!feof(lf->fp)) { rewind(lf->fp);
char buf[FGETS_BUF_SIZE]; /* skip first line */
if (!lf->compat && !fgets(buf, sizeof(buf)-1, lf->fp))
return -1;
while(!feof(lf->fp) && fgets(buf, sizeof(buf)-1, lf->fp)) {
char *ptr = buf; char *ptr = buf;
num_lines++; num_lines++;
fgets(buf, sizeof(buf)-1, lf->fp);
gettimeofday(&lf->last_read, NULL); gettimeofday(&lf->last_read, NULL);
for (j = 0; j < lf->num_fields; j++) { for (j = 0; j < lf->num_fields; j++) {
...@@ -81,7 +85,6 @@ static int time_after(struct timeval *last, ...@@ -81,7 +85,6 @@ static int time_after(struct timeval *last,
int lnstat_update(struct lnstat_file *lnstat_files) int lnstat_update(struct lnstat_file *lnstat_files)
{ {
struct lnstat_file *lf; struct lnstat_file *lf;
char buf[FGETS_BUF_SIZE];
struct timeval tv; struct timeval tv;
gettimeofday(&tv, NULL); gettimeofday(&tv, NULL);
...@@ -91,11 +94,6 @@ int lnstat_update(struct lnstat_file *lnstat_files) ...@@ -91,11 +94,6 @@ int lnstat_update(struct lnstat_file *lnstat_files)
int i; int i;
struct lnstat_field *lfi; struct lnstat_field *lfi;
rewind(lf->fp);
if (!lf->compat) {
/* skip first line */
fgets(buf, sizeof(buf)-1, lf->fp);
}
scan_lines(lf, 1); scan_lines(lf, 1);
for (i = 0, lfi = &lf->fields[i]; for (i = 0, lfi = &lf->fields[i];
...@@ -107,8 +105,6 @@ int lnstat_update(struct lnstat_file *lnstat_files) ...@@ -107,8 +105,6 @@ int lnstat_update(struct lnstat_file *lnstat_files)
/ lf->interval.tv_sec; / lf->interval.tv_sec;
} }
rewind(lf->fp);
fgets(buf, sizeof(buf)-1, lf->fp);
scan_lines(lf, 0); scan_lines(lf, 0);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment