summaryrefslogtreecommitdiffstats
path: root/avahi-compat-howl/text.c
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2005-10-13 02:34:19 +0000
committerLennart Poettering <lennart@poettering.net>2005-10-13 02:34:19 +0000
commit0433169ea9c6906f31b1a78e9a118858dd776dad (patch)
treeb45c627c8e2001f1ce5295a3312b3c06f97054cf /avahi-compat-howl/text.c
parent0e203251414d56b3f6b8d4dafde19a1d27b18caf (diff)
* implement HOWL TXT functions
* return SW_E_NO_IMPL instead of SW_DISCOVERY_E_NOT_SUPPORTED in unsupported HOWL functions git-svn-id: file:///home/lennart/svn/public/avahi/trunk@754 941a03a8-eaeb-0310-b9a0-b1bbd8fe43fe
Diffstat (limited to 'avahi-compat-howl/text.c')
-rw-r--r--avahi-compat-howl/text.c208
1 files changed, 164 insertions, 44 deletions
diff --git a/avahi-compat-howl/text.c b/avahi-compat-howl/text.c
index 1a3be6d..25428d8 100644
--- a/avahi-compat-howl/text.c
+++ b/avahi-compat-howl/text.c
@@ -23,35 +23,89 @@
#include <config.h>
#endif
+#include <assert.h>
+
#include <howl.h>
+#include <avahi-common/strlst.h>
+#include <avahi-common/malloc.h>
+#include <avahi-common/domain.h>
+
#include "warn.h"
-sw_result sw_text_record_init(
- sw_text_record * self) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+struct _sw_text_record {
+ AvahiStringList *strlst;
+ uint8_t *buffer;
+ size_t buffer_size;
+ int buffer_valid;
+};
+
+sw_result sw_text_record_init(sw_text_record *self) {
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (!(*self = avahi_new(struct _sw_text_record, 1))) {
+ *self = NULL;
+ return SW_E_UNKNOWN;
+ }
+
+ (*self)->strlst = NULL;
+ (*self)->buffer = NULL;
+ (*self)->buffer_size = 0;
+ (*self)->buffer_valid = 0;
+
+ return SW_OKAY;
}
-sw_result sw_text_record_fina(
- sw_text_record self) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+sw_result sw_text_record_fina(sw_text_record self) {
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ avahi_string_list_free(self->strlst);
+ avahi_free(self->buffer);
+ avahi_free(self);
+ return SW_OKAY;
}
sw_result sw_text_record_add_string(
sw_text_record self,
sw_const_string string) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+
+ AvahiStringList *n;
+
+ assert(self);
+ assert(string);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (!(n = avahi_string_list_add(self->strlst, string)))
+ return SW_E_UNKNOWN;
+
+ self->strlst = n;
+ self->buffer_valid = 0;
+ return SW_OKAY;
}
sw_result sw_text_record_add_key_and_string_value(
sw_text_record self,
sw_const_string key,
sw_const_string val) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+
+ AvahiStringList *n;
+
+ assert(self);
+ assert(key);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (!(n = avahi_string_list_add_pair(self->strlst, key, val)))
+ return SW_E_UNKNOWN;
+
+ self->strlst = n;
+ self->buffer_valid = 0;
+ return SW_OKAY;
}
sw_result sw_text_record_add_key_and_binary_value(
@@ -59,32 +113,95 @@ sw_result sw_text_record_add_key_and_binary_value(
sw_const_string key,
sw_octets val,
sw_uint32 len) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+
+ AvahiStringList *n;
+
+ assert(self);
+ assert(key);
+ assert(len || !val);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (!(n = avahi_string_list_add_pair_arbitrary(self->strlst, key, val, len)))
+ return SW_E_UNKNOWN;
+
+ self->strlst = n;
+ self->buffer_valid = 0;
+ return SW_OKAY;
+}
+
+static int rebuild(sw_text_record self) {
+ assert(self);
+
+ if (self->buffer_valid)
+ return 0;
+
+ self->buffer_size = avahi_string_list_serialize(self->strlst, NULL, 0);
+
+ if (!(self->buffer = avahi_realloc(self->buffer, self->buffer_size + 1)))
+ return -1;
+
+ avahi_string_list_serialize(self->strlst, self->buffer, self->buffer_size);
+ self->buffer_valid = 1;
+
+ return 0;
}
sw_octets sw_text_record_bytes(sw_text_record self) {
- AVAHI_WARN_UNSUPPORTED;
- return NULL;
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (rebuild(self) < 0)
+ return NULL;
+
+ return self->buffer;
}
sw_uint32 sw_text_record_len(sw_text_record self) {
- AVAHI_WARN_UNSUPPORTED;
- return 0;
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (rebuild(self) < 0)
+ return (uint32_t) -1;
+
+ return self->buffer_size;
}
+struct _sw_text_record_iterator {
+ AvahiStringList *strlst, *index;
+
+};
+
sw_result sw_text_record_iterator_init(
sw_text_record_iterator * self,
sw_octets text_record,
sw_uint32 text_record_len) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ if (!(*self = avahi_new(struct _sw_text_record_iterator, 1))) {
+ *self = NULL;
+ return SW_E_UNKNOWN;
+ }
+
+ (*self)->index = (*self)->strlst = avahi_string_list_reverse(avahi_string_list_parse(text_record, text_record_len));
+
+ return SW_OKAY;
}
-sw_result sw_text_record_iterator_fina(
- sw_text_record_iterator self) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+sw_result sw_text_record_iterator_fina(sw_text_record_iterator self) {
+ assert(self);
+
+ AVAHI_WARN_LINKAGE;
+
+ avahi_string_list_free(self->strlst);
+ avahi_free(self);
+
+ return SW_OKAY;
}
sw_result sw_text_record_iterator_next(
@@ -92,27 +209,30 @@ sw_result sw_text_record_iterator_next(
char key[255],
sw_uint8 val[255],
sw_uint32 * val_len) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
-}
-sw_result sw_text_record_string_iterator_init(
- sw_text_record_string_iterator * self,
- sw_const_string text_record_string) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
-}
+ char *mkey = NULL, *mvalue = NULL;
+ size_t msize = 0;
+
+ assert(self);
+ assert(key);
+
+ AVAHI_WARN_LINKAGE;
-sw_result sw_text_record_string_iterator_fina(
- sw_text_record_string_iterator self) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
-}
+ if (!self->index)
+ return SW_E_UNKNOWN;
-sw_result sw_text_record_string_iterator_next(
- sw_text_record_string_iterator self,
- char key[255],
- char val[255]) {
- AVAHI_WARN_UNSUPPORTED;
- return SW_DISCOVERY_E_NOT_SUPPORTED;
+ if (avahi_string_list_get_pair(self->index, &mkey, &mvalue, &msize) < 0)
+ return SW_E_UNKNOWN;
+
+ avahi_strlcpy(key, mkey, 255);
+ memcpy(val, mvalue, msize);
+ *val_len = msize;
+
+ avahi_free(mkey);
+ avahi_free(mvalue);
+
+ self->index = self->index->next;
+
+ return SW_OKAY;
}
+