]> git.ipfire.org Git - thirdparty/libarchive.git/log
thirdparty/libarchive.git
2 years agotar: demote -xa from error to a warning 1626/head
Emil Velikov [Sun, 21 Nov 2021 18:05:19 +0000 (18:05 +0000)] 
tar: demote -xa from error to a warning

It's fairly common for people to use caf and xaf on Linux. The former in
itself being GNU tar specific - libarchive tar does not allow xa.

While it makes little sense to use xaf with libarchive tar, that is
implementation detail which gets in the way when trying to write trivial
tooling/scripts.

For the sake of compatibility, reduce the error to a warning and augment
the message itself. Making it clear that the option makes little sense.

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
2 years agoMerge pull request #1614 from diabonas/add-no-read-sparse
Martin Matuška [Sun, 21 Nov 2021 10:32:19 +0000 (11:32 +0100)] 
Merge pull request #1614 from diabonas/add-no-read-sparse

Add ARCHIVE_READDISK_NO_SPARSE/--no-read-sparse to improve reproducibility of generated archives

2 years agotest_sparse_basic: test ARCHIVE_READDISK_NO_SPARSE 1614/head
Jonas Witschel [Sat, 20 Nov 2021 10:37:50 +0000 (11:37 +0100)] 
test_sparse_basic: test ARCHIVE_READDISK_NO_SPARSE

2 years agotest_sparse_basic: do not assume that holes can be read in one go
Jonas Witschel [Sun, 21 Nov 2021 09:07:52 +0000 (10:07 +0100)] 
test_sparse_basic: do not assume that holes can be read in one go

verify_sparse_file() assumes that every hole will be fully contained in only
one archive_read_data_block(). This is a reasonable assumption if the file is
indeed sparsely encoded in the archive because archive_read_data_block() will
just skip the hole and return the offset of the next data block.

However, if the file is not sparsely encoded in the archive, a hole consists of
a lot of zeroes that need to be read byte by byte. In this case, the archive
contains no information on where this block of zeroes ends and where actual
data begins. Therefore it can happen that a single archive_read_data_block()
contains both zeroes from a hole and actual data.

If this happens, assert(sparse->type == HOLE) fails. This assertion is
reasonable for sparsely encoded files because archive_read_data_block() will
never only read part of a hole (since it does not really "read" a hole at all,
it just returns a higher offset accounting for the size of the hole).

However, we want to start testing files with verify_sparse_file() that are
explicitly not sparsely encoded. In this case, the assertion does not
necessarily hold any more. Therefore we need to account for the case where the
overlapping block consists of data. To make sure the file contents are
correctly encoded in the archive, we need to test the contents of the data
block, like it is already done for blocks completely contained in the data read
by archive_read_data_block().

Note that this modification does not change the way sparsely encoded files are
verified, it just relaxes an edge case that cannot happen with sparsely encoded
files to make it possible to test any kind of file, whether sparsely encoded or
not.

2 years agoMerge pull request #1621 from botovq/openssl_compat
Martin Matuška [Sat, 20 Nov 2021 23:19:57 +0000 (00:19 +0100)] 
Merge pull request #1621 from botovq/openssl_compat

Remove unnecessary OpenSSL compat ifdef.

2 years agoMerge pull request #1623 from DHowett/dev/duhowett/calling_convention
Martin Matuška [Sat, 20 Nov 2021 23:19:02 +0000 (00:19 +0100)] 
Merge pull request #1623 from DHowett/dev/duhowett/calling_convention

win32: specify the calling convention for functions that interact with libc

2 years agoMerge pull request #1622 from DHowett/dev/duhowett/user32
Martin Matuška [Sat, 20 Nov 2021 23:18:45 +0000 (00:18 +0100)] 
Merge pull request #1622 from DHowett/dev/duhowett/user32

win32: remove the hard dependency on user32.dll

2 years agoMerge pull request #1620 from rlibby/tar-cru-ignore-zeros
Martin Matuška [Sat, 20 Nov 2021 23:17:33 +0000 (00:17 +0100)] 
Merge pull request #1620 from rlibby/tar-cru-ignore-zeros

