*
*/
-#include "qapi/qmp-core.h"
+#include "qemu/osdep.h"
+#include "qapi/qmp/dispatch.h"
-static QTAILQ_HEAD(QmpCommandList, QmpCommand) qmp_commands =
- QTAILQ_HEAD_INITIALIZER(qmp_commands);
-
-void qmp_register_command(const char *name, QmpCommandFunc *fn)
+void qmp_register_command(QmpCommandList *cmds, const char *name,
+ QmpCommandFunc *fn, QmpCommandOptions options)
{
QmpCommand *cmd = g_malloc0(sizeof(*cmd));
cmd->name = name;
- cmd->type = QCT_NORMAL;
cmd->fn = fn;
cmd->enabled = true;
- QTAILQ_INSERT_TAIL(&qmp_commands, cmd, node);
+ cmd->options = options;
+ QTAILQ_INSERT_TAIL(cmds, cmd, node);
+}
+
+void qmp_unregister_command(QmpCommandList *cmds, const char *name)
+{
+ QmpCommand *cmd = qmp_find_command(cmds, name);
+
+ QTAILQ_REMOVE(cmds, cmd, node);
+ g_free(cmd);
}
-QmpCommand *qmp_find_command(const char *name)
+QmpCommand *qmp_find_command(QmpCommandList *cmds, const char *name)
{
QmpCommand *cmd;
- QTAILQ_FOREACH(cmd, &qmp_commands, node) {
+ QTAILQ_FOREACH(cmd, cmds, node) {
if (strcmp(cmd->name, name) == 0) {
return cmd;
}
return NULL;
}
-void qmp_disable_command(const char *name)
+static void qmp_toggle_command(QmpCommandList *cmds, const char *name,
+ bool enabled)
{
QmpCommand *cmd;
- QTAILQ_FOREACH(cmd, &qmp_commands, node) {
+ QTAILQ_FOREACH(cmd, cmds, node) {
if (strcmp(cmd->name, name) == 0) {
- cmd->enabled = false;
+ cmd->enabled = enabled;
return;
}
}
}
-bool qmp_command_is_enabled(const char *name)
+void qmp_disable_command(QmpCommandList *cmds, const char *name)
{
- QmpCommand *cmd;
+ qmp_toggle_command(cmds, name, false);
+}
- QTAILQ_FOREACH(cmd, &qmp_commands, node) {
- if (strcmp(cmd->name, name) == 0) {
- return cmd->enabled;
- }
- }
+void qmp_enable_command(QmpCommandList *cmds, const char *name)
+{
+ qmp_toggle_command(cmds, name, true);
+}
- return false;
+bool qmp_command_is_enabled(const QmpCommand *cmd)
+{
+ return cmd->enabled;
}
-char **qmp_get_command_list(void)
+const char *qmp_command_name(const QmpCommand *cmd)
{
- QmpCommand *cmd;
- int count = 1;
- char **list_head, **list;
+ return cmd->name;
+}
- QTAILQ_FOREACH(cmd, &qmp_commands, node) {
- count++;
- }
+bool qmp_has_success_response(const QmpCommand *cmd)
+{
+ return !(cmd->options & QCO_NO_SUCCESS_RESP);
+}
- list_head = list = g_malloc0(count * sizeof(char *));
+void qmp_for_each_command(QmpCommandList *cmds, qmp_cmd_callback_fn fn,
+ void *opaque)
+{
+ QmpCommand *cmd;
- QTAILQ_FOREACH(cmd, &qmp_commands, node) {
- *list = strdup(cmd->name);
- list++;
+ QTAILQ_FOREACH(cmd, cmds, node) {
+ fn(cmd, opaque);
}
-
- return list_head;
}