summaryrefslogtreecommitdiffstats
path: root/dev
diff options
context:
space:
mode:
authorGravatar Jonathan Beck2008-12-10 23:42:21 +0100
committerGravatar Jonathan Beck2008-12-10 23:42:21 +0100
commitcd95e9bc6e23949b5cef3996132b79bd8803467a (patch)
treea435658908e506a5cb77a9bdabf8a158144ea6d8 /dev
parent625633203a27f569bea8890cb269132fea83b497 (diff)
downloadlibplist-cd95e9bc6e23949b5cef3996132b79bd8803467a.tar.gz
libplist-cd95e9bc6e23949b5cef3996132b79bd8803467a.tar.bz2
fix minor programming erro plus enhance plutil to convert bin to xml and xml to bin.
Diffstat (limited to 'dev')
-rw-r--r--dev/plutil.c29
1 files changed, 13 insertions, 16 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;
}