diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/bplist.c | 60 | ||||
| -rw-r--r-- | src/plist.c | 43 | ||||
| -rw-r--r-- | src/plist.h | 1 | ||||
| -rw-r--r-- | src/xplist.c | 27 | 
4 files changed, 44 insertions, 87 deletions
| diff --git a/src/bplist.c b/src/bplist.c index 2a82b9f..6b2d2f3 100644 --- a/src/bplist.c +++ b/src/bplist.c @@ -24,6 +24,8 @@  #include <stdio.h>  #include <string.h> +#include <libxml/tree.h> +  #include <plist/plist.h>  #include "plist.h" @@ -184,13 +186,28 @@ static plist_t parse_unicode_node(char *bnode, uint64_t size)  {  	plist_data_t data = plist_new_plist_data();  	uint64_t i = 0; -	data->type = PLIST_UNICODE; -	data->unicodeval = (gunichar2 *) malloc(sizeof(gunichar2) * (size + 1)); -	memcpy(data->unicodeval, bnode, sizeof(gunichar2) * size); -	data->unicodeval[sizeof(gunichar2) * size] = '\0'; -	data->length = size; -	for (i = 0; i <= size; i++) -		byte_convert((uint8_t*)(data->unicodeval + i), sizeof(gunichar2)); +	gunichar2 *unicodestr = NULL; +	gchar *tmpstr = NULL; +	int type = 0; +	glong items_read = 0; +	glong items_written = 0; +	GError *error = NULL; + +	data->type = PLIST_STRING; +	unicodestr = (gunichar2 *) malloc(sizeof(gunichar2) * size); +	memcpy(unicodestr, bnode, sizeof(gunichar2) * size); +	for (i = 0; i < size; i++) +		byte_convert((uint8_t*)(unicodestr + i), sizeof(gunichar2)); + +	tmpstr = g_utf16_to_utf8(unicodestr, size, &items_read, &items_written, &error); +	free(unicodestr); + +	data->type = PLIST_STRING; +	data->strval = (char *) malloc(sizeof(char) * (items_written + 1)); +	memcpy(data->strval, tmpstr, items_written); +	data->strval[items_written] = '\0'; +	data->length = strlen(data->strval); +	g_free(tmpstr);  	return g_node_new(data);  } @@ -364,10 +381,6 @@ static gpointer copy_plist_data(gconstpointer src, gpointer data)  	case PLIST_STRING:  		dstdata->strval = strdup(srcdata->strval);  		break; -	case PLIST_UNICODE: -		dstdata->unicodeval = (gunichar2 *) malloc(srcdata->length * sizeof(gunichar2)); -		memcpy(dstdata->unicodeval, srcdata->unicodeval, srcdata->length * sizeof(gunichar2)); -		break;  	case PLIST_DATA:  	case PLIST_ARRAY:  		dstdata->buff = (uint8_t *) malloc(sizeof(uint8_t *) * srcdata->length); @@ -520,10 +533,6 @@ static guint plist_data_hash(gconstpointer key)  		buff = data->strval;  		size = strlen(buff);  		break; -	case PLIST_UNICODE: -		buff = (char *) data->unicodeval; -		size = data->length; -		break;  	case PLIST_DATA:  	case PLIST_ARRAY:  	case PLIST_DICT: @@ -752,6 +761,13 @@ void plist_to_bin(plist_t plist, char **plist_bin, uint32_t * length)  	uint64_t *offsets = NULL;  	uint8_t pad[6] = { 0, 0, 0, 0, 0, 0 };  	uint8_t trailer[BPLIST_TRL_SIZE]; +	//for string +	glong len = 0; +	int type = 0; +	glong items_read = 0; +	glong items_written = 0; +	GError *error = NULL; +	gunichar2 *unicodestr = NULL;  	//check for valid input  	if (!plist || !plist_bin || *plist_bin || !length) @@ -806,10 +822,16 @@ void plist_to_bin(plist_t plist, char **plist_bin, uint32_t * length)  		case PLIST_KEY:  		case PLIST_STRING: -			write_string(bplist_buff, data->strval); -			break; -		case PLIST_UNICODE: -			write_unicode(bplist_buff, data->unicodeval, data->length); +			len = strlen(data->strval); +			type = xmlDetectCharEncoding(data->strval, len); +			if (XML_CHAR_ENCODING_UTF8 == type) { +				unicodestr = g_utf8_to_utf16(data->strval, len, &items_read, &items_written, &error); +				write_unicode(bplist_buff, unicodestr, items_written); +				g_free(unicodestr); +			} +			else if (XML_CHAR_ENCODING_ASCII == type || XML_CHAR_ENCODING_NONE == type) { +				write_string(bplist_buff, data->strval); +			}  			break;  		case PLIST_DATA:  			write_data(bplist_buff, data->buff, data->length); diff --git a/src/plist.c b/src/plist.c index 4fc2780..7949bce 100644 --- a/src/plist.c +++ b/src/plist.c @@ -53,9 +53,6 @@ static void plist_free_node(GNode * node, gpointer none)  		case PLIST_STRING:  			free(data->strval);  			break; -		case PLIST_UNICODE: -			free(data->unicodeval); -			break;  		case PLIST_DATA:  			free(data->buff);  			break; @@ -90,10 +87,6 @@ static plist_t plist_add_sub_element(plist_t node, plist_type type, const void *  		//only structured types are allowed to have nulll value  		if (value || (!value && (type == PLIST_DICT || type == PLIST_ARRAY))) { -			glong len = 0; -			glong items_read = 0; -			glong items_written = 0; -			GError *error = NULL;  			plist_t subnode = NULL;  			//now handle value @@ -115,11 +108,6 @@ static plist_t plist_add_sub_element(plist_t node, plist_type type, const void *  			case PLIST_STRING:  				data->strval = strdup((char *) value);  				break; -			case PLIST_UNICODE: -				len = strlen((char *) value); -				data->unicodeval = g_utf8_to_utf16((char *) value, len, &items_read, &items_written, &error); -				data->length = items_written; -				break;  			case PLIST_DATA:  				data->buff = (uint8_t*)malloc(length);  				memcpy(data->buff, value, length); @@ -210,9 +198,6 @@ static char compare_node_value(plist_type type, plist_data_t data, const void *v  	case PLIST_STRING:  		res = !strcmp(data->strval, ((char *) value));  		break; -	case PLIST_UNICODE: -		res = !memcpy(data->unicodeval, value, length); -		break;  	case PLIST_DATA:  		res = !memcmp(data->buff, (char *) value, length);  		break; @@ -262,11 +247,6 @@ plist_t plist_find_node_by_string(plist_t plist, const char *value)  static void plist_get_type_and_value(plist_t node, plist_type * type, void *value, uint64_t * length)  { -	//for unicode -	glong len = 0; -	glong items_read = 0; -	glong items_written = 0; -	GError *error = NULL;  	plist_data_t data = NULL;  	if (!node) @@ -291,10 +271,6 @@ static void plist_get_type_and_value(plist_t node, plist_type * type, void *valu  	case PLIST_STRING:  		*((char **) value) = strdup(data->strval);  		break; -	case PLIST_UNICODE: -		len = data->length; -		*((char **) value) = g_utf16_to_utf8(data->unicodeval, len, &items_read, &items_written, &error); -		break;  	case PLIST_DATA:  		*((uint8_t **) value) = (uint8_t *) malloc(*length * sizeof(uint8_t));  		memcpy(*((uint8_t **) value), data->buff, *length * sizeof(uint8_t)); @@ -360,11 +336,6 @@ void plist_add_sub_data_el(plist_t node, const char *val, uint64_t length)  	plist_add_sub_element(node, PLIST_DATA, val, length);  } -void plist_add_sub_unicode_el(plist_t node, const char *val) -{ -	plist_add_sub_element(node, PLIST_UNICODE, val, strlen(val)); -} -  void plist_add_sub_date_el(plist_t node, int32_t sec, int32_t usec)  {  	GTimeVal val = { sec, usec }; @@ -423,15 +394,6 @@ void plist_get_data_val(plist_t node, char **val, uint64_t * length)  		plist_get_type_and_value(node, &type, (void *) val, length);  } -void plist_get_unicode_val(plist_t node, char **val) -{ -	plist_type type = plist_get_node_type(node); -	uint64_t length = 0; -	if (PLIST_UNICODE == type) -		plist_get_type_and_value(node, &type, (void *) val, &length); -	assert(length == strlen(*val)); -} -  void plist_get_date_val(plist_t node, int32_t * sec, int32_t * usec)  {  	plist_type type = plist_get_node_type(node); @@ -476,11 +438,6 @@ gboolean plist_data_compare(gconstpointer a, gconstpointer b)  			return TRUE;  		else  			return FALSE; -	case PLIST_UNICODE: -		if (!memcmp(val_a->unicodeval, val_b->unicodeval, val_a->length)) -			return TRUE; -		else -			return FALSE;  	case PLIST_DATA:  		if (!memcmp(val_a->buff, val_b->buff, val_a->length)) diff --git a/src/plist.h b/src/plist.h index ebbb0b5..723ed87 100644 --- a/src/plist.h +++ b/src/plist.h @@ -36,7 +36,6 @@ struct plist_data_s {  		uint64_t intval;  		double realval;  		char *strval; -		gunichar2 *unicodeval;  		uint8_t *buff;  		GTimeVal timeval;  	}; diff --git a/src/xplist.c b/src/xplist.c index 2bee7c7..38cc4fe 100644 --- a/src/xplist.c +++ b/src/xplist.c @@ -126,12 +126,6 @@ static void node_to_xml(GNode * node, gpointer xml_struct)  	//for base64  	gchar *valtmp = NULL; -	//for unicode -	glong len = 0; -	glong items_read = 0; -	glong items_written = 0; -	GError *error = NULL; -  	uint32_t i = 0;  	if (!node) @@ -165,12 +159,6 @@ static void node_to_xml(GNode * node, gpointer xml_struct)  		val = g_strdup(node_data->strval);  		break; -	case PLIST_UNICODE: -		tag = XPLIST_STRING; -		len = node_data->length; -		val = g_utf16_to_utf8(node_data->unicodeval, len, &items_read, &items_written, &error); -		break; -  	case PLIST_KEY:  		tag = XPLIST_KEY;  		val = g_strdup((gchar *) node_data->strval); @@ -233,11 +221,7 @@ static void xml_to_node(xmlNodePtr xml_node, plist_t * plist_node)  	plist_t subnode = NULL;  	//for string -	unsigned char *tmp = NULL;  	glong len = 0; -	glong items_read = 0; -	glong items_written = 0; -	GError *error = NULL;  	int type = 0;  	if (!xml_node) @@ -301,16 +285,11 @@ static void xml_to_node(xmlNodePtr xml_node, plist_t * plist_node)  		if (!xmlStrcmp(node->name, XPLIST_STRING)) {  			xmlChar *strval = xmlNodeGetContent(node);  			len = strlen((char *) strval); -			items_read = 0; -			items_written = 0; -			error = NULL;  			type = xmlDetectCharEncoding(strval, len); -			if (XML_CHAR_ENCODING_UTF8 == type) { -				data->unicodeval = g_utf8_to_utf16((char *) strval, len, &items_read, &items_written, &error); -				data->type = PLIST_UNICODE; -				data->length = items_written; -			} else if (XML_CHAR_ENCODING_ASCII == type || XML_CHAR_ENCODING_NONE == type) { +			if (XML_CHAR_ENCODING_UTF8 == type || +				XML_CHAR_ENCODING_ASCII == type || +				XML_CHAR_ENCODING_NONE == type) {  				data->strval = strdup((char *) strval);  				data->type = PLIST_STRING;  				data->length = strlen(data->strval); | 
