X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-client%2Fclient.h;h=5128bd9ddb16df8da3fbfee27fa96cae8d50aaa1;hb=d8260fdf4310e135f301d0b8296aeffa02f5f494;hp=5b0e9109aecdb415573fda6f2238806128f6d29d;hpb=98d4644e8f9445fa4cf7395b05a9f860b8f3cb9c;p=catta diff --git a/avahi-client/client.h b/avahi-client/client.h index 5b0e910..5128bd9 100644 --- a/avahi-client/client.h +++ b/avahi-client/client.h @@ -1,7 +1,7 @@ #ifndef fooclienthfoo #define fooclienthfoo -/* $Id: core.h 98 2005-06-04 18:56:52Z lathiat $ */ +/* $Id$ */ /*** This file is part of avahi. @@ -22,39 +22,62 @@ USA. ***/ +#include + #include +#include +#include +#include +#include +#include /** \file client.h Definitions and functions for the client API over D-Bus */ +/** \example glib-integration.c Example of how to integrate + * avahi use with GLIB/GTK applications */ + AVAHI_C_DECL_BEGIN -typedef struct _AvahiClientPriv AvahiClientPriv; +/** A connection context */ +typedef struct AvahiClient AvahiClient; + +/** States of a client object, a superset of AvahiServerState */ +typedef enum { + AVAHI_CLIENT_S_REGISTERING = AVAHI_SERVER_REGISTERING, + AVAHI_CLIENT_S_RUNNING = AVAHI_SERVER_RUNNING, + AVAHI_CLIENT_S_COLLISION = AVAHI_SERVER_COLLISION, + AVAHI_CLIENT_DISCONNECTED = 100 /**< Lost DBUS connection to the Avahi daemon */ +} AvahiClientState; -typedef struct _AvahiClient { - int serverid; - AvahiClientPriv *priv; -} AvahiClient; +/** The function prototype for the callback of an AvahiClient */ +typedef void (*AvahiClientCallback) (AvahiClient *s, AvahiClientState state, void* userdata); /** Creates a new client instance */ -AvahiClient* avahi_client_new (); +AvahiClient* avahi_client_new (const AvahiPoll *poll_api, AvahiClientCallback callback, void *userdata, int *error); + +/** Free a client instance */ +void avahi_client_free(AvahiClient *client); /** Get the version of the server */ -char* avahi_client_get_version_string (AvahiClient*); +const char* avahi_client_get_version_string (AvahiClient*); /** Get host name */ -char* avahi_client_get_host_name (AvahiClient*); +const char* avahi_client_get_host_name (AvahiClient*); /** Get domain name */ -char* avahi_client_get_domain_name (AvahiClient*); +const char* avahi_client_get_domain_name (AvahiClient*); /** Get FQDN domain name */ -char* avahi_client_get_host_name_fqdn (AvahiClient*); +const char* avahi_client_get_host_name_fqdn (AvahiClient*); + +/** Get state */ +AvahiClientState avahi_client_get_state(AvahiClient *client); -/** Get alternative host name for a host name that is taken */ -char* avahi_client_get_alternative_host_name (AvahiClient*, char*); +/** Get the last error number */ +int avahi_client_errno (AvahiClient*); -/** Get alternative service name for a service name that is taken */ -char* avahi_client_get_alternative_service_name (AvahiClient*, char*); +/** Return the local service cookie. returns AVAHI_SERVICE_COOKIE_INVALID on failure. */ +uint32_t avahi_client_get_local_service_cookie(AvahiClient *client); AVAHI_C_DECL_END