X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=avahi-common%2Fdomain.h;h=26f4b73832a1602569d49cae1a4624506034d100;hb=a36df935a82b59544fa4fa56effef0ab123a97ce;hp=fc9d7fd6605262a711fcdd3c3f62baf10e06d3ec;hpb=b0cc701e2f5acbd6b115549a1dbe9e00051ff867;p=catta diff --git a/avahi-common/domain.h b/avahi-common/domain.h index fc9d7fd..26f4b73 100644 --- a/avahi-common/domain.h +++ b/avahi-common/domain.h @@ -1,5 +1,5 @@ #ifndef foodomainhfoo -#define foodimainhfoo +#define foodomainhfoo /* $Id$ */ @@ -24,21 +24,43 @@ /** \file domain.h Domain name handling functions */ - #include #include #include +#ifndef DOXYGEN_SHOULD_SKIP_THIS AVAHI_C_DECL_BEGIN +#endif + +/** The maximum length of a a fully escaped domain name C string. This + * is calculated like this: RFC1034 mandates maximum length of FQDNs + * is 255. The maximum label length is 63. To minimize the number of + * (non-escaped) dots, we comprise our maximum-length domain name of + * four labels รก 63 characters plus three inner dots. Escaping the + * four labels quadruples their length at maximum. An escaped domain + * name has the therefore the maximum length of 63*4*4+3=1011. A + * trailing NUL and perhaps two unnecessary dots leading and trailing + * the string brings us to 1014. */ +#define AVAHI_DOMAIN_NAME_MAX 1014 + +/** Maxium size of an unescaped label */ +#define AVAHI_LABEL_MAX 64 + +/** Normalize a domain name into canonical form. This drops trailing + * dots and removes useless backslash escapes. */ +char *avahi_normalize_name(const char *s, char *ret_s, size_t size); /** Normalize a domain name into canonical form. This drops trailing * dots and removes useless backslash escapes. avahi_free() the * result! */ -char *avahi_normalize_name(const char *s); +char *avahi_normalize_name_strdup(const char *s); + +/** Return the local host name. */ +char *avahi_get_host_name(char *ret_s, size_t size); /** Return the local host name. avahi_free() the result! */ -char *avahi_get_host_name(void); +char *avahi_get_host_name_strdup(void); /** Return 1 when the specified domain names are equal, 0 otherwise */ int avahi_domain_equal(const char *a, const char *b); @@ -51,32 +73,50 @@ int avahi_binary_domain_cmp(const char *a, const char *b); char *avahi_unescape_label(const char **name, char *dest, size_t size); /** Escape the domain name in *src and write it to *ret_name */ -char *avahi_escape_label(const uint8_t* src, size_t src_length, char **ret_name, size_t *ret_size); +char *avahi_escape_label(const char* src, size_t src_length, char **ret_name, size_t *ret_size); + +/** Return 1 when the specified string contains a valid generic + * service type (i.e. a series of words starting with "_"), 0 + * otherwise */ +int avahi_is_valid_service_type_generic(const char *t); -/** Return some kind of hash value for a string */ -unsigned avahi_strhash(const char *p); +/** Return 1 when the specified string contains a valid strict service + * type (i.e. consisting of only two words, the latter being either + * _udp or _tcp), 0 otherwise */ +int avahi_is_valid_service_type_strict(const char *t); -/** Return some kind of hash value for a domain */ -unsigned avahi_domain_hash(const char *s); +/** Return 1 when the specified string contains a valid service subtype, 0 otherwise */ +int avahi_is_valid_service_subtype(const char *t); -/** Return 1 when the specified string contains a valid service type, 0 otherwise */ -int avahi_valid_service_type(const char *t); +/** Return a pointer to the type section of a subtype i.e. _foo._sub._bar._tcp => _bar._tcp */ +const char *avahi_get_type_from_subtype(const char *t); /** Return 1 when the specified string contains a valid domain name, 0 otherwise */ -int avahi_valid_domain_name(const char *t); +int avahi_is_valid_domain_name(const char *t); /** Return 1 when the specified string contains a valid service name, 0 otherwise */ -int avahi_valid_service_name(const char *t); +int avahi_is_valid_service_name(const char *t); /** Return 1 when the specified string contains a valid non-FQDN host name (i.e. without dots), 0 otherwise */ -int avahi_valid_host_name(const char *t); +int avahi_is_valid_host_name(const char *t); + +/** Return some kind of hash value for the domain, useful for using domains as hash table keys. */ +unsigned avahi_domain_hash(const char *name); -/** Change every character in the string to upper case (ASCII), return a pointer to the string */ -char *avahi_strup(char *s); +/** Returns 1 if the the end labels of domain are eqal to suffix */ +int avahi_domain_ends_with(const char *domain, const char *suffix); -/** Change every character in the string to lower case (ASCII), return a pointer to the string */ -char *avahi_strdown(char *s); +/** Construct a valid complete service name from a name, a type and a domain */ +int avahi_service_name_join(char *p, size_t size, const char *name, const char *type, const char *domain); +/** Split a full service name into name, type and domain */ +int avahi_service_name_split(const char *p, char *name, size_t name_size, char *type, size_t type_size, char *domain, size_t domain_size); + +/** Just like OpenBSD strlcpy */ +char *avahi_strlcpy(char *dest, const char *src, size_t n); + +#ifndef DOXYGEN_SHOULD_SKIP_THIS AVAHI_C_DECL_END +#endif #endif