tar: respect --ignore-zeros in c r & u modes when reading archives

2 years agoRemove dependency on user32 1622/head
Dustin Howett [Wed, 13 Oct 2021 21:36:05 +0000 (14:36 -0700)] 
Remove dependency on user32

2 years agofix: include archive_platform in ...cpio to ensure calling convention 1623/head
Dustin Howett [Wed, 13 Oct 2021 21:35:40 +0000 (14:35 -0700)] 
fix: include archive_platform in ...cpio to ensure calling convention

2 years agowindows: make sure we use the right calling convention for libc
Dustin Howett [Wed, 13 Oct 2021 21:16:49 +0000 (14:16 -0700)] 
windows: make sure we use the right calling convention for libc

2 years agoRemove OpenSSL compat code that misuses the API 1621/head
Theo Buehler [Fri, 19 Nov 2021 17:55:29 +0000 (18:55 +0100)] 
Remove OpenSSL compat code that misuses the API

Immediately after EVP_CIPHER_CTX_new() neither EVP_CIPHER_CTX_init()
nor EVP_CIHPER_CTX_reset() should be called: the purpose of the init
function is to initialize a context on the stack while reset clears
a used context for reuse. Neither situation is the case here.

Removing the code also fixes a potential NULL dereference because an
error of reset is not signaled to the caller. Fortunately reset doesn't
currently fail in this situation in current OpenSSL and LibreSSL.

2 years agotar/test/test_option_ignore_zeros.c: test tar --ignore-zeros 1620/head
Ryan Libby [Fri, 19 Nov 2021 09:24:59 +0000 (01:24 -0800)] 
tar/test/test_option_ignore_zeros.c: test tar --ignore-zeros

Add some basic tests for operations on concatenated archives.

2 years agotar: respect --ignore-zeros in c r & u modes when reading archives
Ryan Libby [Fri, 19 Nov 2021 09:09:35 +0000 (01:09 -0800)] 
tar: respect --ignore-zeros in c r & u modes when reading archives

Previously, --ignore-zeros was only being applied to t and x modes.

2 years agoarchive_write_disk_posix: fix writing fflags broken in 8a1bd5c
Martin Matuska [Wed, 17 Nov 2021 20:06:00 +0000 (21:06 +0100)] 
archive_write_disk_posix: fix writing fflags broken in 8a1bd5c

The fixup list was erroneously assumed to be directories only.
Only in the case of critical file flags modification (e.g. SF_IMMUTABLE
on BSD systems), other file types (e.g. regular files or symbolic links)
may be added to the fixup list. We still need to verify that we are writing
to the correct file type, so compare the archive entry file type with
the file type of the file to be modified.

Fixes #1617

2 years agoMerge pull request #1588 from IohannRabeson/build_fixes
Martin Matuška [Tue, 16 Nov 2021 00:09:43 +0000 (01:09 +0100)] 
Merge pull request #1588 from IohannRabeson/build_fixes

Windows build fix

2 years agoMerge pull request #1591 from JiaT75/Added_documentation_for_exported_functions_in_ar...
Martin Matuška [Tue, 16 Nov 2021 00:01:17 +0000 (01:01 +0100)] 
Merge pull request #1591 from JiaT75/Added_documentation_for_exported_functions_in_archive_read_disk

Added documentation for exported functions in archive_read_disk

2 years agoMerge pull request #1598 from JiaT75/zip_entry_size_unset_store_fix_1547
Martin Matuška [Mon, 15 Nov 2021 23:59:49 +0000 (00:59 +0100)] 
Merge pull request #1598 from JiaT75/zip_entry_size_unset_store_fix_1547

Zip entry size unset now honors user requested compression level

2 years agoMerge pull request #1601 from evelikov/rm-fallthrough
Martin Matuška [Mon, 15 Nov 2021 23:54:51 +0000 (00:54 +0100)] 
Merge pull request #1601 from evelikov/rm-fallthrough

