Classes | Typedefs
strlst.h File Reference
#include <sys/types.h>
#include <inttypes.h>
#include <stdarg.h>
#include <avahi-common/cdecl.h>
#include <avahi-common/gccmacro.h>
Include dependency graph for strlst.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  AvahiStringList

Typedefs

typedef AVAHI_C_DECL_BEGIN
struct AvahiStringList 
AvahiStringList

Functions

Construction and destruction
AvahiStringListavahi_string_list_new (const char *txt,...) AVAHI_GCC_SENTINEL
AvahiStringListavahi_string_list_new_from_array (const char **array, int length)
void avahi_string_list_free (AvahiStringList *l)
Adding strings
AvahiStringListavahi_string_list_add (AvahiStringList *l, const char *text)
AvahiStringListavahi_string_list_add_printf (AvahiStringList *l, const char *format,...) AVAHI_GCC_PRINTF_ATTR23
AvahiStringListavahi_string_list_add_arbitrary (AvahiStringList *l, const uint8_t *text, size_t size)
AvahiStringListavahi_string_list_add_anonymous (AvahiStringList *l, size_t size)
AvahiStringListavahi_string_list_add_many (AvahiStringList *r,...) AVAHI_GCC_SENTINEL
String list operations
char * avahi_string_list_to_string (AvahiStringList *l)
int avahi_string_list_equal (const AvahiStringList *a, const AvahiStringList *b)
AvahiStringListavahi_string_list_copy (const AvahiStringList *l)
AvahiStringListavahi_string_list_reverse (AvahiStringList *l)
unsigned avahi_string_list_length (const AvahiStringList *l)
Accessing items
AvahiStringListavahi_string_list_get_next (AvahiStringList *l)
uint8_t * avahi_string_list_get_text (AvahiStringList *l)
size_t avahi_string_list_get_size (AvahiStringList *l)
DNS-SD TXT pair handling
AvahiStringListavahi_string_list_find (AvahiStringList *l, const char *key)
int avahi_string_list_get_pair (AvahiStringList *l, char **key, char **value, size_t *size)
AvahiStringListavahi_string_list_add_pair (AvahiStringList *l, const char *key, const char *value)
AvahiStringListavahi_string_list_add_pair_arbitrary (AvahiStringList *l, const char *key, const uint8_t *value, size_t size)

Detailed Description

Implementation of a data type to store lists of strings

Definition in file strlst.h.


Typedef Documentation

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.


Function Documentation

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.

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.

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

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.

Returns the size of the current text

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.

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.



pedal_monitor
Author(s): Pedro Mendes
autogenerated on Fri Jun 6 2014 18:37:22