mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-15 16:53:18 -05:00
[dacp] Fix playing from playspec request
This commit is contained in:
parent
7592462571
commit
551f441273
@ -1139,7 +1139,7 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u
|
|||||||
const char *shuffle;
|
const char *shuffle;
|
||||||
uint32_t plid;
|
uint32_t plid;
|
||||||
uint32_t id;
|
uint32_t id;
|
||||||
uint32_t pos;
|
int pos;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* /ctrl-int/1/playspec?database-spec='dmap.persistentid:0x1'&container-spec='dmap.persistentid:0x5'&container-item-spec='dmap.containeritemid:0x9'
|
/* /ctrl-int/1/playspec?database-spec='dmap.persistentid:0x1'&container-spec='dmap.persistentid:0x5'&container-item-spec='dmap.containeritemid:0x9'
|
||||||
@ -1202,7 +1202,7 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u
|
|||||||
}
|
}
|
||||||
param++;
|
param++;
|
||||||
|
|
||||||
ret = safe_hextou32(param, &pos);
|
ret = safe_hextou32(param, &id);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_DACP, "Couldn't convert container-item-spec/item-spec to an integer in playspec (%s)\n", param);
|
DPRINTF(E_LOG, L_DACP, "Couldn't convert container-item-spec/item-spec to an integer in playspec (%s)\n", param);
|
||||||
@ -1211,15 +1211,15 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
pos = 0;
|
id = 0;
|
||||||
|
|
||||||
DPRINTF(E_DBG, L_DACP, "Playspec request for playlist %d, start song id %d%s\n", plid, pos, (shuffle) ? ", shuffle" : "");
|
DPRINTF(E_DBG, L_DACP, "Playspec request for playlist %d, start song id %d%s\n", plid, id, (shuffle) ? ", shuffle" : "");
|
||||||
|
|
||||||
items = NULL;
|
items = NULL;
|
||||||
if (plid > 0)
|
if (plid > 0)
|
||||||
items = queueitem_make_byplid(plid);
|
items = queueitem_make_byplid(plid);
|
||||||
else if (pos > 0)
|
else if (id > 0)
|
||||||
items = queueitem_make_byid(pos);
|
items = queueitem_make_byid(id);
|
||||||
|
|
||||||
if (!items)
|
if (!items)
|
||||||
{
|
{
|
||||||
@ -1228,6 +1228,12 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u
|
|||||||
goto out_fail;
|
goto out_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pos = queueitem_pos(items, id);
|
||||||
|
if (pos < 0)
|
||||||
|
{
|
||||||
|
DPRINTF(E_DBG, L_DACP, "No item with %d found in queue\n", id);
|
||||||
|
pos = 0;
|
||||||
|
}
|
||||||
DPRINTF(E_DBG, L_DACP, "Playspec start song index is %d\n", pos);
|
DPRINTF(E_DBG, L_DACP, "Playspec start song index is %d\n", pos);
|
||||||
|
|
||||||
player_get_status(&status);
|
player_get_status(&status);
|
||||||
@ -1242,7 +1248,7 @@ dacp_reply_playspec(struct evhttp_request *req, struct evbuffer *evbuf, char **u
|
|||||||
if (shuffle)
|
if (shuffle)
|
||||||
dacp_propset_shufflestate(shuffle, NULL);
|
dacp_propset_shufflestate(shuffle, NULL);
|
||||||
|
|
||||||
ret = player_playback_start_bypos(pos, &id);
|
ret = player_playback_start_bypos(pos, NULL);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_DACP, "Could not start playback\n");
|
DPRINTF(E_LOG, L_DACP, "Could not start playback\n");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user