295 |
|
printw("%8s", size_conv(stats.swap_stats->free)); |
296 |
|
} |
297 |
|
|
298 |
< |
if (stats.mem_stats != NULL && stats.swap_stats != NULL) { |
299 |
< |
/* VM */ |
298 |
> |
/* VM */ |
299 |
> |
if (stats.mem_stats != NULL && stats.mem_stats->total != 0) { |
300 |
|
move(6, 54); |
301 |
|
printw("%5.2f%%", (100.00 * (float)(stats.mem_stats->used)/stats.mem_stats->total)); |
302 |
+ |
} |
303 |
+ |
if (stats.swap_stats != NULL && stats.swap_stats->total != 0) { |
304 |
|
move(7, 54); |
305 |
|
printw("%5.2f%%", (100.00 * (float)(stats.swap_stats->used)/stats.swap_stats->total)); |
306 |
+ |
} |
307 |
+ |
if (stats.mem_stats != NULL && stats.swap_stats != NULL && |
308 |
+ |
stats.mem_stats->total != 0 && stats.swap_stats->total != 0) { |
309 |
|
move(8, 54); |
310 |
|
printw("%5.2f%%", (100.00 * (float)(stats.mem_stats->used+stats.swap_stats->used)/(stats.mem_stats->total+stats.swap_stats->total))); |
311 |
|
} |
428 |
|
extern int optind; |
429 |
|
int c; |
430 |
|
|
431 |
+ |
time_t last_update = 0; |
432 |
+ |
|
433 |
|
WINDOW *window; |
434 |
|
|
428 |
– |
int stdin_fileno; |
429 |
– |
fd_set infds; |
430 |
– |
struct timeval timeout; |
431 |
– |
|
435 |
|
extern int errno; |
433 |
– |
char ch; |
436 |
|
|
437 |
|
int delay=2; |
438 |
< |
#ifdef ALLBSD |
437 |
< |
gid_t gid; |
438 |
< |
#endif |
438 |
> |
|
439 |
|
statgrab_init(); |
440 |
|
#ifdef ALLBSD |
441 |
|
if((setegid(getgid())) != 0){ |
443 |
|
return 1; |
444 |
|
} |
445 |
|
#endif |
446 |
+ |
#ifdef SOLARIS |
447 |
+ |
if((seteuid(getuid())) != 0){ |
448 |
+ |
fprintf(stderr, "Failed to lose setuid'ness\n"); |
449 |
+ |
return 1; |
450 |
+ |
} |
451 |
+ |
#endif |
452 |
|
|
453 |
< |
while ((c = getopt(argc, argv, "vhd:")) != EOF){ |
453 |
> |
while ((c = getopt(argc, argv, "vhd:")) != -1){ |
454 |
|
switch (c){ |
455 |
|
case 'd': |
456 |
|
delay = atoi(optarg); |
458 |
|
fprintf(stderr, "Time must be 1 second or greater\n"); |
459 |
|
exit(1); |
460 |
|
} |
455 |
– |
delay--; |
461 |
|
break; |
462 |
|
case 'v': |
463 |
|
version_num(argv[0]); |
467 |
|
usage(argv[0]); |
468 |
|
return 1; |
469 |
|
break; |
465 |
– |
|
470 |
|
} |
471 |
|
} |
472 |
|
|
475 |
|
nonl(); |
476 |
|
cbreak(); |
477 |
|
noecho(); |
478 |
+ |
timeout(delay * 1000); |
479 |
|
window=newwin(0, 0, 0, 0); |
480 |
|
clear(); |
481 |
|
|
486 |
|
} |
487 |
|
|
488 |
|
display_headings(); |
484 |
– |
stdin_fileno=fileno(stdin); |
489 |
|
|
490 |
|
for(;;){ |
491 |
+ |
time_t now; |
492 |
+ |
int ch = getch(); |
493 |
|
|
494 |
< |
FD_ZERO(&infds); |
495 |
< |
FD_SET(stdin_fileno, &infds); |
490 |
< |
timeout.tv_sec = delay; |
491 |
< |
timeout.tv_usec = 0; |
492 |
< |
|
493 |
< |
if((select((stdin_fileno+1), &infds, NULL, NULL, &timeout)) == -1){ |
494 |
< |
if(errno!=EINTR){ |
495 |
< |
perror("select failed"); |
496 |
< |
exit(1); |
497 |
< |
} |
494 |
> |
if (ch == 'q'){ |
495 |
> |
break; |
496 |
|
} |
497 |
|
|
498 |
< |
if(FD_ISSET(stdin_fileno, &infds)){ |
499 |
< |
ch=getch(); |
500 |
< |
if (ch == 'q'){ |
501 |
< |
endwin(); |
502 |
< |
return 0; |
503 |
< |
} |
498 |
> |
/* To keep the numbers slightly accurate we do not want them |
499 |
> |
* updating more frequently than once a second. |
500 |
> |
*/ |
501 |
> |
now = time(NULL); |
502 |
> |
if ((now - last_update) >= 1) { |
503 |
> |
get_stats(); |
504 |
|
} |
505 |
+ |
last_update = now; |
506 |
|
|
508 |
– |
get_stats(); |
509 |
– |
|
507 |
|
display_data(); |
511 |
– |
|
512 |
– |
/* To keep the numbers slightly accurate we do not want them updating more |
513 |
– |
* frequently than once a second. |
514 |
– |
*/ |
515 |
– |
sleep(1); |
508 |
|
} |
509 |
|
|
510 |
|
endwin(); |