time.c - sbase - suckless unix tools | |
git clone git://git.suckless.org/sbase | |
Log | |
Files | |
Refs | |
README | |
LICENSE | |
--- | |
time.c (1369B) | |
--- | |
1 /* See LICENSE file for copyright and license details. */ | |
2 #include <sys/times.h> | |
3 #include <sys/wait.h> | |
4 | |
5 #include <errno.h> | |
6 #include <stdio.h> | |
7 #include <unistd.h> | |
8 | |
9 #include "util.h" | |
10 | |
11 static void | |
12 usage(void) | |
13 { | |
14 eprintf("usage: %s [-p] cmd [arg ...]\n", argv0); | |
15 } | |
16 | |
17 int | |
18 main(int argc, char *argv[]) | |
19 { | |
20 pid_t pid; | |
21 struct tms tms; /* user and sys times */ | |
22 clock_t r0, r1; /* real time */ | |
23 long ticks; /* per second */ | |
24 int status, savederrno, ret = 0; | |
25 | |
26 ARGBEGIN { | |
27 case 'p': | |
28 break; | |
29 default: | |
30 usage(); | |
31 } ARGEND | |
32 | |
33 if (!argc) | |
34 usage(); | |
35 | |
36 if ((ticks = sysconf(_SC_CLK_TCK)) <= 0) | |
37 eprintf("sysconf _SC_CLK_TCK:"); | |
38 | |
39 if ((r0 = times(&tms)) == (clock_t)-1) | |
40 eprintf("times:"); | |
41 | |
42 switch ((pid = fork())) { | |
43 case -1: | |
44 eprintf("fork:"); | |
45 case 0: | |
46 execvp(argv[0], argv); | |
47 savederrno = errno; | |
48 weprintf("execvp %s:", argv[0]); | |
49 _exit(126 + (savederrno == ENOENT)); | |
50 default: | |
51 break; | |
52 } | |
53 waitpid(pid, &status, 0); | |
54 | |
55 if ((r1 = times(&tms)) == (clock_t)-1) | |
56 eprintf("times:"); | |
57 | |
58 if (WIFSIGNALED(status)) { | |
59 fprintf(stderr, "Command terminated by signal %d\n", | |
60 WTERMSIG(status)); | |
61 ret = 128 + WTERMSIG(status); | |
62 } | |
63 | |
64 fprintf(stderr, "real %f\nuser %f\nsys %f\n", | |
65 (r1 - r0) / (double)ticks, | |
66 tms.tms_cutime / (double)ticks, | |
67 tms.tms_cstime / (double)ticks); | |
68 | |
69 if (WIFEXITED(status)) | |
70 ret = WEXITSTATUS(status); | |
71 | |
72 return ret; | |
73 } |