4 * Copyright (C) 2009 Red Hat Inc.
7 * Luiz Capitulino <lcapitulino@redhat.com>
9 * This work is licensed under the terms of the GNU GPL, version 2. See
10 * the COPYING file in the top-level directory.
14 #include "qemu-queue.h"
15 #include "qemu-common.h"
17 static void qlist_destroy_obj(QObject
*obj
);
19 static const QType qlist_type
= {
21 .destroy
= qlist_destroy_obj
,
25 * qlist_new(): Create a new QList
27 * Return strong reference.
29 QList
*qlist_new(void)
33 qlist
= qemu_malloc(sizeof(*qlist
));
34 QTAILQ_INIT(&qlist
->head
);
35 QOBJECT_INIT(qlist
, &qlist_type
);
41 * qlist_append_obj(): Append an QObject into QList
43 * NOTE: ownership of 'value' is transferred to the QList
45 void qlist_append_obj(QList
*qlist
, QObject
*value
)
49 entry
= qemu_malloc(sizeof(*entry
));
52 QTAILQ_INSERT_TAIL(&qlist
->head
, entry
, next
);
56 * qlist_iter(): Iterate over all the list's stored values.
58 * This function allows the user to provide an iterator, which will be
59 * called for each stored value in the list.
61 void qlist_iter(const QList
*qlist
,
62 void (*iter
)(QObject
*obj
, void *opaque
), void *opaque
)
66 QTAILQ_FOREACH(entry
, &qlist
->head
, next
)
67 iter(entry
->value
, opaque
);
71 * qobject_to_qlist(): Convert a QObject into a QList
73 QList
*qobject_to_qlist(const QObject
*obj
)
75 if (qobject_type(obj
) != QTYPE_QLIST
) {
79 return container_of(obj
, QList
, base
);
83 * qlist_destroy_obj(): Free all the memory allocated by a QList
85 static void qlist_destroy_obj(QObject
*obj
)
88 QListEntry
*entry
, *next_entry
;
91 qlist
= qobject_to_qlist(obj
);
93 QTAILQ_FOREACH_SAFE(entry
, &qlist
->head
, next
, next_entry
) {
94 QTAILQ_REMOVE(&qlist
->head
, entry
, next
);
95 qobject_decref(entry
->value
);