locate: don't allow empty list

This commit is contained in:
Max Kellermann 2012-08-07 23:37:38 +02:00
parent 7725577a53
commit 8855efebc0
3 changed files with 9 additions and 33 deletions

View File

@ -62,10 +62,7 @@ handle_find(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, false); locate_item_list_parse(argv + 1, argc - 1, false);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -85,10 +82,7 @@ handle_findadd(struct client *client, int argc, char *argv[])
{ {
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, false); locate_item_list_parse(argv + 1, argc - 1, false);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -110,10 +104,7 @@ handle_search(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, true); locate_item_list_parse(argv + 1, argc - 1, true);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -134,10 +125,7 @@ handle_searchadd(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, true); locate_item_list_parse(argv + 1, argc - 1, true);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -161,10 +149,7 @@ handle_searchaddpl(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 2, argc - 2, true); locate_item_list_parse(argv + 2, argc - 2, true);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -186,10 +171,7 @@ handle_count(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, false); locate_item_list_parse(argv + 1, argc - 1, false);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }

View File

@ -679,10 +679,7 @@ handle_playlistfind(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, false); locate_item_list_parse(argv + 1, argc - 1, false);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }
@ -700,10 +697,7 @@ handle_playlistsearch(struct client *client, int argc, char *argv[])
struct locate_item_list *list = struct locate_item_list *list =
locate_item_list_parse(argv + 1, argc - 1, true); locate_item_list_parse(argv + 1, argc - 1, true);
if (list == NULL || list->length == 0) { if (list == NULL) {
if (list != NULL)
locate_item_list_free(list);
command_error(client, ACK_ERROR_ARG, "incorrect arguments"); command_error(client, ACK_ERROR_ARG, "incorrect arguments");
return COMMAND_RETURN_ERROR; return COMMAND_RETURN_ERROR;
} }

View File

@ -88,7 +88,7 @@ locate_item_list_new(unsigned length)
struct locate_item_list * struct locate_item_list *
locate_item_list_parse(char *argv[], unsigned argc, bool fold_case) locate_item_list_parse(char *argv[], unsigned argc, bool fold_case)
{ {
if (argc % 2 != 0) if (argc == 0 || argc % 2 != 0)
return NULL; return NULL;
struct locate_item_list *list = locate_item_list_new(argc / 2); struct locate_item_list *list = locate_item_list_new(argc / 2);