From d1df71ebbcb23456ca5985dea9cb06e2453f903e Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Sun, 7 Sep 2008 13:37:33 +0200 Subject: [PATCH] playlist: fix FILE* leak in appendSongToStoredPlaylistByPath() When an error occurs after the file has been opened, the function will never close the FILE object. --- src/storedPlaylist.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/src/storedPlaylist.c b/src/storedPlaylist.c index b806ecf0b..46a0ce3ca 100644 --- a/src/storedPlaylist.c +++ b/src/storedPlaylist.c @@ -301,9 +301,11 @@ int appendSongToStoredPlaylistByPath(int fd, const char *utf8path, Song *song) if (fstat(fileno(file), &st) < 0) { commandError(fd, ACK_ERROR_NO_EXIST, "could not stat file " "\"%s\": %s", path_max_tmp, strerror(errno)); + while (fclose(file) != 0 && errno == EINTR); return -1; } if (st.st_size >= ((MPD_PATH_MAX+1) * playlist_max_length)) { + while (fclose(file) != 0 && errno == EINTR); commandError(fd, ACK_ERROR_PLAYLIST_MAX, "playlist is at the max size"); return -1;