4 This file is part of avahi.
6 avahi is free software; you can redistribute it and/or modify it
7 under the terms of the GNU Lesser General Public License as
8 published by the Free Software Foundation; either version 2.1 of the
9 License, or (at your option) any later version.
11 avahi is distributed in the hope that it will be useful, but WITHOUT
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
14 Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with avahi; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
29 #include <avahi-common/llist.h>
30 #include <avahi-common/malloc.h>
35 typedef struct AvahiRecordListItem AvahiRecordListItem;
37 struct AvahiRecordListItem {
43 AVAHI_LLIST_FIELDS(AvahiRecordListItem, items);
47 struct AvahiRecordList {
48 AVAHI_LLIST_HEAD(AvahiRecordListItem, read);
49 AVAHI_LLIST_HEAD(AvahiRecordListItem, unread);
52 AvahiRecordList *avahi_record_list_new(void) {
55 if (!(l = avahi_new(AvahiRecordList, 1))) {
56 avahi_log_error("avahi_new() failed.");
60 AVAHI_LLIST_HEAD_INIT(AvahiRecordListItem, l->read);
61 AVAHI_LLIST_HEAD_INIT(AvahiRecordListItem, l->unread);
65 void avahi_record_list_free(AvahiRecordList *l) {
68 avahi_record_list_flush(l);
72 static void item_free(AvahiRecordList *l, AvahiRecordListItem *i) {
77 AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->read, i);
79 AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->unread, i);
81 avahi_record_unref(i->record);
85 void avahi_record_list_flush(AvahiRecordList *l) {
89 item_free(l, l->read);
91 item_free(l, l->unread);
94 AvahiRecord* avahi_record_list_next(AvahiRecordList *l, int *flush_cache, int *unicast_response, int *auxiliary) {
96 AvahiRecordListItem *i;
103 r = avahi_record_ref(i->record);
104 if (unicast_response)
105 *unicast_response = i->unicast_response;
107 *flush_cache = i->flush_cache;
109 *auxiliary = i->auxiliary;
111 AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->unread, i);
112 AVAHI_LLIST_PREPEND(AvahiRecordListItem, items, l->read, i);
119 static AvahiRecordListItem *get(AvahiRecordList *l, AvahiRecord *r) {
120 AvahiRecordListItem *i;
125 for (i = l->read; i; i = i->items_next)
126 if (avahi_record_equal_no_ttl(i->record, r))
129 for (i = l->unread; i; i = i->items_next)
130 if (avahi_record_equal_no_ttl(i->record, r))
136 void avahi_record_list_push(AvahiRecordList *l, AvahiRecord *r, int flush_cache, int unicast_response, int auxiliary) {
137 AvahiRecordListItem *i;
145 if (!(i = avahi_new(AvahiRecordListItem, 1))) {
146 avahi_log_error("avahi_new() failed.");
150 i->unicast_response = unicast_response;
151 i->flush_cache = flush_cache;
152 i->auxiliary = auxiliary;
153 i->record = avahi_record_ref(r);
156 AVAHI_LLIST_PREPEND(AvahiRecordListItem, items, l->unread, i);
159 void avahi_record_list_drop(AvahiRecordList *l, AvahiRecord *r) {
160 AvahiRecordListItem *i;
165 if (!(i = get(l, r)))
171 int avahi_record_list_is_empty(AvahiRecordList *l) {
174 return !l->unread && !l->read;