mtree reader: return early, remove fallthrough chain

2 years agoMerge pull request #1606 from JiaT75/clean_up_archive_read_disk_descend_functions
Martin Matuška [Mon, 15 Nov 2021 23:46:53 +0000 (00:46 +0100)] 
Merge pull request #1606 from JiaT75/clean_up_archive_read_disk_descend_functions

Cleaned up archive_read_disk_descend functions

2 years agoMerge pull request #1609 from JiaT75/added_error_message_to_warning_bsdtar_1561
Martin Matuška [Mon, 15 Nov 2021 23:45:36 +0000 (00:45 +0100)] 
Merge pull request #1609 from JiaT75/added_error_message_to_warning_bsdtar_1561

Added error text to warning when untaring with bsdtar

2 years agotar: expose ARCHIVE_READDISK_NO_SPARSE as --no-read-sparse
Jonas Witschel [Sun, 14 Nov 2021 17:56:49 +0000 (18:56 +0100)] 
tar: expose ARCHIVE_READDISK_NO_SPARSE as --no-read-sparse

2 years agoAdd ARCHIVE_READDISK_NO_SPARSE to suppress reading sparse file info
Jonas Witschel [Sun, 14 Nov 2021 17:56:49 +0000 (18:56 +0100)] 
Add ARCHIVE_READDISK_NO_SPARSE to suppress reading sparse file info

Sparse file information depends on the file system and can therefore be a
source of unreproducibility for the generated archives, e.g. if the same
content is compressed on a file system with and without sparse file support.
Add an option to suppress reading this information from disk entirely.

2 years agoAdded error message when archive extraction fails 1609/head
jiat75 [Sat, 30 Oct 2021 03:47:15 +0000 (11:47 +0800)] 
Added error message when archive extraction fails

2 years agoCleaned up archive_read_disk_descend functions. 1606/head
jiat75 [Wed, 27 Oct 2021 14:05:43 +0000 (22:05 +0800)] 
Cleaned up archive_read_disk_descend functions.

2 years agoFixing typo in archive_read_disk man page 1591/head
jiat75 [Wed, 27 Oct 2021 13:56:58 +0000 (21:56 +0800)] 
Fixing typo in archive_read_disk man page

2 years agoUsing the new .editorconfig to fix formatting on size unset store test 1598/head
jiat75 [Wed, 27 Oct 2021 12:43:48 +0000 (20:43 +0800)] 
Using the new .editorconfig to fix formatting on size unset store test

2 years agoReusing code from zip size known and adjusting comments
jiat75 [Wed, 27 Oct 2021 12:28:20 +0000 (20:28 +0800)] 
Reusing code from zip size known and adjusting comments

2 years agoMerge pull request #1602 from evelikov/editorconfig
Martin Matuška [Tue, 26 Oct 2021 12:22:23 +0000 (14:22 +0200)] 
Merge pull request #1602 from evelikov/editorconfig

editorconfig: add simple top-level file

2 years agoMerge pull request #1589 from JiaT75/added-missing-checks-for-canLzip-canLzma-and...
Martin Matuška [Tue, 26 Oct 2021 12:21:51 +0000 (14:21 +0200)] 
Merge pull request #1589 from JiaT75/added-missing-checks-for-canLzip-canLzma-and-canXz

added missing checks for canLzip, canLzma, and canXz

2 years agoMerge pull request #1590 from jsonn/master
Martin Matuška [Tue, 26 Oct 2021 12:03:10 +0000 (14:03 +0200)] 
Merge pull request #1590 from jsonn/master

Support ARCHIVE_EXTRACT_SECURE_NODOTDOT on Windows

2 years agoMerge pull request #1593 from JiaT75/added_bin_to_gitignore
Martin Matuška [Tue, 26 Oct 2021 11:51:25 +0000 (13:51 +0200)] 
Merge pull request #1593 from JiaT75/added_bin_to_gitignore

Added bin folder to .gitignore

