qapi-dealloc-visitor.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. /*
  2. * Dealloc Visitor
  3. *
  4. * Copyright (C) 2012-2016 Red Hat, Inc.
  5. * Copyright IBM, Corp. 2011
  6. *
  7. * Authors:
  8. * Michael Roth <mdroth@linux.vnet.ibm.com>
  9. *
  10. * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
  11. * See the COPYING.LIB file in the top-level directory.
  12. *
  13. */
  14. #include "qemu/osdep.h"
  15. #include "qapi/dealloc-visitor.h"
  16. #include "qemu/queue.h"
  17. #include "qemu-common.h"
  18. #include "qapi/qmp/types.h"
  19. #include "qapi/visitor-impl.h"
  20. struct QapiDeallocVisitor
  21. {
  22. Visitor visitor;
  23. };
  24. static void qapi_dealloc_start_struct(Visitor *v, const char *name, void **obj,
  25. size_t unused, Error **errp)
  26. {
  27. }
  28. static void qapi_dealloc_end_struct(Visitor *v, void **obj)
  29. {
  30. if (obj) {
  31. g_free(*obj);
  32. }
  33. }
  34. static void qapi_dealloc_start_alternate(Visitor *v, const char *name,
  35. GenericAlternate **obj, size_t size,
  36. bool promote_int, Error **errp)
  37. {
  38. }
  39. static void qapi_dealloc_end_alternate(Visitor *v, void **obj)
  40. {
  41. if (obj) {
  42. g_free(*obj);
  43. }
  44. }
  45. static void qapi_dealloc_start_list(Visitor *v, const char *name,
  46. GenericList **list, size_t size,
  47. Error **errp)
  48. {
  49. }
  50. static GenericList *qapi_dealloc_next_list(Visitor *v, GenericList *tail,
  51. size_t size)
  52. {
  53. GenericList *next = tail->next;
  54. g_free(tail);
  55. return next;
  56. }
  57. static void qapi_dealloc_end_list(Visitor *v, void **obj)
  58. {
  59. }
  60. static void qapi_dealloc_type_str(Visitor *v, const char *name, char **obj,
  61. Error **errp)
  62. {
  63. if (obj) {
  64. g_free(*obj);
  65. }
  66. }
  67. static void qapi_dealloc_type_int64(Visitor *v, const char *name, int64_t *obj,
  68. Error **errp)
  69. {
  70. }
  71. static void qapi_dealloc_type_uint64(Visitor *v, const char *name,
  72. uint64_t *obj, Error **errp)
  73. {
  74. }
  75. static void qapi_dealloc_type_bool(Visitor *v, const char *name, bool *obj,
  76. Error **errp)
  77. {
  78. }
  79. static void qapi_dealloc_type_number(Visitor *v, const char *name, double *obj,
  80. Error **errp)
  81. {
  82. }
  83. static void qapi_dealloc_type_anything(Visitor *v, const char *name,
  84. QObject **obj, Error **errp)
  85. {
  86. if (obj) {
  87. qobject_decref(*obj);
  88. }
  89. }
  90. static void qapi_dealloc_type_null(Visitor *v, const char *name, Error **errp)
  91. {
  92. }
  93. static void qapi_dealloc_free(Visitor *v)
  94. {
  95. g_free(container_of(v, QapiDeallocVisitor, visitor));
  96. }
  97. Visitor *qapi_dealloc_visitor_new(void)
  98. {
  99. QapiDeallocVisitor *v;
  100. v = g_malloc0(sizeof(*v));
  101. v->visitor.type = VISITOR_DEALLOC;
  102. v->visitor.start_struct = qapi_dealloc_start_struct;
  103. v->visitor.end_struct = qapi_dealloc_end_struct;
  104. v->visitor.start_alternate = qapi_dealloc_start_alternate;
  105. v->visitor.end_alternate = qapi_dealloc_end_alternate;
  106. v->visitor.start_list = qapi_dealloc_start_list;
  107. v->visitor.next_list = qapi_dealloc_next_list;
  108. v->visitor.end_list = qapi_dealloc_end_list;
  109. v->visitor.type_int64 = qapi_dealloc_type_int64;
  110. v->visitor.type_uint64 = qapi_dealloc_type_uint64;
  111. v->visitor.type_bool = qapi_dealloc_type_bool;
  112. v->visitor.type_str = qapi_dealloc_type_str;
  113. v->visitor.type_number = qapi_dealloc_type_number;
  114. v->visitor.type_any = qapi_dealloc_type_anything;
  115. v->visitor.type_null = qapi_dealloc_type_null;
  116. v->visitor.free = qapi_dealloc_free;
  117. return &v->visitor;
  118. }