tload: new usage & fix coding style

Coding style fixed and more readable help output.

Signed-off-by: Sami Kerola <kerolasa@iki.fi>
This commit is contained in:
Sami Kerola 2011-06-05 13:19:35 +02:00
parent 05765771c2
commit a08e0a6ef2

101
tload.c
View File

@ -11,28 +11,30 @@
*/ */
#include "proc/version.h" #include "proc/version.h"
#include "proc/sysinfo.h" #include "proc/sysinfo.h"
#include <stdio.h> #include <err.h>
#include <stdlib.h> #include <errno.h>
#include <fcntl.h>
#include <getopt.h>
#include <setjmp.h> #include <setjmp.h>
#include <signal.h> #include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h> #include <string.h>
#include <unistd.h>
#include <termios.h>
#include <fcntl.h>
#include <sys/ioctl.h> #include <sys/ioctl.h>
#include <termios.h>
#include <unistd.h>
static char *screen; static char *screen;
static int nrows = 25; static int nrows = 25;
static int ncols = 80; static int ncols = 80;
static int scr_size; static int scr_size;
static int fd=1; static int fd = 1;
static int dly=5; static int dly = 5;
static jmp_buf jb; static jmp_buf jb;
static void alrm(int signo) static void alrm(int signo __attribute__ ((__unused__)))
{ {
(void)signo;
signal(SIGALRM, alrm); signal(SIGALRM, alrm);
alarm(dly); alarm(dly);
} }
@ -50,44 +52,72 @@ static void setsize(int i)
} }
scr_size = nrows * ncols; scr_size = nrows * ncols;
if (screen == NULL) if (screen == NULL)
screen = (char *) malloc(scr_size); screen = (char *)malloc(scr_size);
else else
screen = (char *) realloc(screen, scr_size); screen = (char *)realloc(screen, scr_size);
if (screen == NULL) { if (screen == NULL)
perror(""); err(EXIT_FAILURE, "cannot allocate %zu bytes", scr_size);
exit(1);
} memset(screen, ' ', scr_size - 1);
memset(screen, ' ', scr_size-1);
*(screen + scr_size - 2) = '\0'; *(screen + scr_size - 2) = '\0';
if (i) if (i)
longjmp(jb, 0); longjmp(jb, 0);
} }
static void __attribute__ ((__noreturn__))
usage(FILE * out)
{
fprintf(out,
"\nUsage: %s [options] [tty]\n"
"\nOptions:\n", program_invocation_short_name);
fprintf(out,
" -d, --delay <secs> update delay in seconds\n"
" -s, --scale <num> vertical scale\n"
" -h, --help display this help text\n"
" -V, --version display version information and exit\n");
fprintf(out, "\nFor more information see tload(1).\n");
exit(out == stderr ? EXIT_FAILURE : EXIT_SUCCESS);
}
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
int lines, row, col=0; int lines, row, col = 0;
int i, opt; int i, opt;
double av[3]; double av[3];
static double max_scale, scale_fact; static double max_scale, scale_fact;
char *scale_arg = NULL; char *scale_arg = NULL;
while ((opt = getopt(argc, argv, "s:d:V")) != -1) static const struct option longopts[] = {
{"scale", required_argument, NULL, 's'},
{"delay", required_argument, NULL, 'd'},
{"help", no_argument, NULL, 'h'},
{"version", no_argument, NULL, 'V'},
{NULL, 0, NULL, 0}
};
while ((opt = getopt_long(argc, argv, "s:d:Vh", longopts, NULL)) != -1)
switch (opt) { switch (opt) {
case 's': scale_arg = optarg; break; case 's':
case 'd': dly = atoi(optarg); break; scale_arg = optarg;
case 'V': display_version(); exit(0); break; break;
case 'd':
dly = atoi(optarg);
break;
case 'V':
display_version();
exit(0);
break;
case 'h':
usage(stdout);
default: default:
printf("usage: tload [-V] [-d delay] [-s scale] [tty]\n"); usage(stderr);
exit(1);
} }
if (argc > optind) { if (argc > optind)
if ((fd = open(argv[optind], 1)) == -1) { if ((fd = open(argv[optind], 1)) == -1)
perror("tty"); err(EXIT_FAILURE, "can not open tty");
exit(1);
}
}
setsize(0); setsize(0);
@ -111,7 +141,7 @@ int main(int argc, char **argv)
repeat: repeat:
lines = av[0] * scale_fact; lines = av[0] * scale_fact;
row = nrows-1; row = nrows - 1;
while (--lines >= 0) { while (--lines >= 0) {
*(screen + row * ncols + col) = '*'; *(screen + row * ncols + col) = '*';
@ -123,7 +153,7 @@ int main(int argc, char **argv)
while (row >= 0) while (row >= 0)
*(screen + row-- * ncols + col) = ' '; *(screen + row-- * ncols + col) = ' ';
for (i = 1; ; ++i) { for (i = 1;; ++i) {
char *p; char *p;
row = nrows - (i * scale_fact); row = nrows - (i * scale_fact);
if (row < 0) if (row < 0)
@ -136,14 +166,13 @@ int main(int argc, char **argv)
if (++col == ncols) { if (++col == ncols) {
--col; --col;
memmove(screen, screen + 1, scr_size-1); memmove(screen, screen + 1, scr_size - 1);
for(row = nrows-2; row >= 0; --row) for (row = nrows - 2; row >= 0; --row)
*(screen + row * ncols + col) = ' '; *(screen + row * ncols + col) = ' ';
} }
i = sprintf(screen, " %.2f, %.2f, %.2f", i = sprintf(screen, " %.2f, %.2f, %.2f", av[0], av[1], av[2]);
av[0], av[1], av[2]); if (i > 0)
if (i>0)
screen[i] = ' '; screen[i] = ' ';
write(fd, "\033[H", 3); write(fd, "\033[H", 3);