2 years agoMerge pull request #1604 from AdamKorcz/fuzz1
Martin Matuška [Tue, 26 Oct 2021 11:24:03 +0000 (13:24 +0200)] 
Merge pull request #1604 from AdamKorcz/fuzz1

Add CIFuzz

2 years agoAdd CIFuzz 1604/head
AdamKorcz [Tue, 26 Oct 2021 10:10:08 +0000 (11:10 +0100)] 
Add CIFuzz

2 years agoeditorconfig: add simple top-level file 1602/head
Emil Velikov [Sat, 23 Oct 2021 14:32:12 +0000 (15:32 +0100)] 
editorconfig: add simple top-level file

Add a simple top-level .editorconfig file to manage common attributes
such as indentation style, trailing whitespace and newline at end of
file. The format is wide spread and has support for nearly every editor
out there - see https://editorconfig.org/ for more.

Majority of the project is C - which uses tabs, although there are some
CMake files using 2 space indent and shell scripts - predominantly using
4 space indent.

This makes it harder for casual contributors to butcher things :-)

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
2 years agomtree reader: return early, remove fallthrough chain 1601/head
Emil Velikov [Sat, 23 Oct 2021 13:42:55 +0000 (14:42 +0100)] 
mtree reader: return early, remove fallthrough chain

Remove the excessive fallthrough chain in parse_keyword(). Even though
it is in the else/error path, there is no point in comparing the key
another dozen (or more) times when we know it will fail.

Just use an early return (OK) or break respectively.

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
2 years agoAdding test to Makefile.am
jiat75 [Tue, 19 Oct 2021 14:56:50 +0000 (22:56 +0800)] 
Adding test to Makefile.am

2 years agoAdded copyright to new test file.
jiat75 [Tue, 19 Oct 2021 14:33:10 +0000 (22:33 +0800)] 
Added copyright to new test file.

2 years agoAdded new test to cmake lists
jiat75 [Tue, 19 Oct 2021 13:45:58 +0000 (21:45 +0800)] 
Added new test to cmake lists

2 years agoAdded assertions for folder
jiat75 [Sun, 17 Oct 2021 02:37:22 +0000 (10:37 +0800)] 
Added assertions for folder

2 years agoAdded test for writing an zip file without entry size and no compression
jiat75 [Sun, 17 Oct 2021 01:52:13 +0000 (09:52 +0800)] 
Added test for writing an zip file without entry size and no compression

2 years agoOnly use deflate when size is not set if the user did not specify a compression algorithm
jiat75 [Sat, 16 Oct 2021 07:33:25 +0000 (15:33 +0800)] 
Only use deflate when size is not set if the user did not specify a compression algorithm

2 years agoAdded bin folder to .gitignore 1593/head
jiat75 [Sat, 9 Oct 2021 05:58:44 +0000 (13:58 +0800)] 
Added bin folder to .gitignore

2 years agoRemoved unused function. 1589/head
jiat75 [Thu, 7 Oct 2021 14:43:08 +0000 (22:43 +0800)] 
Removed unused function.

2 years agoAdded all exported but undocumented functions to man pages
jiat75 [Wed, 6 Oct 2021 10:58:44 +0000 (18:58 +0800)] 
Added all exported but undocumented functions to man pages

2 years agoSupport ARCHIVE_EXTRACT_SECURE_NODOTDOT on Windows 1590/head
Joerg Sonnenberger [Wed, 6 Oct 2021 22:24:30 +0000 (00:24 +0200)] 
Support ARCHIVE_EXTRACT_SECURE_NODOTDOT on Windows

2 years agoadded missing checks for canLzip, canLzma, and canXz
jiat75 [Sun, 3 Oct 2021 07:23:28 +0000 (15:23 +0800)] 
added missing checks for canLzip, canLzma, and canXz

2 years agoMake all the implicit cast explicit. 1588/head
IohannRabeson [Sun, 3 Oct 2021 06:07:37 +0000 (02:07 -0400)] 
Make all the implicit cast explicit.

To prevent conversion warning preventing to build on Windows.

