builtin-commit: add --date option
[git/vmiklos.git] / test-date.c
bloba9e705f79a148790f4de55c7918dc9c669382a4f
1 #include "cache.h"
3 static const char *usage_msg = "\n"
4 " test-date show [time_t]...\n"
5 " test-date parse [date]...\n"
6 " test-date approxidate [date]...\n";
8 static void show_dates(char **argv, struct timeval *now)
10 char buf[128];
12 for (; *argv; argv++) {
13 time_t t = atoi(*argv);
14 show_date_relative(t, 0, now, buf, sizeof(buf));
15 printf("%s -> %s\n", *argv, buf);
19 static void parse_dates(char **argv, struct timeval *now)
21 for (; *argv; argv++) {
22 char result[100];
23 time_t t;
25 result[0] = 0;
26 parse_date(*argv, result, sizeof(result));
27 t = strtoul(result, NULL, 0);
28 printf("%s -> %s\n", *argv,
29 t ? show_date(t, 0, DATE_ISO8601) : "bad");
33 static void parse_approxidate(char **argv, struct timeval *now)
35 for (; *argv; argv++) {
36 time_t t;
37 t = approxidate_relative(*argv, now);
38 printf("%s -> %s\n", *argv, show_date(t, 0, DATE_ISO8601));
42 int main(int argc, char **argv)
44 struct timeval now;
45 const char *x;
47 x = getenv("TEST_DATE_NOW");
48 if (x) {
49 now.tv_sec = atoi(x);
50 now.tv_usec = 0;
52 else
53 gettimeofday(&now, NULL);
55 argv++;
56 if (!*argv)
57 usage(usage_msg);
58 if (!strcmp(*argv, "show"))
59 show_dates(argv+1, &now);
60 else if (!strcmp(*argv, "parse"))
61 parse_dates(argv+1, &now);
62 else if (!strcmp(*argv, "approxidate"))
63 parse_approxidate(argv+1, &now);
64 else
65 usage(usage_msg);
66 return 0;