#include <sys/types.h>
#include <inttypes.h>
#include <stdarg.h>
#include <avahi-common/cdecl.h>
#include <avahi-common/gccmacro.h>
Go to the source code of this file.
Implementation of a data type to store lists of strings
Definition in file strlst.h.
typedef AVAHI_C_DECL_BEGIN struct AvahiStringList AvahiStringList |
Linked list of strings that can contain any number of binary characters, including NUL bytes. An empty list is created by assigning a NULL to a pointer to AvahiStringList. The string list is stored in reverse order, so that appending to the string list is effectively a prepending to the linked list. This object is used primarily for storing DNS TXT record data.
AvahiStringList* avahi_string_list_add | ( | AvahiStringList * | l, |
const char * | text | ||
) |
Append a NUL terminated string to the specified string list. The passed string is copied using g_strdup(). Returns the new list start.
AvahiStringList* avahi_string_list_add_anonymous | ( | AvahiStringList * | l, |
size_t | size | ||
) |
Append a new entry to the string list. The string is not filled with data. The caller should fill in string data afterwards by writing it to l->text, where l is the pointer returned by this function. This function exists solely to optimize a few operations where otherwise superfluous string copying would be necessary.
AvahiStringList* avahi_string_list_add_arbitrary | ( | AvahiStringList * | l, |
const uint8_t * | text, | ||
size_t | size | ||
) |
Append an arbitrary length byte string to the list. Returns the new list start.
AvahiStringList* avahi_string_list_add_many | ( | AvahiStringList * | r, |
... | |||
) |
Same as avahi_string_list_add(), but takes a variable number of NUL terminated strings. The argument list must be terminated by a NULL pointer. Returns the new list start.
AvahiStringList* avahi_string_list_add_pair | ( | AvahiStringList * | l, |
const char * | key, | ||
const char * | value | ||
) |
Add a new DNS-SD TXT key value pair to the string list. value may be NULL in case you want to specify a key without a value
AvahiStringList* avahi_string_list_add_pair_arbitrary | ( | AvahiStringList * | l, |
const char * | key, | ||
const uint8_t * | value, | ||
size_t | size | ||
) |
Same as avahi_string_list_add_pair() but allow strings containing NUL bytes in *value.
AvahiStringList* avahi_string_list_add_printf | ( | AvahiStringList * | l, |
const char * | format, | ||
... | |||
) |
Append a new NUL terminated formatted string to the specified string list
AvahiStringList* avahi_string_list_copy | ( | const AvahiStringList * | l | ) |
Copy a string list
int avahi_string_list_equal | ( | const AvahiStringList * | a, |
const AvahiStringList * | b | ||
) |
Compare to string lists
AvahiStringList* avahi_string_list_find | ( | AvahiStringList * | l, |
const char * | key | ||
) |
Find the string list entry for the given DNS-SD TXT key
Free a string list
Returns the next item in the string list
int avahi_string_list_get_pair | ( | AvahiStringList * | l, |
char ** | key, | ||
char ** | value, | ||
size_t * | size | ||
) |
Return the DNS-SD TXT key and value for the specified string list item. If size is not NULL it will be filled with the length of value. (for strings containing NUL bytes). If the entry doesn't contain a value *value will be set to NULL. You need to avahi_free() the strings returned in *key and *value.
size_t avahi_string_list_get_size | ( | AvahiStringList * | l | ) |
Returns the size of the current text
uint8_t* avahi_string_list_get_text | ( | AvahiStringList * | l | ) |
Returns the text for the current item
unsigned avahi_string_list_length | ( | const AvahiStringList * | l | ) |
Return the number of elements in the string list
AvahiStringList* avahi_string_list_new | ( | const char * | txt, |
... | |||
) |
Create a new string list by taking a variable list of NUL terminated strings. The strings are copied using g_strdup(). The argument list must be terminated by a NULL pointer.
AvahiStringList* avahi_string_list_new_from_array | ( | const char ** | array, |
int | length | ||
) |
Create a new string list from a string array. The strings are copied using g_strdup(). length should contain the length of the array, or -1 if the array is NULL terminated
Reverse the string list.
char* avahi_string_list_to_string | ( | AvahiStringList * | l | ) |
Convert the string list object to a single character string, seperated by spaces and enclosed in "". avahi_free() the result! This function doesn't work well with string that contain NUL bytes.