summaryrefslogtreecommitdiff
path: root/lib/sqfs
diff options
context:
space:
mode:
authorDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2020-01-12 08:15:00 +0100
committerDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2020-01-12 08:15:48 +0100
commitc92faad51817c10570de3680e95a3fd18bb21204 (patch)
treedb42bdf6cc15ed89e2e25e4cc368acf51f785ca7 /lib/sqfs
parent525d582aea7d42231c8641b19f38881ee43133ea (diff)
Add an inode deep copy helper function to libsquashfs
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/sqfs')
-rw-r--r--lib/sqfs/inode.c49
1 files changed, 49 insertions, 0 deletions
diff --git a/lib/sqfs/inode.c b/lib/sqfs/inode.c
index 4a75e64..bb1ccef 100644
--- a/lib/sqfs/inode.c
+++ b/lib/sqfs/inode.c
@@ -10,6 +10,9 @@
#include "sqfs/inode.h"
#include "sqfs/error.h"
+#include <string.h>
+#include <stdlib.h>
+
static int inverse_type[] = {
[SQFS_INODE_DIR] = SQFS_INODE_EXT_DIR,
[SQFS_INODE_FILE] = SQFS_INODE_EXT_FILE,
@@ -27,6 +30,52 @@ static int inverse_type[] = {
[SQFS_INODE_EXT_SOCKET] = SQFS_INODE_SOCKET,
};
+int sqfs_inode_copy(const sqfs_inode_generic_t *src,
+ sqfs_inode_generic_t **out)
+{
+ sqfs_inode_generic_t *copy;
+ size_t size = sizeof(*src);
+
+ switch (src->base.type) {
+ case SQFS_INODE_FILE:
+ case SQFS_INODE_EXT_FILE:
+ size += src->num_file_blocks;
+ break;
+ case SQFS_INODE_DIR:
+ case SQFS_INODE_EXT_DIR:
+ size += src->num_dir_idx_bytes;
+ break;
+ case SQFS_INODE_SLINK:
+ size += src->data.slink.target_size;
+ break;
+ case SQFS_INODE_EXT_SLINK:
+ size += src->data.slink_ext.target_size;
+ break;
+ case SQFS_INODE_BDEV:
+ case SQFS_INODE_CDEV:
+ case SQFS_INODE_FIFO:
+ case SQFS_INODE_SOCKET:
+ case SQFS_INODE_EXT_BDEV:
+ case SQFS_INODE_EXT_CDEV:
+ case SQFS_INODE_EXT_FIFO:
+ case SQFS_INODE_EXT_SOCKET:
+ break;
+ default:
+ return SQFS_ERROR_CORRUPTED;
+ }
+
+ copy = calloc(1, size);
+ if (copy == NULL)
+ return SQFS_ERROR_ALLOC;
+
+ memcpy(copy, src, size);
+ copy->block_sizes = (sqfs_u32 *)copy->extra;
+ copy->slink_target = (char *)copy->extra;
+
+ *out = copy;
+ return 0;
+}
+
int sqfs_inode_get_xattr_index(const sqfs_inode_generic_t *inode,
sqfs_u32 *out)
{