diff options
Diffstat (limited to 'swig')
-rw-r--r-- | swig/Makefile.am | 15 | ||||
-rw-r--r-- | swig/__init__.py | 1 | ||||
-rw-r--r-- | swig/plist.i | 171 |
3 files changed, 187 insertions, 0 deletions
diff --git a/swig/Makefile.am b/swig/Makefile.am new file mode 100644 index 0000000..2e5b280 --- /dev/null +++ b/swig/Makefile.am @@ -0,0 +1,15 @@ +INCLUDES = -I$(top_srcdir)/include + +BUILT_SOURCES = $(srcdir)/plist_wrap.c +SWIG_SOURCES = plist.i + +pkgpython_PYTHON = PList.py __init__.py +pkgpyexec_LTLIBRARIES = _PList.la +_PList_la_SOURCES = $(srcdir)/plist_wrap.c $(SWIG_SOURCES) +_PList_la_CFLAGS = $(PYTHON_CPPFLAGS) -I$(top_srcdir)/src +_PList_la_LDFLAGS = -module $(PYTHON_LDFLAGS) +_PList_la_LIBADD = ../src/libplist.la + +$(srcdir)/plist_wrap.c : $(SWIG_SOURCES) + $(SWIG) $(SWIG_PYTHON_OPT) $(INCLUDES) -I$(top_srcdir)/src -o $@ $< + diff --git a/swig/__init__.py b/swig/__init__.py new file mode 100644 index 0000000..8d1c8b6 --- /dev/null +++ b/swig/__init__.py @@ -0,0 +1 @@ + diff --git a/swig/plist.i b/swig/plist.i new file mode 100644 index 0000000..78f102f --- /dev/null +++ b/swig/plist.i @@ -0,0 +1,171 @@ + /* swig.i */ + %module PList + %{ + /* Includes the header in the wrapper code */ + #include <plist/plist.h> +typedef struct { + plist_t node; +} PListNode; + %} +/* Parse the header file to generate wrappers */ +typedef enum { + PLIST_BOOLEAN, + PLIST_UINT, + PLIST_REAL, + PLIST_STRING, + PLIST_UNICODE, + PLIST_ARRAY, + PLIST_DICT, + PLIST_DATE, + PLIST_DATA, + PLIST_KEY, + PLIST_NONE +} plist_type; + +typedef struct { + plist_t node; +} PListNode; + +%extend PListNode { // Attach these functions to struct Vector + PListNode(plist_type t) { + PListNode* node = NULL; + switch (t) { + case PLIST_ARRAY : + node = (PListNode*) malloc(sizeof(PListNode)); + node->node = plist_new_array(); + break; + case PLIST_DICT : + node = (PListNode*) malloc(sizeof(PListNode)); + node->node = plist_new_dict(); + break; + default : + node = NULL; + break; + } + return node; + } + + PListNode(char* xml) { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist_from_xml(xml, strlen(xml), &plist->node); + return plist; + } + + PListNode(char* bin, uint64_t len) { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist_from_bin(bin, len, &plist->node); + return plist; + } + + ~PListNode() { + plist_free($self->node); + free($self); + } + + void AddSubNode(PListNode* subnode) { + plist_add_sub_node($self->node, subnode); + } + + void AddSubKey(char* k) { + plist_add_sub_key_el($self->node, k); + } + + void AddSubString(char* s) { + plist_add_sub_string_el($self->node, s); + } + + void AddSubBool(char b) { + plist_add_sub_bool_el($self->node, b); + } + + void AddSubUInt(uint64_t i) { + plist_add_sub_uint_el($self->node, i); + } + + void AddSubReal(double d) { + plist_add_sub_real_el($self->node, d); + } + + void AddSubData(char* v, uint64_t l) { + plist_add_sub_data_el($self->node, v, l); + } + + PListNode* GetFirstChild() { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist_get_first_child(&$self->node); + return plist; + } + + PListNode* GetNextSibling() { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist_get_next_sibling(&$self->node); + return plist; + } + + PListNode* GetPrevSibling() { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist_get_prev_sibling(&$self->node); + return plist; + } + + char* AsKey() { + char* k = NULL; + plist_get_key_val($self->node, &k); + return k; + } + + char* AsString() { + char* s = NULL; + plist_get_string_val($self->node, &s); + return s; + } + + char AsBool() { + char b; + plist_get_bool_val($self->node, &b); + return b; + } + + uint64_t AsUInt() { + uint64_t i = 0; + plist_get_uint_val($self->node, &i); + return i; + } + + double AsReal() { + double d = 0; + plist_get_real_val($self->node, &d); + return d; + } + + char* AsData() { + char* v; + uint64_t l; + plist_get_data_val($self->node, &v, &l); + return v; + } + + plist_type GetType() { + return plist_get_node_type($self->node); + } + + PListNode* FindSubNodeByString(char* s) { + PListNode* plist = (PListNode*) malloc(sizeof(PListNode)); + plist = plist_find_node_by_string($self->node, s); + return plist; + } + + char* ToXml () { + char* s = NULL; + uint32_t l; + plist_to_xml($self->node, &s, &l); + return s; + } + + char* ToBin () { + char* s = NULL; + uint32_t l; + plist_to_bin($self->node, &s, &l); + return s; + } +};
\ No newline at end of file |