diff options
| author | 2008-12-10 23:42:21 +0100 | |
|---|---|---|
| committer | 2008-12-10 23:42:21 +0100 | |
| commit | cd95e9bc6e23949b5cef3996132b79bd8803467a (patch) | |
| tree | a435658908e506a5cb77a9bdabf8a158144ea6d8 | |
| parent | 625633203a27f569bea8890cb269132fea83b497 (diff) | |
| download | libplist-cd95e9bc6e23949b5cef3996132b79bd8803467a.tar.gz libplist-cd95e9bc6e23949b5cef3996132b79bd8803467a.tar.bz2 | |
fix minor programming erro plus enhance plutil to convert bin to xml and xml to bin.
| -rw-r--r-- | dev/plutil.c | 29 | ||||
| -rw-r--r-- | src/plist.c | 8 | 
2 files changed, 17 insertions, 20 deletions
| diff --git a/dev/plutil.c b/dev/plutil.c index 4a34077..e76506e 100644 --- a/dev/plutil.c +++ b/dev/plutil.c @@ -18,8 +18,6 @@ int main(int argc, char *argv[])  	Options *options = parse_arguments(argc, argv);  	int argh = 0; -	printf("plistutil version 0.2 written by FxChiP\n"); -  	if (!options) {  		print_usage();  		return 0; @@ -31,26 +29,25 @@ int main(int argc, char *argv[])  	stat(options->in_file, filestats); -	printf("here?\n");  	char *bplist_entire = (char *) malloc(sizeof(char) * (filestats->st_size + 1)); -	//argh = fgets(bplist_entire, filestats->st_size, bplist);  	argh = fread(bplist_entire, sizeof(char), filestats->st_size, bplist); -	printf("read %i bytes\n", argh);  	fclose(bplist); -	printf("or here?\n");  	// bplist_entire contains our stuff +  	plist_t root_node = NULL; -	bin_to_plist(bplist_entire, filestats->st_size, &root_node); -	printf("plutil debug mode\n\n"); -	printf("file size %i\n\n", (int) filestats->st_size); -	if (!root_node) { -		printf("Invalid binary plist (or some other error occurred.)\n"); -		return 0; -	} -	char *plist_xml = NULL; +	char *plist_out = NULL;  	int size = 0; -	plist_to_xml(root_node, &plist_xml, &size); -	printf("%s\n", plist_xml); + +	if (memcmp(bplist_entire, "bplist00", 8) == 0) { +		bin_to_plist(bplist_entire, filestats->st_size, &root_node); +		plist_to_xml(root_node, &plist_out, &size); +	} else { +		xml_to_plist(bplist_entire, filestats->st_size, &root_node); +		plist_to_bin(root_node, &plist_out, &size); +	} + + +	printf("%s\n", plist_out);  	return 0;  } diff --git a/src/plist.c b/src/plist.c index 431c64a..2a6d4bc 100644 --- a/src/plist.c +++ b/src/plist.c @@ -1014,16 +1014,16 @@ guint plist_data_hash(gconstpointer key)  	case PLIST_REAL:  		buff = (char *) &data->intval;  		size = 8; - +		break;  	case PLIST_KEY:  	case PLIST_STRING:  		buff = data->strval;  		size = strlen(buff); - +		break;  	case PLIST_UNICODE:  		buff = data->unicodeval;  		size = strlen(buff) * sizeof(wchar_t); - +		break;  	case PLIST_DATA:  	case PLIST_ARRAY:  	case PLIST_DICT: @@ -1267,7 +1267,7 @@ void plist_to_bin(plist_t plist, char **plist_bin, uint32_t * length)  	uint8_t *buff = NULL;  	uint8_t size = 0;  	uint64_t offsets[num_objects]; -	for (i = 0; i <= num_objects; i++) { +	for (i = 0; i < num_objects; i++) {  		offsets[i] = bplist_buff->len;  		struct plist_data *data = (struct plist_data *) ((GNode *) g_ptr_array_index(objects, i))->data; | 
