ref: a2704c509801ead9a2e12dcc66f586e5ddad0557
parent: 1d1e346565e4678f97ebb57f3680b68df0d0c60f
author: google <google@daverabbitz.ath.cx>
date: Sat Sep 1 20:33:39 EDT 2012
Add -i flag to date: prints ISO-8601 datestamp Add -t flag to date: prints ISO-8601 timestamp
--- a/sys/man/1/date
+++ b/sys/man/1/date
@@ -24,6 +24,12 @@
.B -n
Report the date as the number of seconds since the
epoch, 00:00:00 GMT, January 1, 1970.
+.TP
+.B -i
+Report the date as ISO-8601 without time and timezone suffix.
+.TP
+.B -t
+Report the date as ISO-8601 with time and timezone suffix.
.PP
The conversion from Greenwich Mean Time to local time depends on the
.B $timezone
--- a/sys/src/cmd/date.c
+++ b/sys/src/cmd/date.c
@@ -1,17 +1,66 @@
#include <u.h>
#include <libc.h>
-int uflg, nflg;
+int uflg, nflg, iflg, tflg;
+char*
+isodate(Tm *t)
+{+ static char c[10+14+1]; /* leave room to append isotime */
+
+ ct_numb(c, t->year / 100 + 119);
+ ct_numb(c+2, t->year % 100 + 100);
+ c[4] = '-';
+ ct_numb(c+5, t->mon + 101);
+ c[7] = '-';
+ ct_numb(c+8, t->mday + 100);
+ c[10] = 0;
+ return c;
+}
+
+char*
+isotime(Tm *t)
+{+ int tz;
+ char *c, *d;
+ d = isodate(t);
+ c = d + 10; /* append to isodate */
+ c[0] = 'T';
+ ct_numb(c+1, t->hour+100);
+ c[3] = ':';
+ ct_numb(c+4, t->min+100);
+ c[6] = ':';
+ ct_numb(c+7, t->sec+100);
+ tz = t->tzoff / 60;
+ if(t->tzoff) {+ /* localtime */
+ if (t->tzoff > 0) {+ c[9] = '+';
+ } else {+ c[9] = '-';
+ tz = -tz;
+ }
+ ct_numb(c+10, tz / 60 + 100);
+ ct_numb(c+12, tz % 60 + 100);
+ c[14] = 0;
+ } else {+ c[9] = 'Z';
+ c[10] = 0;
+ }
+ return d;
+}
+
void
main(int argc, char *argv[])
{ulong now;
-
+ Tm *tm;
ARGBEGIN{case 'n': nflg = 1; break;
case 'u': uflg = 1; break;
- default: fprint(2, "usage: date [-un] [seconds]\n"); exits("usage");+ case 't': tflg = 1; /* implies -i */
+ case 'i': iflg = 1; break;
+ default: fprint(2, "usage: date [-itun] [seconds]\n"); exits("usage");}ARGEND
if(argc == 1)
@@ -21,10 +70,17 @@
if(nflg)
print("%ld\n", now);- else if(uflg)
- print("%s", asctime(gmtime(now)));- else
- print("%s", ctime(now));-
+ else if(iflg) {+ tm = uflg ? gmtime(now) : localtime(now);
+ if(tflg)
+ print("%s\n", isotime(tm));+ else
+ print("%s\n", isodate(tm));+ } else {+ if(uflg)
+ print("%s", asctime(gmtime(now)));+ else
+ print("%s", ctime(now));+ }
exits(0);
}
--
⑨