summaryrefslogtreecommitdiffstats
path: root/test/plist_test.c
blob: 069701e3609e14e26d2231f0acb86d844cdc031d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/*
 * backup_test.c
 * source libplist regression test
 *
 * Copyright (c) 2009 Jonathan Beck All Rights Reserved.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * 
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA 
 */


#include "plist/plist.h"

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>

#ifdef _MSC_VER
#pragma warning(disable:4996)
#endif


int main(int argc, char *argv[])
{
	FILE *iplist = NULL;
	FILE *oplist = NULL;
	plist_t root_node1 = NULL;
	plist_t root_node2 = NULL;
	char *plist_xml = NULL;
	char *plist_xml2 = NULL;
	char *plist_bin = NULL;
	int size_in = 0;
	int size_out = 0;
	int size_out2 = 0;
	char *file_in = NULL;
	struct stat *filestats = (struct stat *) malloc(sizeof(struct stat));
	if (argc!= 2) {
		printf("Wrong input\n");
		return 1;
	}

	file_in = argv[1];
	//read input file
	iplist = fopen(file_in, "rb");

	if (!iplist) {
		printf("File does not exists\n");
		return 2;
	}
	printf("File %s is open\n", file_in);
	stat(file_in, filestats);
	size_in = filestats->st_size;
	plist_xml = (char *) malloc(sizeof(char) * (size_in + 1));
	fread(plist_xml, sizeof(char), size_in, iplist);
	fclose(iplist);


	//convert one format to another
	plist_from_xml(plist_xml, size_in, &root_node1);
	if (!root_node1) {
		printf("PList XML parsing failed\n");
		return 3;
	}
	else
		printf("PList XML parsing succeeded\n");

	plist_to_bin(root_node1, &plist_bin, &size_out);
	if (!plist_bin) {
		printf("PList BIN writing failed\n");
		return 4;
	}
	else
		printf("PList BIN writing succeeded\n");

	plist_from_bin(plist_bin, size_out, &root_node2);
	if (!root_node2) {
		printf("PList BIN parsing failed\n");
		return 5;
	}
	else
		printf("PList BIN parsing succeeded\n");

	plist_to_xml(root_node2, &plist_xml2, &size_out2);
	if (!plist_xml2) {
		printf("PList XML writing failed\n");
		return 8;
	}
	else
		printf("PList XML writing succeeded\n");

	if (plist_xml2) {
		FILE *oplist = NULL;
		char file_out[512];
		sprintf(file_out, "%s.out", file_in);
		oplist = fopen(file_out, "wb");
		fwrite(plist_xml2, size_out2, sizeof(char), oplist);
		fclose(oplist);
	}

	plist_free(root_node1);
	plist_free(root_node2);
	free(plist_bin);
	free(plist_xml);
	free(plist_xml2);
	free(filestats);

	if (size_in != size_out2) {
		printf("Size of input and output is different\n");
		printf("Input size : %i\n", size_in);
		printf("Output size : %i\n", size_out2);
	}

	//success
	return 0;
}