]>
Commit | Line | Data |
---|---|---|
269e09f3 IM |
1 | #ifndef OBJECT_INTERFACES_H |
2 | #define OBJECT_INTERFACES_H | |
3 | ||
4 | #include "qom/object.h" | |
90998d58 DB |
5 | #include "qapi/qmp/qdict.h" |
6 | #include "qapi/visitor.h" | |
269e09f3 IM |
7 | |
8 | #define TYPE_USER_CREATABLE "user-creatable" | |
9 | ||
10 | #define USER_CREATABLE_CLASS(klass) \ | |
11 | OBJECT_CLASS_CHECK(UserCreatableClass, (klass), \ | |
12 | TYPE_USER_CREATABLE) | |
13 | #define USER_CREATABLE_GET_CLASS(obj) \ | |
14 | OBJECT_GET_CLASS(UserCreatableClass, (obj), \ | |
15 | TYPE_USER_CREATABLE) | |
16 | #define USER_CREATABLE(obj) \ | |
17 | INTERFACE_CHECK(UserCreatable, (obj), \ | |
18 | TYPE_USER_CREATABLE) | |
19 | ||
20 | ||
21 | typedef struct UserCreatable { | |
22 | /* <private> */ | |
23 | Object Parent; | |
24 | } UserCreatable; | |
25 | ||
26 | /** | |
27 | * UserCreatableClass: | |
28 | * @parent_class: the base class | |
29 | * @complete: callback to be called after @obj's properties are set. | |
d6edb155 LM |
30 | * @can_be_deleted: callback to be called before an object is removed |
31 | * to check if @obj can be removed safely. | |
269e09f3 IM |
32 | * |
33 | * Interface is designed to work with -object/object-add/object_add | |
34 | * commands. | |
35 | * Interface is mandatory for objects that are designed to be user | |
36 | * creatable (i.e. -object/object-add/object_add, will accept only | |
37 | * objects that inherit this interface). | |
38 | * | |
39 | * Interface also provides an optional ability to do the second | |
40 | * stage * initialization of the object after its properties were | |
41 | * set. | |
42 | * | |
43 | * For objects created without using -object/object-add/object_add, | |
44 | * @user_creatable_complete() wrapper should be called manually if | |
45 | * object's type implements USER_CREATABLE interface and needs | |
46 | * complete() callback to be called. | |
47 | */ | |
48 | typedef struct UserCreatableClass { | |
49 | /* <private> */ | |
50 | InterfaceClass parent_class; | |
51 | ||
52 | /* <public> */ | |
53 | void (*complete)(UserCreatable *uc, Error **errp); | |
d6edb155 | 54 | bool (*can_be_deleted)(UserCreatable *uc, Error **errp); |
269e09f3 IM |
55 | } UserCreatableClass; |
56 | ||
57 | /** | |
58 | * user_creatable_complete: | |
59 | * @obj: the object whose complete() method is called if defined | |
60 | * @errp: if an error occurs, a pointer to an area to store the error | |
61 | * | |
62 | * Wrapper to call complete() method if one of types it's inherited | |
63 | * from implements USER_CREATABLE interface, otherwise the call does | |
64 | * nothing. | |
65 | */ | |
66 | void user_creatable_complete(Object *obj, Error **errp); | |
d6edb155 LM |
67 | |
68 | /** | |
69 | * user_creatable_can_be_deleted: | |
70 | * @uc: the object whose can_be_deleted() method is called if implemented | |
71 | * @errp: if an error occurs, a pointer to an area to store the error | |
72 | * | |
73 | * Wrapper to call can_be_deleted() method if one of types it's inherited | |
74 | * from implements USER_CREATABLE interface. | |
75 | */ | |
76 | bool user_creatable_can_be_deleted(UserCreatable *uc, Error **errp); | |
90998d58 | 77 | |
90998d58 DB |
78 | /** |
79 | * user_creatable_add_type: | |
80 | * @type: the object type name | |
81 | * @id: the unique ID for the object | |
82 | * @qdict: the object properties | |
83 | * @v: the visitor | |
84 | * @errp: if an error occurs, a pointer to an area to store the error | |
85 | * | |
86 | * Create an instance of the user creatable object @type, placing | |
87 | * it in the object composition tree with name @id, initializing | |
88 | * it with properties from @qdict | |
89 | * | |
90 | * Returns: the newly created object or NULL on error | |
91 | */ | |
92 | Object *user_creatable_add_type(const char *type, const char *id, | |
93 | const QDict *qdict, | |
94 | Visitor *v, Error **errp); | |
95 | ||
96 | /** | |
97 | * user_creatable_add_opts: | |
98 | * @opts: the object definition | |
99 | * @errp: if an error occurs, a pointer to an area to store the error | |
100 | * | |
101 | * Create an instance of the user creatable object whose type | |
102 | * is defined in @opts by the 'qom-type' option, placing it | |
103 | * in the object composition tree with name provided by the | |
104 | * 'id' field. The remaining options in @opts are used to | |
105 | * initialize the object properties. | |
106 | * | |
107 | * Returns: the newly created object or NULL on error | |
108 | */ | |
109 | Object *user_creatable_add_opts(QemuOpts *opts, Error **errp); | |
110 | ||
111 | ||
112 | /** | |
113 | * user_creatable_add_opts_predicate: | |
114 | * @type: the QOM type to be added | |
115 | * | |
116 | * A callback function to determine whether an object | |
117 | * of type @type should be created. Instances of this | |
118 | * callback should be passed to user_creatable_add_opts_foreach | |
119 | */ | |
120 | typedef bool (*user_creatable_add_opts_predicate)(const char *type); | |
121 | ||
122 | /** | |
123 | * user_creatable_add_opts_foreach: | |
124 | * @opaque: a user_creatable_add_opts_predicate callback or NULL | |
125 | * @opts: options to create | |
51b9b478 | 126 | * @errp: unused |
90998d58 DB |
127 | * |
128 | * An iterator callback to be used in conjunction with | |
129 | * the qemu_opts_foreach() method for creating a list of | |
130 | * objects from a set of QemuOpts | |
131 | * | |
132 | * The @opaque parameter can be passed a user_creatable_add_opts_predicate | |
133 | * callback to filter which types of object are created during iteration. | |
51b9b478 | 134 | * When it fails, report the error. |
90998d58 | 135 | * |
51b9b478 | 136 | * Returns: 0 on success, -1 when an error was reported. |
90998d58 DB |
137 | */ |
138 | int user_creatable_add_opts_foreach(void *opaque, | |
139 | QemuOpts *opts, Error **errp); | |
140 | ||
141 | /** | |
142 | * user_creatable_del: | |
143 | * @id: the unique ID for the object | |
144 | * @errp: if an error occurs, a pointer to an area to store the error | |
145 | * | |
146 | * Delete an instance of the user creatable object identified | |
147 | * by @id. | |
148 | */ | |
149 | void user_creatable_del(const char *id, Error **errp); | |
150 | ||
269e09f3 | 151 | #endif |