diff options
author | Rich Felker <dalias@aerifal.cx> | 2017-06-15 12:58:08 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2017-06-15 12:58:08 -0400 |
commit | 5c10c33d2a35204ee76931625a007fcc8cca3228 (patch) | |
tree | 8847a78536f72c9c062ad5cd2bedc6fd4ae79ee4 /src | |
parent | 1c86c7f5c26dd0569df7afc23ee9866fb3f645dc (diff) | |
download | musl-5c10c33d2a35204ee76931625a007fcc8cca3228.tar.gz musl-5c10c33d2a35204ee76931625a007fcc8cca3228.tar.bz2 musl-5c10c33d2a35204ee76931625a007fcc8cca3228.tar.xz musl-5c10c33d2a35204ee76931625a007fcc8cca3228.zip |
handle localtime errors in ctime
ctime passes the result from localtime directly to asctime. But in case
of error, localtime returns 0. This causes an error (NULL pointer
dereference) in asctime.
based on patch by Omer Anson.
Diffstat (limited to 'src')
-rw-r--r-- | src/time/ctime.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/time/ctime.c b/src/time/ctime.c index 185ec554..36029315 100644 --- a/src/time/ctime.c +++ b/src/time/ctime.c @@ -2,5 +2,7 @@ char *ctime(const time_t *t) { - return asctime(localtime(t)); + struct tm *tm = localtime(t); + if (!tm) return 0; + return asctime(tm); } |