2 years agoMerge pull request #1575 from Hello71/patch-1
Martin Matuška [Thu, 30 Sep 2021 13:41:29 +0000 (15:41 +0200)] 
Merge pull request #1575 from Hello71/patch-1

libarchive.3: update archive format list

2 years agoMerge pull request #1567 from russelltg/russell_zstd_threads
Martin Matuška [Thu, 30 Sep 2021 11:20:05 +0000 (13:20 +0200)] 
Merge pull request #1567 from russelltg/russell_zstd_threads

zstd filter writer: add threads option

2 years agoMerge pull request #1569 from ferivoz/dir
Martin Matuška [Thu, 30 Sep 2021 11:17:34 +0000 (13:17 +0200)] 
Merge pull request #1569 from ferivoz/dir

Ignore size of directories with regular type

2 years agolibarchive.3: update archive format list 1575/head
Alex Xu [Fri, 17 Sep 2021 02:33:55 +0000 (02:33 +0000)] 
libarchive.3: update archive format list

Add 7-Zip and WARC to read formats, add many compressors, sort lists in approximate lexicographical order.

2 years agoAdded test case for ustar directory handling 1569/head
Samanta Navarro [Sun, 29 Aug 2021 11:59:29 +0000 (11:59 +0000)] 
Added test case for ustar directory handling

Based on test_compat_tar_hardlink.c and with input by Tim Kientzle.

2 years agoMerge pull request #1570 from ferivoz/mac
Martin Matuška [Sat, 4 Sep 2021 22:28:16 +0000 (00:28 +0200)] 
Merge pull request #1570 from ferivoz/mac

Fix size_t cast in read_mac_metadata_blob

2 years agoIgnore size of directories with regular type
Samanta Navarro [Sat, 28 Aug 2021 11:53:24 +0000 (11:53 +0000)] 
Ignore size of directories with regular type

In old tar formats directories are specified by appending a slash to
their names.

Directories may have sizes, but they do not have data blocks. Keep this
in mind and avoid skipping data blocks when encountering directories.

2 years agoFix size_t cast in read_mac_metadata_blob 1570/head
Samanta Navarro [Sat, 28 Aug 2021 11:58:00 +0000 (11:58 +0000)] 
Fix size_t cast in read_mac_metadata_blob

The size_t data type on 32 bit systems is smaller than int64_t. Check
the int64_t value before casting to size_t. If the value is too large
then stop operation instead of continuing operation with truncated
value.

2 years agoarchive_write_set_format_cpio_binary: fix compilation on OpenBSD
Martin Matuska [Fri, 27 Aug 2021 16:04:59 +0000 (18:04 +0200)] 
archive_write_set_format_cpio_binary: fix compilation on OpenBSD

Rename swap16 and swap32 to la_swap16 and la_swap32.

2 years agoFix following symlinks when processing the fixup list
Martin Matuska [Fri, 27 Aug 2021 08:56:28 +0000 (10:56 +0200)] 
Fix following symlinks when processing the fixup list

The previous fix in b41daecb5 was incomplete. Fixup entries are
given the original path without calling cleanup_pathname().
To make sure we don't follow a symlink, we must strip trailing
slashes from the path.

The fixup entries are always directories. Make sure we try to modify
only directories by providing O_DIRECTORY to open() (if supported)
and if it fails to check directory via lstat().

Fixes #1566

2 years agofix --threads commandline 1567/head
Russell Greene [Wed, 25 Aug 2021 17:26:48 +0000 (13:26 -0400)] 
fix --threads commandline

2 years agozstd filter writer: add threads option
Russell Greene [Wed, 25 Aug 2021 16:09:19 +0000 (12:09 -0400)] 
zstd filter writer: add threads option

2 years agoCI: provide a more complete Ubuntu package list
Martin Matuska [Sun, 22 Aug 2021 23:06:27 +0000 (01:06 +0200)] 
CI: provide a more complete Ubuntu package list

2 years agoLibarchive 3.5.3dev
Martin Matuska [Sun, 22 Aug 2021 22:50:26 +0000 (00:50 +0200)] 
Libarchive 3.5.3dev

