X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~mdw/git/disorder/blobdiff_plain/44385936ca254ab99b800640f16b18401478a95a..7a4c02b06ea54d59bb3b724119542726da830ddd:/server/play.c diff --git a/server/play.c b/server/play.c index bd27474..d73aec7 100644 --- a/server/play.c +++ b/server/play.c @@ -44,6 +44,7 @@ #include "configuration.h" #include "queue.h" #include "server-queue.h" +#include "rights.h" #include "trackdb.h" #include "play.h" #include "plugin.h" @@ -115,6 +116,11 @@ static int speaker_readable(ev_source *ev, int fd, D(("SM_FINISHED %s", sm.id)); finished(ev); break; + case SM_UNKNOWN: + /* we asked for an unknown track to be cancelled */ + if(playing && !strcmp(sm.id, playing->id)) + finished(ev); + break; case SM_PLAYING: /* track ID is playing, DATA seconds played */ D(("SM_PLAYING %s %ld", sm.id, sm.data)); @@ -312,14 +318,16 @@ static int start(ev_source *ev, memset(&sm, 0, sizeof sm); D(("start %s %d", q->id, prepare_only)); - if(find_player_pid(q->id) > 0) { - if(prepare_only) return START_OK; - /* We have already prepared this track so we just need to tell the speaker - * process to start actually playing the queued up audio data */ - strcpy(sm.id, q->id); - sm.type = SM_PLAY; - speaker_send(speaker_fd, &sm); - D(("sent SM_PLAY for %s", sm.id)); + if(q->prepared) { + /* The track is alraedy prepared */ + if(!prepare_only) { + /* We want to run it, since it's prepared the answer is to tell the + * speaker to set it off */ + strcpy(sm.id, q->id); + sm.type = SM_PLAY; + speaker_send(speaker_fd, &sm); + D(("sent SM_PLAY for %s", sm.id)); + } return START_OK; } /* Find the player plugin. */ @@ -396,7 +404,7 @@ static int start(ev_source *ev, memset(&addr, 0, sizeof addr); addr.sun_family = AF_UNIX; snprintf(addr.sun_path, sizeof addr.sun_path, - "%s/speaker", config->home); + "%s/speaker/socket", config->home); sfd = xsocket(PF_UNIX, SOCK_STREAM, 0); if(connect(sfd, (const struct sockaddr *)&addr, sizeof addr) < 0) fatal(errno, "connecting to %s", addr.sun_path); @@ -424,6 +432,7 @@ static int start(ev_source *ev, * (but it should be for play_track() */ execlp("disorder-normalize", "disorder-normalize", log_default == &log_syslog ? "--syslog" : "--no-syslog", + "--config", configfile, (char *)0); fatal(errno, "executing disorder-normalize"); /* end of the innermost fork */ @@ -478,6 +487,7 @@ static int start(ev_source *ev, return START_SOFTFAIL; } store_player_pid(q->id, pid); + q->prepared = 1; if(lfd != -1) xclose(lfd); setpgid(pid, pid);