summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko2020-11-28 23:21:13 +0100
committerDenys Vlasenko2020-11-28 23:21:13 +0100
commit32a8f70ac1caa4037b63747c0c0a5086953ea668 (patch)
tree796ed8c6940796ffafc00561e1ab75787fb3a317
parent4dee01605996be88ec247256eb47d2686f6b7104 (diff)
downloadbusybox-32a8f70ac1caa4037b63747c0c0a5086953ea668.zip
busybox-32a8f70ac1caa4037b63747c0c0a5086953ea668.tar.gz
libbb: in @SECONDS date format, use 64-bit time if libc allows
function old new delta packed_usage 33472 33486 +14 parse_datestr 919 916 -3 Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--coreutils/date.c1
-rw-r--r--libbb/time.c6
2 files changed, 6 insertions, 1 deletions
diff --git a/coreutils/date.c b/coreutils/date.c
index dfc1c76..7061f17 100644
--- a/coreutils/date.c
+++ b/coreutils/date.c
@@ -111,6 +111,7 @@
//usage: )
//usage: "\n"
//usage: "\nRecognized TIME formats:"
+//usage: "\n @seconds_since_1970"
//usage: "\n hh:mm[:ss]"
//usage: "\n [YYYY.]MM.DD-hh:mm[:ss]"
//usage: "\n YYYY-MM-DD hh:mm[:ss]"
diff --git a/libbb/time.c b/libbb/time.c
index e66a9cb..86b88a4 100644
--- a/libbb/time.c
+++ b/libbb/time.c
@@ -90,7 +90,11 @@ void FAST_FUNC parse_datestr(const char *date_str, struct tm *ptm)
ptm->tm_mon -= 1; /* Adjust month from 1-12 to 0-11 */
} else
if (date_str[0] == '@') {
- time_t t = bb_strtol(date_str + 1, NULL, 10);
+ time_t t;
+ if (sizeof(t) <= sizeof(long))
+ t = bb_strtol(date_str + 1, NULL, 10);
+ else /* time_t is 64 bits but longs are smaller */
+ t = bb_strtoll(date_str + 1, NULL, 10);
if (!errno) {
struct tm *lt = localtime(&t);
if (lt) {