X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-core%2Fbrowse.h;h=70e724fddcc7654668a026d32b97f7570fe4834f;hb=c75a6b480b047abc73ee7afd912aef249e9da8e3;hp=2c9a2ab297df0ba8366182e5f4992ed3d6c66d13;hpb=7540df5ed6b383ec93f5a4f10ab2d08f9b9869e4;p=catta diff --git a/avahi-core/browse.h b/avahi-core/browse.h index 2c9a2ab..70e724f 100644 --- a/avahi-core/browse.h +++ b/avahi-core/browse.h @@ -23,17 +23,43 @@ ***/ #include + #include "core.h" #include "timeeventq.h" #include "server.h" +#include "dns.h" +#include "lookup.h" -void avahi_browser_cleanup(AvahiServer *server); -void avahi_browser_notify(AvahiServer *s, AvahiInterface *i, AvahiRecord *record, AvahiBrowserEvent event); +typedef struct AvahiSRBLookup AvahiSRBLookup; + +struct AvahiSRecordBrowser { + AVAHI_LLIST_FIELDS(AvahiSRecordBrowser, browser); + int dead; + AvahiServer *server; + + AvahiKey *key; + AvahiIfIndex interface; + AvahiProtocol protocol; + AvahiLookupFlags flags; + + AvahiTimeEvent *defer_time_event; -gboolean avahi_is_subscribed(AvahiServer *s, AvahiInterface *i, AvahiKey *k); + AvahiSRecordBrowserCallback callback; + void* userdata; + + /* Lookup data */ + AVAHI_LLIST_HEAD(AvahiSRBLookup, lookups); + unsigned n_lookups; + + AvahiSRBLookup *root_lookup; +}; + +void avahi_browser_cleanup(AvahiServer *server); -void avahi_record_browser_destroy(AvahiRecordBrowser *b); +void avahi_s_record_browser_destroy(AvahiSRecordBrowser *b); +void avahi_s_record_browser_restart(AvahiSRecordBrowser *b); +void avahi_s_record_browser_cancel(AvahiSRecordBrowser *b); -void avahi_browser_new_interface(AvahiServer*s, AvahiInterface *i); +#define AVAHI_VALID_FLAGS(flags, max) (!((flags) & ~(max))) #endif