X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Frrlist.c;h=915ecbb87bccb3297e5d5187c6d4d4978ebfdf33;hb=78a76e3d5f1d9cc81fd901b8e0263483a7c707d0;hp=429f142c1fa64f5ff430431dd5198cc56bbf085f;hpb=af1ce5fe2245fba0045d2c0d70b58b700938bd2f;p=catta diff --git a/avahi-core/rrlist.c b/avahi-core/rrlist.c index 429f142..915ecbb 100644 --- a/avahi-core/rrlist.c +++ b/avahi-core/rrlist.c @@ -19,99 +19,172 @@ USA. ***/ +#ifdef HAVE_CONFIG_H +#include +#endif + +#include +#include + +#include +#include + #include "rrlist.h" -#include "llist.h" +#include "log.h" typedef struct AvahiRecordListItem AvahiRecordListItem; struct AvahiRecordListItem { + int read; AvahiRecord *record; - gboolean unicast_response; - gboolean flush_cache; + int unicast_response; + int flush_cache; + int auxiliary; AVAHI_LLIST_FIELDS(AvahiRecordListItem, items); }; - struct AvahiRecordList { - AVAHI_LLIST_HEAD(AvahiRecordListItem, items); + AVAHI_LLIST_HEAD(AvahiRecordListItem, read); + AVAHI_LLIST_HEAD(AvahiRecordListItem, unread); + + int all_flush_cache; }; AvahiRecordList *avahi_record_list_new(void) { - AvahiRecordList *l = g_new(AvahiRecordList, 1); - AVAHI_LLIST_HEAD_INIT(AvahiRecordListItem, l->items); + AvahiRecordList *l; + + if (!(l = avahi_new(AvahiRecordList, 1))) { + avahi_log_error("avahi_new() failed."); + return NULL; + } + + AVAHI_LLIST_HEAD_INIT(AvahiRecordListItem, l->read); + AVAHI_LLIST_HEAD_INIT(AvahiRecordListItem, l->unread); + + l->all_flush_cache = 1; return l; } void avahi_record_list_free(AvahiRecordList *l) { - g_assert(l); + assert(l); avahi_record_list_flush(l); - g_free(l); + avahi_free(l); } static void item_free(AvahiRecordList *l, AvahiRecordListItem *i) { - g_assert(i); + assert(l); + assert(i); - AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->items, i); + if (i->read) + AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->read, i); + else + AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->unread, i); + avahi_record_unref(i->record); - g_free(i); + avahi_free(i); } void avahi_record_list_flush(AvahiRecordList *l) { - g_assert(l); + assert(l); - while (l->items) - item_free(l, l->items); + while (l->read) + item_free(l, l->read); + while (l->unread) + item_free(l, l->unread); + + l->all_flush_cache = 1; } -AvahiRecord* avahi_record_list_pop(AvahiRecordList *l, gboolean *flush_cache, gboolean *unicast_response) { +AvahiRecord* avahi_record_list_next(AvahiRecordList *l, int *ret_flush_cache, int *ret_unicast_response, int *ret_auxiliary) { AvahiRecord *r; + AvahiRecordListItem *i; - if (!l->items) + if (!(i = l->unread)) return NULL; - - r = avahi_record_ref(l->items->record); - if (unicast_response) *unicast_response = l->items->unicast_response; - if (flush_cache) *flush_cache = l->items->flush_cache; - item_free(l, l->items); + assert(!i->read); + + r = avahi_record_ref(i->record); + if (ret_unicast_response) + *ret_unicast_response = i->unicast_response; + if (ret_flush_cache) + *ret_flush_cache = i->flush_cache; + if (ret_auxiliary) + *ret_auxiliary = i->auxiliary; + + AVAHI_LLIST_REMOVE(AvahiRecordListItem, items, l->unread, i); + AVAHI_LLIST_PREPEND(AvahiRecordListItem, items, l->read, i); + + i->read = 1; return r; } -void avahi_record_list_push(AvahiRecordList *l, AvahiRecord *r, gboolean flush_cache, gboolean unicast_response) { +static AvahiRecordListItem *get(AvahiRecordList *l, AvahiRecord *r) { AvahiRecordListItem *i; - - g_assert(l); - g_assert(r); + + assert(l); + assert(r); - for (i = l->items; i; i = i->items_next) + for (i = l->read; i; i = i->items_next) if (avahi_record_equal_no_ttl(i->record, r)) - return; + return i; - i = g_new(AvahiRecordListItem, 1); + for (i = l->unread; i; i = i->items_next) + if (avahi_record_equal_no_ttl(i->record, r)) + return i; + + return NULL; +} + +void avahi_record_list_push(AvahiRecordList *l, AvahiRecord *r, int flush_cache, int unicast_response, int auxiliary) { + AvahiRecordListItem *i; + + assert(l); + assert(r); + + if (get(l, r)) + return; + + if (!(i = avahi_new(AvahiRecordListItem, 1))) { + avahi_log_error("avahi_new() failed."); + return; + } + i->unicast_response = unicast_response; i->flush_cache = flush_cache; + i->auxiliary = auxiliary; i->record = avahi_record_ref(r); - AVAHI_LLIST_PREPEND(AvahiRecordListItem, items, l->items, i); + i->read = 0; + + l->all_flush_cache = l->all_flush_cache && flush_cache; + + AVAHI_LLIST_PREPEND(AvahiRecordListItem, items, l->unread, i); } void avahi_record_list_drop(AvahiRecordList *l, AvahiRecord *r) { AvahiRecordListItem *i; - g_assert(l); - g_assert(r); + assert(l); + assert(r); + + if (!(i = get(l, r))) + return; - for (i = l->items; i; i = i->items_next) - if (avahi_record_equal_no_ttl(i->record, r)) { - item_free(l, i); - break; - } + item_free(l, i); +} + +int avahi_record_list_is_empty(AvahiRecordList *l) { + assert(l); + + return !l->unread && !l->read; } +int avahi_record_list_all_flush_cache(AvahiRecordList *l) { + assert(l); -gboolean avahi_record_list_empty(AvahiRecordList *l) { - g_assert(l); + /* Return TRUE if all entries in this list have flush_cache set */ - return !l->items; + return l->all_flush_cache; }