diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2021-04-08 12:04:33 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2021-04-08 12:04:33 +0200 |
commit | a3739ada111bf4e36ae7576b24176d1db55e1365 (patch) | |
tree | a7c0eee1aacf91137c6f163a7dc301cf114125ff /extras | |
parent | 7c6c0c07dda1f44b930ee2dbb9451979b6a2cb83 (diff) |
Fix: libsquashfs: add sqfs_free() function
On systems like Windows, the dynamic library and applications can
easily end up being linked against different runtime libraries, so
applications cannot be expected to be able to free() any malloc'd
pointer that the library returns.
This commit adds an sqfs_free function so the application can pass
pointers back to the library to call the correct free() implementation.
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'extras')
-rw-r--r-- | extras/browse.c | 20 | ||||
-rw-r--r-- | extras/mk42sqfs.c | 2 | ||||
-rw-r--r-- | extras/mknastyfs.c | 2 |
3 files changed, 12 insertions, 12 deletions
diff --git a/extras/browse.c b/extras/browse.c index 86ce788..8b96c15 100644 --- a/extras/browse.c +++ b/extras/browse.c @@ -70,12 +70,12 @@ static void list_directory(const char *dirname) sqfs_dir_reader_get_root_inode(dr, &root); ret = sqfs_dir_reader_find_by_path(dr, root, dirname, &inode); - free(root); + sqfs_free(root); if (ret) goto fail_resolve; ret = sqfs_dir_reader_open_dir(dr, inode, 0); - free(inode); + sqfs_free(inode); if (ret) goto fail_open; } else { @@ -85,7 +85,7 @@ static void list_directory(const char *dirname) goto fail_resolve; ret = sqfs_dir_reader_open_dir(dr, inode, 0); - free(inode); + sqfs_free(inode); if (ret) goto fail_open; } @@ -102,7 +102,7 @@ static void list_directory(const char *dirname) } len = ent->size + 1; - free(ent); + sqfs_free(ent); } col_count = 79 / (max_len + 1); @@ -148,7 +148,7 @@ static void list_directory(const char *dirname) printf("%.*s", ent->size + 1, ent->name); fputs("\033[0m", stdout); - free(ent); + sqfs_free(ent); ++i; if (i == col_count) { @@ -231,7 +231,7 @@ static void stat_cmd(const char *filename) if (*filename == '/') { sqfs_dir_reader_get_root_inode(dr, &root); ret = sqfs_dir_reader_find_by_path(dr, root, filename, &inode); - free(root); + sqfs_free(root); if (ret) goto fail_resolve; } else { @@ -398,12 +398,12 @@ static void stat_cmd(const char *filename) printf("\tSize: %u\n", idx->size + 1); printf("\tEntry: %.*s\n\n", idx->size + 1, idx->name); - free(idx); + sqfs_free(idx); } break; } - free(inode); + sqfs_free(inode); return; fail_resolve: printf("Error resolving '%s', error code %d\n", filename, ret); @@ -429,7 +429,7 @@ static void cat_cmd(const char *filename) if (*filename == '/') { sqfs_dir_reader_get_root_inode(dr, &root); ret = sqfs_dir_reader_find_by_path(dr, root, filename, &inode); - free(root); + sqfs_free(root); } else { ret = sqfs_dir_reader_find_by_path(dr, working_dir, filename, &inode); @@ -459,7 +459,7 @@ static void cat_cmd(const char *filename) offset += diff; } - free(inode); + sqfs_free(inode); } /*****************************************************************************/ diff --git a/extras/mk42sqfs.c b/extras/mk42sqfs.c index 92323e0..08dffe6 100644 --- a/extras/mk42sqfs.c +++ b/extras/mk42sqfs.c @@ -167,7 +167,7 @@ int main(void) sqfs_meta_writer_get_position(inode_m, &block_start, &offset); super.root_inode_ref = (block_start << 16) | offset; sqfs_meta_writer_write_inode(inode_m, inode); - free(inode); + sqfs_free(inode); /* flush the meta data to the file */ sqfs_meta_writer_flush(inode_m); diff --git a/extras/mknastyfs.c b/extras/mknastyfs.c index daadf37..20074d3 100644 --- a/extras/mknastyfs.c +++ b/extras/mknastyfs.c @@ -146,7 +146,7 @@ int main(void) sqfs_meta_writer_get_position(inode_m, &block_start, &offset); super.root_inode_ref = (block_start << 16) | offset; sqfs_meta_writer_write_inode(inode_m, inode); - free(inode); + sqfs_free(inode); /* flush the meta data to the file */ sqfs_meta_writer_flush(inode_m); |