qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH v2 01/27] qom: clean up cast macros


From: Anthony Liguori
Subject: Re: [Qemu-devel] [PATCH v2 01/27] qom: clean up cast macros
Date: Mon, 06 Feb 2012 08:03:43 -0600
User-agent: Mozilla/5.0 (X11; U; Linux x86_64; en-US; rv:1.9.2.23) Gecko/20110922 Lightning/1.0b2 Thunderbird/3.1.15

On 02/04/2012 02:02 AM, Paolo Bonzini wrote:
Signed-off-by: Paolo Bonzini<address@hidden>

Reviewed-by: Anthony Liguori <address@hidden>

Regards,

Anthony Liguori

---
  include/qemu/object.h |   22 +++++++++++++++-------
  1 files changed, 15 insertions(+), 7 deletions(-)

diff --git a/include/qemu/object.h b/include/qemu/object.h
index 9d0251d..ab1c48c 100644
--- a/include/qemu/object.h
+++ b/include/qemu/object.h
@@ -259,6 +259,16 @@ struct TypeInfo
      ((Object *)(obj))

  /**
+ * OBJECT_CLASS:
+ * @class: A derivative of #ObjectClas.
+ *
+ * Converts a class to an #ObjectClass.  Since all objects are #Objects,
+ * this function will always succeed.
+ */
+#define OBJECT_CLASS(class) \
+    ((ObjectClass *)(class))
+
+/**
   * OBJECT_CHECK:
   * @type: The C type to use for the return value.
   * @obj: A derivative of @type to cast.
@@ -272,7 +282,7 @@ struct TypeInfo
   * generated.
   */
  #define OBJECT_CHECK(type, obj, name) \
-    ((type *)object_dynamic_cast_assert((Object *)(obj), (name)))
+    ((type *)object_dynamic_cast_assert(OBJECT(obj), (name)))

  /**
   * OBJECT_CLASS_CHECK:
@@ -280,11 +290,12 @@ struct TypeInfo
   * @obj: A derivative of @type to cast.
   * @name: the QOM typename of @class.
   *
- * A type safe version of @object_check_class.  This macro is typically wrapped
- * by each type to perform type safe casts of a class to a specific class type.
+ * A type safe version of @object_class_dynamic_cast_assert.  This macro is
+ * typically wrapped by each type to perform type safe casts of a class to a
+ * specific class type.
   */
  #define OBJECT_CLASS_CHECK(class, obj, name) \
-    ((class *)object_class_dynamic_cast_assert((ObjectClass *)(obj), (name)))
+    ((class *)object_class_dynamic_cast_assert(OBJECT_CLASS(obj), (name)))

  /**
   * OBJECT_GET_CLASS:
@@ -299,9 +310,6 @@ struct TypeInfo
  #define OBJECT_GET_CLASS(class, obj, name) \
      OBJECT_CLASS_CHECK(class, object_get_class(OBJECT(obj)), name)

-#define OBJECT_CLASS(class) \
-    ((ObjectClass *)(class))
-
  /**
   * InterfaceClass:
   * @parent_class: the base class




reply via email to

[Prev in Thread] Current Thread [Next in Thread]