freebsd-dev/contrib/one-true-awk/testdir/time.c
Warner Losh 23f24377b1 awk: Merge 20210729 from One True Awk upstream (0592de4a)
July 27, 2021:
	As per IEEE Std 1003.1-2008, -F "str" is now consistent with
	-v FS="str" when str is null. Thanks to Warner Losh.

July 24, 2021:
	Fix readrec's definition of a record. This fixes an issue
	with NetBSD's RS regular expression support that can cause
	an infinite read loop. Thanks to Miguel Pineiro Jr.

	Fix regular expression RS ^-anchoring. RS ^-anchoring needs to
	know if it is reading the first record of a file. This change
	restores a missing line that was overlooked when porting NetBSD's
	RS regex functionality. Thanks to Miguel Pineiro Jr.

	Fix size computation in replace_repeat() for special case
	REPEAT_WITH_Q. Thanks to Todd C. Miller.

Also, included the tests from upstream, though they aren't yet connected
to the tree.

Sponsored by:		Netflix
2021-08-01 10:22:39 -06:00

32 lines
712 B
C

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/times.h>
#include <time.h>
int main(int argc, char *argv[])
{
struct tms before, after;
char cmd[10000];
int i;
double fudge = 100.0; /* should be CLOCKS_PER_SEC but that gives nonsense */
times(&before);
/* ... place code to be timed here ... */
cmd[0] = 0;
for (i = 1; i < argc; i++)
sprintf(cmd+strlen(cmd), "%s ", argv[i]);
sprintf(cmd+strlen(cmd), "\n");
/* printf("cmd = [%s]\n", cmd); */
system(cmd);
times(&after);
fprintf(stderr, "user %6.3f\n", (after.tms_cutime - before.tms_cutime)/fudge);
fprintf(stderr, "sys %6.3f\n", (after.tms_cstime - before.tms_cstime)/fudge);
return 0;
}