Commit 5a50fa71 authored by Warren Dukes's avatar Warren Dukes

block signals when writing db to ensure db isn't corrupted

git-svn-id: https://svn.musicpd.org/mpd/trunk@730 09075e82-0dd4-0310-85a5-a0d7c8717e4f
parent acf0e147
...@@ -553,6 +553,7 @@ int printDirectoryInfo(FILE * fp, char * name) { ...@@ -553,6 +553,7 @@ int printDirectoryInfo(FILE * fp, char * name) {
return 0; return 0;
} }
/* DON'T BLOCK SIGNALS IN THIS FUNCTION, called by writeDirectoryDB() */
void writeDirectoryInfo(FILE * fp, Directory * directory) { void writeDirectoryInfo(FILE * fp, Directory * directory) {
ListNode * node = (directory->subDirectories)->firstNode; ListNode * node = (directory->subDirectories)->firstNode;
Directory * subDirectory; Directory * subDirectory;
...@@ -684,12 +685,18 @@ int writeDirectoryDB() { ...@@ -684,12 +685,18 @@ int writeDirectoryDB() {
while(!(fp=fopen(directorydb,"w")) && errno==EINTR); while(!(fp=fopen(directorydb,"w")) && errno==EINTR);
if(!fp) return -1; if(!fp) return -1;
/* block signals so we ensure the db doesn't get corrupted */
/* no functions that writeDirectoryInfoCalls should mess with
signals or signal blocking! */
blockSignals();
myfprintf(fp,"%s\n",DIRECTORY_INFO_BEGIN); myfprintf(fp,"%s\n",DIRECTORY_INFO_BEGIN);
myfprintf(fp,"%s%s\n",DIRECTORY_MPD_VERSION,VERSION); myfprintf(fp,"%s%s\n",DIRECTORY_MPD_VERSION,VERSION);
myfprintf(fp,"%s%s\n",DIRECTORY_FS_CHARSET,getFsCharset()); myfprintf(fp,"%s%s\n",DIRECTORY_FS_CHARSET,getFsCharset());
myfprintf(fp,"%s\n",DIRECTORY_INFO_END); myfprintf(fp,"%s\n",DIRECTORY_INFO_END);
writeDirectoryInfo(fp,mp3rootDirectory); writeDirectoryInfo(fp,mp3rootDirectory);
unblockSignals();
while(fclose(fp) && errno==EINTR); while(fclose(fp) && errno==EINTR);
return 0; return 0;
......
...@@ -90,6 +90,8 @@ void blockSignals() { ...@@ -90,6 +90,8 @@ void blockSignals() {
sigaddset(&sset,SIGCHLD); sigaddset(&sset,SIGCHLD);
sigaddset(&sset,SIGUSR1); sigaddset(&sset,SIGUSR1);
sigaddset(&sset,SIGHUP); sigaddset(&sset,SIGHUP);
sigaddset(&sset,SIGINT);
sigaddset(&sset,SIGTERM);
while(sigprocmask(SIG_BLOCK,&sset,NULL)<0 && errno==EINTR); while(sigprocmask(SIG_BLOCK,&sset,NULL)<0 && errno==EINTR);
} }
...@@ -100,5 +102,7 @@ void unblockSignals() { ...@@ -100,5 +102,7 @@ void unblockSignals() {
sigaddset(&sset,SIGCHLD); sigaddset(&sset,SIGCHLD);
sigaddset(&sset,SIGUSR1); sigaddset(&sset,SIGUSR1);
sigaddset(&sset,SIGHUP); sigaddset(&sset,SIGHUP);
sigaddset(&sset,SIGINT);
sigaddset(&sset,SIGTERM);
while(sigprocmask(SIG_UNBLOCK,&sset,NULL)<0 && errno==EINTR); while(sigprocmask(SIG_UNBLOCK,&sset,NULL)<0 && errno==EINTR);
} }
...@@ -132,6 +132,7 @@ void freeSongList(SongList * list) { ...@@ -132,6 +132,7 @@ void freeSongList(SongList * list) {
freeList(list); freeList(list);
} }
/* DON'T BLOCK SIGNALS IN THIS FUNCTION, called by writeDirectoryDB() */
int printSongInfo(FILE * fp, Song * song) { int printSongInfo(FILE * fp, Song * song) {
myfprintf(fp,"%s%s\n",SONG_FILE,song->utf8file); myfprintf(fp,"%s%s\n",SONG_FILE,song->utf8file);
...@@ -151,6 +152,7 @@ int printSongInfoFromList(FILE * fp, SongList * list) { ...@@ -151,6 +152,7 @@ int printSongInfoFromList(FILE * fp, SongList * list) {
return 0; return 0;
} }
/* DON'T BLOCK SIGNALS IN THIS FUNCTION, called by writeDirectoryDB() */
void writeSongInfoFromList(FILE * fp, SongList * list) { void writeSongInfoFromList(FILE * fp, SongList * list) {
ListNode * tempNode = list->firstNode; ListNode * tempNode = list->firstNode;
......
...@@ -51,6 +51,7 @@ ...@@ -51,6 +51,7 @@
#include "mp4ff/mp4ff.h" #include "mp4ff/mp4ff.h"
#endif #endif
/* DON'T BLOCK SIGNALS IN THIS FUNCTION, called by writeDirectoryDB() */
void printMpdTag(FILE * fp, MpdTag * tag) { void printMpdTag(FILE * fp, MpdTag * tag) {
if(tag->artist) myfprintf(fp,"Artist: %s\n",tag->artist); if(tag->artist) myfprintf(fp,"Artist: %s\n",tag->artist);
if(tag->album) myfprintf(fp,"Album: %s\n",tag->album); if(tag->album) myfprintf(fp,"Album: %s\n",tag->album);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment