diff options
author | Max Kellermann <max@duempel.org> | 2009-07-06 11:48:21 +0200 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2009-07-06 11:48:21 +0200 |
commit | 17e3054399ba649b6e2c6fa8e7a946c286eafe77 (patch) | |
tree | 2d33e7e61631024cf330bf53e963d78412b3416f /src | |
parent | 09aadffe9bc14b42fb36342f1b133b8e15745b5c (diff) | |
download | mpd-17e3054399ba649b6e2c6fa8e7a946c286eafe77.tar.gz mpd-17e3054399ba649b6e2c6fa8e7a946c286eafe77.tar.xz mpd-17e3054399ba649b6e2c6fa8e7a946c286eafe77.zip |
song_print: check gmtime_r()'s return value
When song->mtime was not initialized properly, it was revealed that
strftime() might crash when gmtime_r() returns NULL due to an invalid
time_t input value.
Diffstat (limited to 'src')
-rw-r--r-- | src/song_print.c | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/src/song_print.c b/src/song_print.c index 2efae9b89..2c4da6cb0 100644 --- a/src/song_print.c +++ b/src/song_print.c @@ -51,20 +51,24 @@ song_print_info(struct client *client, struct song *song) song_print_url(client, song); if (song->mtime > 0) { - time_t t = song->mtime; #ifndef G_OS_WIN32 struct tm tm; #endif - char timestamp[32]; + const struct tm *tm2; - strftime(timestamp, sizeof(timestamp), "%FT%TZ", #ifdef G_OS_WIN32 - gmtime(&t) + tm2 = gmtime(&song->mtime); #else - gmtime_r(&t, &tm) + tm2 = gmtime_r(&song->mtime, &tm); #endif - ); - client_printf(client, "Last-Modified: %s\n", timestamp); + + if (tm2 != NULL) { + char timestamp[32]; + + strftime(timestamp, sizeof(timestamp), "%FT%TZ", tm2); + client_printf(client, "Last-Modified: %s\n", + timestamp); + } } if (song->tag) |