2 years agoRelease 3.5.2 v3.5.2
Martin Matuska [Sun, 22 Aug 2021 15:33:36 +0000 (17:33 +0200)] 
Release 3.5.2

2 years agoSkip archive_write_disk_fixup test on Windows
Martin Matuska [Sun, 22 Aug 2021 13:53:31 +0000 (15:53 +0200)] 
Skip archive_write_disk_fixup test on Windows

2 years agoDo not follow symlinks when processing the fixup list
Martin Matuska [Thu, 19 Aug 2021 23:50:27 +0000 (01:50 +0200)] 
Do not follow symlinks when processing the fixup list

Use lchmod() instead of chmod() and tell the remaining functions that the
real file to be modified is a symbolic link.

Fixes #1566

2 years agoNever follow symlinks when setting file flags on Linux
Martin Matuska [Sun, 22 Aug 2021 01:53:28 +0000 (03:53 +0200)] 
Never follow symlinks when setting file flags on Linux

When opening a file descriptor to set file flags on linux, ensure
no symbolic links are followed. This fixes the case when an archive
contains a directory entry followed by a symlink entry with the same
path. The fixup code would modify file flags of the symlink target.

2 years agoFix handling of symbolic link ACLs
Martin Matuska [Sat, 21 Aug 2021 18:51:07 +0000 (20:51 +0200)] 
Fix handling of symbolic link ACLs

On Linux ACLs on symbolic links are not supported.
We must avoid calling acl_set_file() on symbolic links as their
targets are modified instead.

While here, do not try to set default ACLs on non-directories.

Fixes #1565

2 years agowrite_disk_posix: rename variable in check_symlinks_fsobj()
Martin Matuska [Sat, 21 Aug 2021 07:07:54 +0000 (09:07 +0200)] 
write_disk_posix: rename variable in check_symlinks_fsobj()

Rename the flag "extracting_hardlink" to "checking_linkname" to
be more accurate about its use. If the variable is non-zero it
means that check_symlinks_fsobj() is called on the linkname
when a hardlink is going to be created.

2 years agoFix extracting hardlinks to symlinks
Martin Matuska [Fri, 20 Aug 2021 23:39:31 +0000 (01:39 +0200)] 
Fix extracting hardlinks to symlinks

On platforms that support the linkat(2) function we can safely
write hardlinks to symlinks as linkat(2) does not follow symlinks
by default.

Fixes #1044

2 years agoAdd ability to skip atime test in directory traversals
Martin Matuska [Fri, 20 Aug 2021 09:58:41 +0000 (11:58 +0200)] 
Add ability to skip atime test in directory traversals

2 years agoCI: Add FreeBSD 13.0 to Cirrus CI build
Martin Matuska [Wed, 12 May 2021 07:52:44 +0000 (09:52 +0200)] 
CI: Add FreeBSD 13.0 to Cirrus CI build

2 years agoMerge pull request #1542 from ferivoz/intmax
Martin Matuška [Sat, 17 Jul 2021 22:49:43 +0000 (00:49 +0200)] 
Merge pull request #1542 from ferivoz/intmax

Handle all negative int64_t values in mtree/tar

2 years agoMerge pull request #1552 from AndyBrown91/windows-long-path-fix
Martin Matuška [Sat, 17 Jul 2021 22:35:03 +0000 (00:35 +0200)] 
Merge pull request #1552 from AndyBrown91/windows-long-path-fix

Windows: Use full path including prefix when looking up file handle

2 years agoWindows: Use full path including prefix when looking up file handle 1552/head
Andy Brown [Tue, 13 Jul 2021 12:05:19 +0000 (13:05 +0100)] 
Windows: Use full path including prefix when looking up file handle

2 years agoMerge pull request #1540 from ferivoz/typos
Martin Matuška [Wed, 30 Jun 2021 08:24:56 +0000 (10:24 +0200)] 
Merge pull request #1540 from ferivoz/typos

Fix typos

2 years agoMerge pull request #1541 from ferivoz/mutual
Martin Matuška [Wed, 30 Jun 2021 08:23:23 +0000 (10:23 +0200)] 
Merge pull request #1541 from ferivoz/mutual

Fix mutual check in tar sparse handling

2 years agoFix mutual check in tar sparse handling 1541/head
Samanta Navarro [Tue, 1 Jun 2021 11:26:30 +0000 (11:26 +0000)] 
Fix mutual check in tar sparse handling

GNU.sparse.numbytes and GNU.sparse.offset both have to be set before
gnu_add_sparse_entry can be called.

The GNU.sparse.numbytes parser checks for tar->sparse_numbytes.
This has to be tar->sparse_offset instead to work just like the
GNU.sparse.offset parser.

2 years agoFix typos 1540/head
Samanta Navarro [Tue, 1 Jun 2021 11:26:02 +0000 (11:26 +0000)] 
Fix typos

Typos found with codespell

2 years agoHandle all negative int64_t values in mtree/tar 1542/head
Samanta Navarro [Tue, 1 Jun 2021 11:25:03 +0000 (11:25 +0000)] 
Handle all negative int64_t values in mtree/tar

The variable last_digit_limit is negative since INT64_MIN itself is
negative as well. This means that the last digit after "limit" always
leads to maxval.

Turning last_digit_limit positive in itself is not sufficient because
it would lead to a signed integer overflow during shift operation.

If limit is reached and the last digit is last_digit_limit, the number
is at least maxval. The already existing if condition for even larger
(or smaller) values can be reused to prevent the last shift.

In my humble opinion it might make sense to reduce duplicated code and
keep it separated in a utility source file for shared use.

2 years agoRestore comment formatting
Joerg Sonnenberger [Sun, 30 May 2021 21:01:12 +0000 (23:01 +0200)] 
Restore comment formatting

2 years agoMerge pull request #1532 from Gei0r/master
Martin Matuška [Thu, 27 May 2021 09:33:19 +0000 (11:33 +0200)] 
Merge pull request #1532 from Gei0r/master

7zip: Use compression settings from file also for file header

2 years agoMerge pull request #1530 from owtaylor/close-short-writes
Martin Matuška [Thu, 27 May 2021 09:32:21 +0000 (11:32 +0200)] 
Merge pull request #1530 from owtaylor/close-short-writes

On close, handle short writes from archive_write_callback

2 years agoMerge pull request #1529 from owtaylor/getcwd
Martin Matuška [Thu, 27 May 2021 09:32:02 +0000 (11:32 +0200)] 
Merge pull request #1529 from owtaylor/getcwd

Avoid getcwd(0, PATH_MAX) for GNU libc

2 years agoMerge pull request #1509 from mariXanna/fix/#1508
Martin Matuška [Thu, 27 May 2021 07:11:12 +0000 (09:11 +0200)] 
Merge pull request #1509 from mariXanna/fix/#1508

Added support of deflate algorithm in symbolic link decompression for zip archives

2 years agoUse tabs for indentation 1532/head
Adrian Ebeling [Wed, 19 May 2021 06:52:27 +0000 (08:52 +0200)] 
Use tabs for indentation

3 years ago7zip: Use compression settings for file header
Adrian Ebeling [Mon, 17 May 2021 19:11:38 +0000 (21:11 +0200)] 
7zip: Use compression settings for file header

3 years agoOn close, handle short writes from archive_write_callback 1530/head
Owen W. Taylor [Wed, 12 May 2021 20:26:24 +0000 (16:26 -0400)] 
On close, handle short writes from archive_write_callback

The archive_write_callback passed to archive_write_open() is documented as:

 "each call to the write callback function should translate to a single write(2) system call.
  On success, the write callback should return the number of bytes actually written"

And in most places, the code repeatedly calls the write callback, but when flushing
the buffer at close, the write callback was called once, assuming it would write everything.
This could result in a truncated archive.

A test is added to test short writes in different code paths.

