just to be carfile, make sure to null terminate when using strncpy
git-svn-id: https://svn.musicpd.org/mpd/trunk@506 09075e82-0dd4-0310-85a5-a0d7c8717e4f
This commit is contained in:
parent
12d19cccd2
commit
53f728a0ae
|
@ -116,6 +116,7 @@ int waitOnDecode(PlayerControl * pc, AudioFormat * af, DecoderControl * dc,
|
|||
|
||||
if(dc->start || dc->error!=DECODE_ERROR_NOERROR) {
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
pc->error = PLAYER_ERROR_FILE;
|
||||
quitDecode(pc,dc);
|
||||
return -1;
|
||||
|
@ -123,6 +124,7 @@ int waitOnDecode(PlayerControl * pc, AudioFormat * af, DecoderControl * dc,
|
|||
|
||||
if(initAudio(af)<0) {
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
pc->error = PLAYER_ERROR_AUDIO;
|
||||
quitDecode(pc,dc);
|
||||
return -1;
|
||||
|
@ -184,6 +186,7 @@ void decodeSeek(PlayerControl * pc, AudioFormat * af, DecoderControl * dc,
|
|||
else { \
|
||||
if(initAudio(NULL)<0) { \
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN); \
|
||||
pc->erroredFile[MAXPATHLEN] = '\0' \
|
||||
pc->error = PLAYER_ERROR_AUDIO; \
|
||||
quitDecode(pc,dc); \
|
||||
return; \
|
||||
|
@ -221,6 +224,7 @@ int decoderInit(PlayerControl * pc, Buffer * cb, AudioFormat *af,
|
|||
while(1) {
|
||||
if(dc->start) {
|
||||
strncpy(dc->file,pc->file,MAXPATHLEN);
|
||||
dc->file[MAXPATHLEN] = '\0';
|
||||
switch(pc->decodeType) {
|
||||
#ifdef HAVE_MAD
|
||||
case DECODE_TYPE_MP3:
|
||||
|
@ -252,6 +256,9 @@ int decoderInit(PlayerControl * pc, Buffer * cb, AudioFormat *af,
|
|||
#endif
|
||||
default:
|
||||
ret = DECODE_ERROR_UNKTYPE;
|
||||
strncpy(pc->erroredFile,dc->file,
|
||||
MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
}
|
||||
if(ret<0) {
|
||||
dc->error = DECODE_ERROR_FILE;
|
||||
|
@ -273,6 +280,7 @@ int decoderInit(PlayerControl * pc, Buffer * cb, AudioFormat *af,
|
|||
}
|
||||
else if(pid<0) {
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
pc->error = PLAYER_ERROR_SYSTEM;
|
||||
return -1;
|
||||
}
|
||||
|
|
|
@ -333,9 +333,13 @@ int main(int argc, char * argv[]) {
|
|||
|
||||
if(!options.dbFile) {
|
||||
strncpy(directorydb,playlistDir,MAXPATHLEN);
|
||||
directorydb[MAXPATHLEN] = '\0';
|
||||
strncat(directorydb,"/.mpddb",MAXPATHLEN-strlen(playlistDir));
|
||||
}
|
||||
else strncpy(directorydb,options.dbFile,MAXPATHLEN);
|
||||
else {
|
||||
strncpy(directorydb,options.dbFile,MAXPATHLEN);
|
||||
directorydb[MAXPATHLEN] = '\0';
|
||||
}
|
||||
if(options.createDB>0 || readDirectoryDB()<0) {
|
||||
if(options.createDB<0) {
|
||||
ERROR("can't open db file and using \"--no-create-db\""
|
||||
|
|
|
@ -182,6 +182,7 @@ int playerPlay(FILE * fp, char * utf8file) {
|
|||
struct stat st;
|
||||
if(stat(rmp2amp(utf8ToFsCharset(utf8file)),&st)<0) {
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
pc->error = PLAYER_ERROR_FILENOTFOUND;
|
||||
return 0;
|
||||
}
|
||||
|
@ -190,12 +191,14 @@ int playerPlay(FILE * fp, char * utf8file) {
|
|||
decodeType = playerGetDecodeType(utf8file);
|
||||
if(decodeType < 0) {
|
||||
strncpy(pc->erroredFile,pc->file,MAXPATHLEN);
|
||||
pc->erroredFile[MAXPATHLEN] = '\0';
|
||||
pc->error = PLAYER_ERROR_UNKTYPE;
|
||||
return 0;
|
||||
}
|
||||
pc->decodeType = decodeType;
|
||||
|
||||
strncpy(pc->file,rmp2amp(utf8ToFsCharset(utf8file)),MAXPATHLEN);
|
||||
pc->file[MAXPATHLEN] = '\0';
|
||||
|
||||
pc->play = 1;
|
||||
if(player_pid==0 && playerInit()<0) {
|
||||
|
@ -327,6 +330,7 @@ int queueSong(char * utf8file) {
|
|||
|
||||
if(pc->queueState==PLAYER_QUEUE_BLANK) {
|
||||
strncpy(pc->file,rmp2amp(utf8ToFsCharset(utf8file)),MAXPATHLEN);
|
||||
pc->file[MAXPATHLEN] = '\0';
|
||||
|
||||
decodeType = playerGetDecodeType(utf8file);
|
||||
if(decodeType < 0) return -1;
|
||||
|
@ -393,6 +397,7 @@ int playerSeek(FILE * fp, char * utf8file, float time) {
|
|||
pc->decodeType = decodeType;
|
||||
|
||||
strncpy(pc->file,file,MAXPATHLEN);
|
||||
pc->file[MAXPATHLEN] = '\0';
|
||||
}
|
||||
|
||||
if(pc->error==PLAYER_ERROR_NOERROR) {
|
||||
|
|
Loading…
Reference in New Issue