aboutsummaryrefslogtreecommitdiffstats
path: root/src/clone_fs.c
diff options
context:
space:
mode:
authorfishsoupisgood <github@madingley.org>2018-05-14 02:40:06 +0100
committerfishsoupisgood <github@madingley.org>2018-05-14 02:40:06 +0100
commitec9eb54d2f36f9c98607b5fc8745f978cfebd63e (patch)
treee8570d2f581d844ce24d02eb9d89bdd156d3cd2c /src/clone_fs.c
parentb8e2bb419265d10c11fc5840aabce81379bb242d (diff)
downloadext_clone-ec9eb54d2f36f9c98607b5fc8745f978cfebd63e.tar.gz
ext_clone-ec9eb54d2f36f9c98607b5fc8745f978cfebd63e.tar.bz2
ext_clone-ec9eb54d2f36f9c98607b5fc8745f978cfebd63e.zip
support non extents and fast symlinks
Diffstat (limited to 'src/clone_fs.c')
-rw-r--r--src/clone_fs.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/clone_fs.c b/src/clone_fs.c
index 1269b30..332a09b 100644
--- a/src/clone_fs.c
+++ b/src/clone_fs.c
@@ -13,6 +13,13 @@ int clone_fs (ext2_filsys src_fs, ext2_filsys dst_fs)
if (ret) return -1;
+#if 0
+ EXT2_MOAN_FAIL (ret, ext2fs_inode_scan_flags (scan, EXT2_SF_SKIP_MISSING_ITABLE, 0));
+
+ if (ret) return -1;
+
+#endif
+
for (;;) {
EXT2_MOAN_FAIL (ret, ext2fs_get_next_inode (scan, &i_num, &src_i));
@@ -36,16 +43,20 @@ int clone_fs (ext2_filsys src_fs, ext2_filsys dst_fs)
if (i_num == src_fs->super->s_journal_inum) skip = 1;
+ // if (ext2fs_test_inode_bitmap2(src_fs->inode_map,i_num)) skip=1;
+
if (skip) continue;
- if (clone_inode (src_fs, dst_fs, i_num, &src_i)) {
+ ret = clone_inode (src_fs, dst_fs, i_num, &src_i);
+
+ if (ret) {
fprintf (stderr, "clone_inode(%d) failed\n", (int) i_num);
break;
}
}
ext2fs_close_inode_scan (scan);
- return 0;
+ return ret;
}