aboutsummaryrefslogtreecommitdiff
path: root/archival/libarchive/data_extract_all.c
diff options
context:
space:
mode:
Diffstat (limited to 'archival/libarchive/data_extract_all.c')
-rw-r--r--archival/libarchive/data_extract_all.c16
1 files changed, 7 insertions, 9 deletions
diff --git a/archival/libarchive/data_extract_all.c b/archival/libarchive/data_extract_all.c
index 8fa69ffaf..4c95db4a6 100644
--- a/archival/libarchive/data_extract_all.c
+++ b/archival/libarchive/data_extract_all.c
@@ -122,13 +122,10 @@ void FAST_FUNC data_extract_all(archive_handle_t *archive_handle)
/* Handle hard links separately */
if (hard_link) {
- res = link(hard_link, dst_name);
- if (res != 0) {
- /* shared message */
- bb_perror_msg("can't create %slink '%s' to '%s'",
- "hard", dst_name, hard_link
- );
- }
+ create_or_remember_link(&archive_handle->link_placeholders,
+ hard_link,
+ dst_name,
+ 1);
/* Hardlinks have no separate mode/ownership, skip chown/chmod */
goto ret;
}
@@ -195,9 +192,10 @@ void FAST_FUNC data_extract_all(archive_handle_t *archive_handle)
*
* Untarring bug.tar would otherwise place evil.py in '/tmp'.
*/
- create_or_remember_symlink(&archive_handle->symlink_placeholders,
+ create_or_remember_link(&archive_handle->link_placeholders,
file_header->link_target,
- dst_name);
+ dst_name,
+ 0);
break;
case S_IFSOCK:
case S_IFBLK: