aboutsummaryrefslogtreecommitdiff
path: root/src/client_process.c
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2009-07-29 08:00:01 +0200
committerMax Kellermann <max@duempel.org>2009-07-29 08:00:01 +0200
commit6f060081be272d4a8b1bcf1ad0197de4ea5cd5e3 (patch)
tree1e74296a7dd107b9ecbac6153652d245e40ae19e /src/client_process.c
parent7f865f722c55dc7a2a27c7869030accc8ab9beb2 (diff)
command: moved command_process_list() to client.c
Diffstat (limited to 'src/client_process.c')
-rw-r--r--src/client_process.c30
1 files changed, 26 insertions, 4 deletions
diff --git a/src/client_process.c b/src/client_process.c
index 5579b70e..2f69cc6a 100644
--- a/src/client_process.c
+++ b/src/client_process.c
@@ -25,6 +25,28 @@
#define CLIENT_LIST_OK_MODE_BEGIN "command_list_ok_begin"
#define CLIENT_LIST_MODE_END "command_list_end"
+static enum command_return
+client_process_command_list(struct client *client, bool list_ok, GSList *list)
+{
+ enum command_return ret = COMMAND_RETURN_OK;
+ unsigned num = 0;
+
+ for (GSList *cur = list; cur != NULL; cur = g_slist_next(cur)) {
+ char *cmd = cur->data;
+
+ g_debug("command_process_list: process command \"%s\"",
+ cmd);
+ ret = command_process(client, num++, cmd);
+ g_debug("command_process_list: command returned %i", ret);
+ if (ret != COMMAND_RETURN_OK || client_is_expired(client))
+ break;
+ else if (list_ok)
+ client_puts(client, "list_OK\n");
+ }
+
+ return ret;
+}
+
enum command_return
client_process_line(struct client *client, char *line)
{
@@ -61,9 +83,9 @@ client_process_line(struct client *client, char *line)
to restore the correct order */
client->cmd_list = g_slist_reverse(client->cmd_list);
- ret = command_process_list(client,
- client->cmd_list_OK,
- client->cmd_list);
+ ret = client_process_command_list(client,
+ client->cmd_list_OK,
+ client->cmd_list);
g_debug("[%u] process command "
"list returned %i", client->num, ret);
@@ -104,7 +126,7 @@ client_process_line(struct client *client, char *line)
} else {
g_debug("[%u] process command \"%s\"",
client->num, line);
- ret = command_process(client, line);
+ ret = command_process(client, 0, line);
g_debug("[%u] command returned %i",
client->num, ret);