diff options
author | Luiz Capitulino <lcapitulino@redhat.com> | 2009-10-07 13:41:48 -0300 |
---|---|---|
committer | Anthony Liguori <aliguori@us.ibm.com> | 2009-10-08 21:17:18 -0500 |
commit | 9ac11138aa5b7b03fa37995b9790ca04541c02a0 (patch) | |
tree | a303e22cb3a27f584637acb7e7f33ddf66f7ac30 /qlist.h | |
parent | 4a9c5ec282c3d6a3e419927460c49e82a230d726 (diff) | |
download | qemu-9ac11138aa5b7b03fa37995b9790ca04541c02a0.tar.gz qemu-9ac11138aa5b7b03fa37995b9790ca04541c02a0.tar.bz2 qemu-9ac11138aa5b7b03fa37995b9790ca04541c02a0.zip |
Introduce QList
QList is a high-level data type that can be used to store QObjects
in a singly-linked list.
The following functions are available:
- qlist_new() Create a new QList
- qlist_append() Append a QObject to the list
- qlist_iter() Iterate over stored QObjects
Patchworks-ID: 35334
Signed-off-by: Luiz Capitulino <lcapitulino@redhat.com>
Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
Diffstat (limited to 'qlist.h')
-rw-r--r-- | qlist.h | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/qlist.h b/qlist.h new file mode 100644 index 0000000000..3eb1eb83b2 --- /dev/null +++ b/qlist.h @@ -0,0 +1,38 @@ +/* + * QList data type header. + * + * Copyright (C) 2009 Red Hat Inc. + * + * Authors: + * Luiz Capitulino <lcapitulino@redhat.com> + * + * This work is licensed under the terms of the GNU GPL, version 2. See + * the COPYING file in the top-level directory. + */ +#ifndef QLIST_H +#define QLIST_H + +#include "qobject.h" +#include "qemu-queue.h" +#include "qemu-common.h" + +typedef struct QListEntry { + QObject *value; + QTAILQ_ENTRY(QListEntry) next; +} QListEntry; + +typedef struct QList { + QObject_HEAD; + QTAILQ_HEAD(,QListEntry) head; +} QList; + +#define qlist_append(qlist, obj) \ + qlist_append_obj(qlist, QOBJECT(obj)) + +QList *qlist_new(void); +void qlist_append_obj(QList *qlist, QObject *obj); +void qlist_iter(const QList *qlist, + void (*iter)(QObject *obj, void *opaque), void *opaque); +QList *qobject_to_qlist(const QObject *obj); + +#endif /* QLIST_H */ |