]> Git Repo - qemu.git/blobdiff - qapi/qmp-registry.c
spapr_vscsi: Fix REPORT_LUNS handling
[qemu.git] / qapi / qmp-registry.c
index 25c89ad098a2a655a6bf9eb9a0f4f94119f24e65..3e4498a3f6b88980f3c6194a1f7db501270fa111 100644 (file)
  *
  */
 
-#include "qapi/qmp-core.h"
+#include <glib.h>
+#include <string.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(const char *name, QmpCommandFunc *fn,
+                          QmpCommandOptions options)
 {
     QmpCommand *cmd = g_malloc0(sizeof(*cmd));
 
@@ -25,6 +28,7 @@ void qmp_register_command(const char *name, QmpCommandFunc *fn)
     cmd->type = QCT_NORMAL;
     cmd->fn = fn;
     cmd->enabled = true;
+    cmd->options = options;
     QTAILQ_INSERT_TAIL(&qmp_commands, cmd, node);
 }
 
@@ -40,47 +44,48 @@ QmpCommand *qmp_find_command(const char *name)
     return NULL;
 }
 
-void qmp_disable_command(const char *name)
+static void qmp_toggle_command(const char *name, bool enabled)
 {
     QmpCommand *cmd;
 
     QTAILQ_FOREACH(cmd, &qmp_commands, 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(const char *name)
 {
-    QmpCommand *cmd;
+    qmp_toggle_command(name, false);
+}
 
-    QTAILQ_FOREACH(cmd, &qmp_commands, node) {
-        if (strcmp(cmd->name, name) == 0) {
-            return cmd->enabled;
-        }
-    }
+void qmp_enable_command(const char *name)
+{
+    qmp_toggle_command(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(qmp_cmd_callback_fn fn, void *opaque)
+{
+    QmpCommand *cmd;
 
     QTAILQ_FOREACH(cmd, &qmp_commands, node) {
-        *list = strdup(cmd->name);
-        list++;
+        fn(cmd, opaque);
     }
-
-    return list_head;
 }
This page took 0.022803 seconds and 4 git commands to generate.