]> git.proxmox.com Git - mirror_qemu.git/blobdiff - qapi/qmp-registry.c
Merge remote-tracking branch 'remotes/kraxel/tags/ui-20190704-pull-request' into...
[mirror_qemu.git] / qapi / qmp-registry.c
index 3fe8866d44b1f86972fa537b41c416e058344f2c..ca00f74795ba8c00f5e5d415f7d39ad08e0b1fba 100644 (file)
  *
  */
 
-#include "qapi/qmp-core.h"
+#include "qemu/osdep.h"
+#include "qapi/qmp/dispatch.h"
 
-static QTAILQ_HEAD(, 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 = qemu_mallocz(sizeof(*cmd));
+    QmpCommand *cmd = g_malloc0(sizeof(*cmd));
 
     cmd->name = name;
-    cmd->type = QCT_NORMAL;
     cmd->fn = fn;
-    QTAILQ_INSERT_TAIL(&qmp_commands, cmd, node);
+    cmd->enabled = true;
+    cmd->options = options;
+    QTAILQ_INSERT_TAIL(cmds, cmd, node);
 }
 
-QmpCommand *qmp_find_command(const char *name)
+QmpCommand *qmp_find_command(QmpCommandList *cmds, const char *name)
 {
-    QmpCommand *i;
+    QmpCommand *cmd;
 
-    QTAILQ_FOREACH(i, &qmp_commands, node) {
-        if (strcmp(i->name, name) == 0) {
-            return i;
+    QTAILQ_FOREACH(cmd, cmds, node) {
+        if (strcmp(cmd->name, name) == 0) {
+            return cmd;
         }
     }
     return NULL;
 }
+
+static void qmp_toggle_command(QmpCommandList *cmds, const char *name,
+                               bool enabled)
+{
+    QmpCommand *cmd;
+
+    QTAILQ_FOREACH(cmd, cmds, node) {
+        if (strcmp(cmd->name, name) == 0) {
+            cmd->enabled = enabled;
+            return;
+        }
+    }
+}
+
+void qmp_disable_command(QmpCommandList *cmds, const char *name)
+{
+    qmp_toggle_command(cmds, name, false);
+}
+
+void qmp_enable_command(QmpCommandList *cmds, const char *name)
+{
+    qmp_toggle_command(cmds, name, true);
+}
+
+bool qmp_command_is_enabled(const QmpCommand *cmd)
+{
+    return cmd->enabled;
+}
+
+const char *qmp_command_name(const QmpCommand *cmd)
+{
+    return cmd->name;
+}
+
+bool qmp_has_success_response(const QmpCommand *cmd)
+{
+    return !(cmd->options & QCO_NO_SUCCESS_RESP);
+}
+
+void qmp_for_each_command(QmpCommandList *cmds, qmp_cmd_callback_fn fn,
+                          void *opaque)
+{
+    QmpCommand *cmd;
+
+    QTAILQ_FOREACH(cmd, cmds, node) {
+        fn(cmd, opaque);
+    }
+}