MPD client: support command_list_ok_begin
This commit is contained in:
parent
2a15b1de70
commit
dfc7ff57ef
@ -1498,9 +1498,6 @@ mpd_client_parse_response (const char *p, struct mpd_response *response)
|
|||||||
{
|
{
|
||||||
if (!strcmp (p, "OK"))
|
if (!strcmp (p, "OK"))
|
||||||
return response->success = true;
|
return response->success = true;
|
||||||
if (!strcmp (p, "list_OK"))
|
|
||||||
// TODO: either implement this or fail the connection properly
|
|
||||||
hard_assert (!"command_list_ok_begin not implemented");
|
|
||||||
|
|
||||||
char *end = NULL;
|
char *end = NULL;
|
||||||
if (*p++ != 'A' || *p++ != 'C' || *p++ != 'K' || *p++ != ' ' || *p++ != '[')
|
if (*p++ != 'A' || *p++ != 'C' || *p++ != 'K' || *p++ != ' ' || *p++ != '[')
|
||||||
@ -1574,7 +1571,9 @@ mpd_client_parse_line (struct mpd_client *self, const char *line)
|
|||||||
|
|
||||||
struct mpd_response response;
|
struct mpd_response response;
|
||||||
memset (&response, 0, sizeof response);
|
memset (&response, 0, sizeof response);
|
||||||
if (mpd_client_parse_response (line, &response))
|
if (!strcmp (line, "list_OK"))
|
||||||
|
str_vector_add_owned (&self->data, NULL);
|
||||||
|
else if (mpd_client_parse_response (line, &response))
|
||||||
{
|
{
|
||||||
mpd_client_dispatch (self, &response);
|
mpd_client_dispatch (self, &response);
|
||||||
free (response.current_command);
|
free (response.current_command);
|
||||||
@ -1759,6 +1758,15 @@ mpd_client_list_begin (struct mpd_client *self)
|
|||||||
self->in_list = true;
|
self->in_list = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Beware that "list_OK" turns into NULL values in the output vector
|
||||||
|
static void
|
||||||
|
mpd_client_list_ok_begin (struct mpd_client *self)
|
||||||
|
{
|
||||||
|
hard_assert (!self->in_list);
|
||||||
|
mpd_client_send_command (self, "command_list_ok_begin", NULL);
|
||||||
|
self->in_list = true;
|
||||||
|
}
|
||||||
|
|
||||||
/// End a list of commands. Remember to call mpd_client_add_task()
|
/// End a list of commands. Remember to call mpd_client_add_task()
|
||||||
/// to handle the summary response.
|
/// to handle the summary response.
|
||||||
static void
|
static void
|
||||||
|
Loading…
Reference in New Issue
Block a user