diff options
author | nicm <nicm> | 2016-10-18 08:46:43 +0000 |
---|---|---|
committer | nicm <nicm> | 2016-10-18 08:46:43 +0000 |
commit | 2e5c49a1fd8c534d546899f7c133a0adf212a7d1 (patch) | |
tree | f36a847ecf194bec453f4c339c08685f17fe9887 /cmd-queue.c | |
parent | 8763bced7678b97fe4a55d03c50f168418ff5f13 (diff) | |
download | rtmux-2e5c49a1fd8c534d546899f7c133a0adf212a7d1.tar.gz rtmux-2e5c49a1fd8c534d546899f7c133a0adf212a7d1.tar.bz2 rtmux-2e5c49a1fd8c534d546899f7c133a0adf212a7d1.zip |
Give each item on queue a name for better logging.
Diffstat (limited to 'cmd-queue.c')
-rw-r--r-- | cmd-queue.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/cmd-queue.c b/cmd-queue.c index 5056fffc..24fd0c56 100644 --- a/cmd-queue.c +++ b/cmd-queue.c @@ -112,6 +112,8 @@ cmdq_remove(struct cmdq_item *item) cmd_list_free(item->cmdlist); TAILQ_REMOVE(item->queue, item, entry); + + free((void *)item->name); free(item); } @@ -147,10 +149,15 @@ cmdq_get_command(struct cmd_list *cmdlist, struct cmd_find_state *current, struct cmdq_item *item, *first = NULL, *last = NULL; struct cmd *cmd; u_int group = cmdq_next_group(); + char *tmp; TAILQ_FOREACH(cmd, &cmdlist->list, qentry) { + xasprintf(&tmp, "command[%s]", cmd->entry->name); + item = xcalloc(1, sizeof *item); + item->name = tmp; item->type = CMDQ_COMMAND; + item->group = group; item->flags = flags; @@ -220,12 +227,17 @@ out: /* Get a callback for the command queue. */ struct cmdq_item * -cmdq_get_callback(cmdq_cb cb, void *data) +cmdq_get_callback1(const char *name, cmdq_cb cb, void *data) { struct cmdq_item *item; + char *tmp; + + xasprintf(&tmp, "callback[%s]", name); item = xcalloc(1, sizeof *item); + item->name = tmp; item->type = CMDQ_CALLBACK; + item->group = 0; item->flags = 0; @@ -289,8 +301,8 @@ cmdq_next(struct client *c) item = TAILQ_FIRST(queue); if (item == NULL) break; - log_debug("%s %s: type %d, flags %x", __func__, name, - item->type, item->flags); + log_debug("%s %s: %s (%d), flags %x", __func__, name, + item->name, item->type, item->flags); /* * Any item with the waiting flag set waits until an external |