summaryrefslogtreecommitdiffstats
path: root/src/AFC.c
diff options
context:
space:
mode:
authorGravatar Matt Colyer2008-08-07 00:00:12 -0700
committerGravatar Matt Colyer2008-08-07 00:00:12 -0700
commit4c3f86499f8dfe344fb5f92b805e8c090290a79e (patch)
treebba8b935df1b5ef637065e789a66f7b9fd2888f4 /src/AFC.c
parent1c6aa3dd8aa8cd985a63ccbfa3848ebbe52715e1 (diff)
downloadlibplist-4c3f86499f8dfe344fb5f92b805e8c090290a79e.tar.gz
libplist-4c3f86499f8dfe344fb5f92b805e8c090290a79e.tar.bz2
Added cleanup when closing a file, probably needs a bit more throughness
but its a start. Added a missing unlock call so you can read a file more than once.
Diffstat (limited to 'src/AFC.c')
-rw-r--r--src/AFC.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/AFC.c b/src/AFC.c
index 680a08f..6fb5a9e 100644
--- a/src/AFC.c
+++ b/src/AFC.c
@@ -423,9 +423,11 @@ int afc_read_file(AFClient *client, AFCFile *file, char *data, int length) {
bytes = receive_AFC_data(client, &input);
if (bytes < 0) {
if (input) free(input);
+ afc_unlock(client);
return -1;
} else if (bytes == 0) {
if (input) free(input);
+ afc_unlock(client);
return current_count;
} else {
if (input) {
@@ -493,6 +495,4 @@ void afc_close_file(AFClient *client, AFCFile *file) {
bytes = receive_AFC_data(client, &buffer);
afc_unlock(client);
return;
- if (buffer) free(buffer); // we're *SUPPOSED* to get an "error" here.
}
-