3 years agoAvoid getcwd(0, PATH_MAX) for GNU libc 1529/head
Owen W. Taylor [Wed, 12 May 2021 20:37:16 +0000 (16:37 -0400)] 
Avoid getcwd(0, PATH_MAX) for GNU libc

Recent versions of GNU libc and GCC produce a warning on getcwd(0, PATH_MAX):

 test_main.c: In function ‘get_refdir’:
 test_main.c:3684:8: error: argument 1 is null but the corresponding size argument 2 value is 4096 [-Werror=nonnull]
   3684 |  pwd = getcwd(NULL, PATH_MAX);/* Solaris getcwd needs the size. */

This is because getcwd() is marked with the 'write_only (1, 2)' attribute.

Using the alternate getcwd(NULL, 0) path which is supported by GNU libc avoids this.

3 years agoMerge pull request #1502 from tih/cpio-bin-formats
Martin Matuška [Mon, 10 May 2021 19:05:00 +0000 (21:05 +0200)] 
Merge pull request #1502 from tih/cpio-bin-formats

Support for PWB and v7 binary cpio formats

3 years agoMerge pull request #1519 from zoulasc/master
Martin Matuška [Mon, 10 May 2021 19:02:16 +0000 (21:02 +0200)] 
Merge pull request #1519 from zoulasc/master

Extract common transfer setting code for statfs and statvfs.

3 years agoMerge pull request #1520 from odubaj/master
Martin Matuška [Mon, 10 May 2021 19:00:53 +0000 (21:00 +0200)] 
Merge pull request #1520 from odubaj/master

Fixed double free when calling lzx_huffman_init frees pointer ds-

3 years agoCatch up with autoconf changes: 1519/head
Christos Zoulas [Sat, 8 May 2021 20:07:51 +0000 (16:07 -0400)] 
Catch up with autoconf changes:
    HAVE_STRUCT_STATFS
    HAVE_STRUCT_STATFS_F_IOSIZE

3 years agoCast isprint(3) argument to unsigned char to avoid undefined behavior.
Christos Zoulas [Sat, 8 May 2021 20:07:04 +0000 (16:07 -0400)] 
Cast isprint(3) argument to unsigned char to avoid undefined behavior.

3 years agoNetBSD provides a statfs symbol for binary compatibility but does not
Christos Zoulas [Sat, 8 May 2021 20:06:11 +0000 (16:06 -0400)] 
NetBSD provides a statfs symbol for binary compatibility but does not
provide a visible struct statfs. Check for that.

3 years agoMerge remote-tracking branch 'upstream/master'
Christos Zoulas [Sat, 8 May 2021 19:38:34 +0000 (15:38 -0400)] 
Merge remote-tracking branch 'upstream/master'

3 years agoMerge pull request #1504 from legnaleurc/fix-rar-header-skim
Martin Matuška [Sat, 8 May 2021 19:27:56 +0000 (21:27 +0200)] 
Merge pull request #1504 from legnaleurc/fix-rar-header-skim

fix rar header skiming

3 years agofix rar header skiming 1504/head
Wei-Cheng Pan [Tue, 9 Mar 2021 16:34:55 +0000 (16:34 +0000)] 
fix rar header skiming

The available size returned from `__archive_read_ahead` can be larger
then required size. Substract by available size may underflow `skip`,
which will reach EOF too soon.

3 years agoMerge pull request #1524 from DerDakon/cpio-ext
Martin Matuška [Fri, 7 May 2021 15:37:38 +0000 (17:37 +0200)] 
Merge pull request #1524 from DerDakon/cpio-ext

cpio test: add source file extension

3 years agoMerge pull request #1521 from odubaj/leak-fix-rar
Martin Matuška [Sun, 18 Apr 2021 22:36:06 +0000 (00:36 +0200)] 
Merge pull request #1521 from odubaj/leak-fix-rar

Fixed leak of rar before ending with error

3 years agoMerge pull request #1522 from bradking/no-u_char
Brad King [Tue, 6 Apr 2021 18:11:36 +0000 (14:11 -0400)] 
Merge pull request #1522 from bradking/no-u_char

Use uint8_t instead of u_char