Accepting request 1131652 from Base:System
- GNU tar 1.34: * Fail when building GNU tar if the platform supports 64-bit time_t but the build only uses 32-bit time_t. * Leave the devmajor and devminor fields empty (rather than zero) for non-special files, as this is more compatible with traditional tar. Fixes: * Fix interaction of --update with --wildcards. * When extracting archives into an empty directory, do not create hard links to files outside that directory. * Handle partial reads from regular files. * Warn file changed as we read it less often. Formerly, tar warned if the file's size or ctime changed. However, this generated a false positive if tar read a file while another process hard-linked to it, changing its ctime. Now, tar warns if the file's size, mtime, user ID, group ID, or mode changes. Although neither heuristic is perfect, the new one should work better in practice. * Fix --ignore-failed-read to ignore file-changed read errors as far as exit status is concerned. You can now suppress file-changed issues entirely with --ignore-failed-read --warning=no-file-changed. * Fix --remove-files to not remove a file that changed while we read it. * Fix --atime-preserve=replace to not fail if there was no need to replace, either because we did not read the file, or the atime did not change. * Fix race when creating a parent directory while another process is also doing so. * Fix handling of prefix keywords not followed by "." in pax OBS-URL: https://build.opensuse.org/request/show/1131652 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/tar?expand=0&rev=83
This commit is contained in:
commit
5c3c9fcbbb
156
add_forgotten-tests.patch
Normal file
156
add_forgotten-tests.patch
Normal file
@ -0,0 +1,156 @@
|
|||||||
|
From 7fac753fb6e6c0459788ee9015b984dba1de5402 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Lukas Javorsky <ljavorsk@redhat.com>
|
||||||
|
Date: Tue, 18 Jul 2023 14:10:12 +0000
|
||||||
|
Subject: [PATCH] Add exclude17 and exclude18 tests which were forgotten by
|
||||||
|
upstream
|
||||||
|
|
||||||
|
Sources:
|
||||||
|
*https://git.savannah.gnu.org/cgit/tar.git/tree/tests/exclude17.at
|
||||||
|
*https://git.savannah.gnu.org/cgit/tar.git/tree/tests/exclude18.at
|
||||||
|
|
||||||
|
Repoted to upstream in ML:
|
||||||
|
*https://lists.gnu.org/archive/html/bug-tar/2023-07/msg00002.html
|
||||||
|
---
|
||||||
|
tests/exclude17.at | 35 +++++++++++++++++++
|
||||||
|
tests/exclude18.at | 87 ++++++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
2 files changed, 122 insertions(+)
|
||||||
|
create mode 100644 tests/exclude17.at
|
||||||
|
create mode 100644 tests/exclude18.at
|
||||||
|
|
||||||
|
diff --git a/tests/exclude17.at b/tests/exclude17.at
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..5539ef3
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/exclude17.at
|
||||||
|
@@ -0,0 +1,35 @@
|
||||||
|
+# Process this file with autom4te to create testsuite. -*- Autotest -*-
|
||||||
|
+#
|
||||||
|
+# Test suite for GNU tar.
|
||||||
|
+# Copyright 2013-2023 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+# This file is part of GNU tar.
|
||||||
|
+
|
||||||
|
+# GNU tar is free software; you can redistribute it and/or modify
|
||||||
|
+# it under the terms of the GNU General Public License as published by
|
||||||
|
+# the Free Software Foundation; either version 3 of the License, or
|
||||||
|
+# (at your option) any later version.
|
||||||
|
+
|
||||||
|
+# GNU tar is distributed in the hope that it will be useful,
|
||||||
|
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+# GNU General Public License for more details.
|
||||||
|
+
|
||||||
|
+# You should have received a copy of the GNU General Public License
|
||||||
|
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+
|
||||||
|
+AT_SETUP([--exclude-vcs-ignores memory allocation])
|
||||||
|
+AT_KEYWORDS([exclude exclude17])
|
||||||
|
+
|
||||||
|
+AT_TAR_CHECK([
|
||||||
|
+mkdir dir
|
||||||
|
+cd dir
|
||||||
|
+echo '*.o' >.cvsignore
|
||||||
|
+tar -cf - --exclude-vcs-ignores . | tar -tf -
|
||||||
|
+],
|
||||||
|
+[0],
|
||||||
|
+[./
|
||||||
|
+./.cvsignore
|
||||||
|
+])
|
||||||
|
+
|
||||||
|
+AT_CLEANUP
|
||||||
|
diff --git a/tests/exclude18.at b/tests/exclude18.at
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..64aaa52
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/tests/exclude18.at
|
||||||
|
@@ -0,0 +1,87 @@
|
||||||
|
+# Process this file with autom4te to create testsuite. -*- Autotest -*-
|
||||||
|
+
|
||||||
|
+# Test suite for GNU tar.
|
||||||
|
+# Copyright 2004-2023 Free Software Foundation, Inc.
|
||||||
|
+
|
||||||
|
+# This file is part of GNU tar.
|
||||||
|
+
|
||||||
|
+# GNU tar is free software; you can redistribute it and/or modify
|
||||||
|
+# it under the terms of the GNU General Public License as published by
|
||||||
|
+# the Free Software Foundation; either version 3 of the License, or
|
||||||
|
+# (at your option) any later version.
|
||||||
|
+
|
||||||
|
+# GNU tar is distributed in the hope that it will be useful,
|
||||||
|
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+# GNU General Public License for more details.
|
||||||
|
+
|
||||||
|
+# You should have received a copy of the GNU General Public License
|
||||||
|
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
+
|
||||||
|
+# Test --exclude-vcs option with subcommands: EXTRACT, LIST, DIFF.
|
||||||
|
+# Check VCS directory with files, and empty.
|
||||||
|
+#
|
||||||
|
+# Ref: https://savannah.gnu.org/bugs/?62859
|
||||||
|
+# Wed 03 Aug 2022 04:06:28 PM UTC, original submission: Quote
|
||||||
|
+# Mohamed Akram <mohdakram>
|
||||||
|
+# > The --exclude-vcs flag seems to exclude .gitignore but not .git when
|
||||||
|
+# extracting.
|
||||||
|
+
|
||||||
|
+AT_SETUP([--exclude-vcs extract list compare])
|
||||||
|
+AT_KEYWORDS([exclude-vcs extract list compare exclude18])
|
||||||
|
+
|
||||||
|
+AT_TAR_CHECK([
|
||||||
|
+AT_SORT_PREREQ
|
||||||
|
+mkdir gitrepo
|
||||||
|
+cd gitrepo
|
||||||
|
+
|
||||||
|
+# Make an empty VCS directory:
|
||||||
|
+mkdir .svn
|
||||||
|
+
|
||||||
|
+# Make a VCS directory with a file:
|
||||||
|
+mkdir .git
|
||||||
|
+touch .git/_A
|
||||||
|
+
|
||||||
|
+# Make a VCS file:
|
||||||
|
+touch .gitignore
|
||||||
|
+
|
||||||
|
+# Make non-VCS files:
|
||||||
|
+touch .git_B
|
||||||
|
+touch _C
|
||||||
|
+
|
||||||
|
+# Create an archive, include VCS:
|
||||||
|
+cd ..
|
||||||
|
+tar -cf gitrepo.tar gitrepo
|
||||||
|
+rm -r gitrepo
|
||||||
|
+
|
||||||
|
+echo Extract:
|
||||||
|
+tar -xvf gitrepo.tar --exclude-vcs | sort
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+echo List:
|
||||||
|
+tar -tf gitrepo.tar --exclude-vcs | sort
|
||||||
|
+
|
||||||
|
+echo
|
||||||
|
+echo Diff:
|
||||||
|
+tar -dvf gitrepo.tar --exclude-vcs gitrepo | sort
|
||||||
|
+
|
||||||
|
+],
|
||||||
|
+[0],
|
||||||
|
+[Extract:
|
||||||
|
+gitrepo/
|
||||||
|
+gitrepo/.git_B
|
||||||
|
+gitrepo/_C
|
||||||
|
+
|
||||||
|
+List:
|
||||||
|
+gitrepo/
|
||||||
|
+gitrepo/.git_B
|
||||||
|
+gitrepo/_C
|
||||||
|
+
|
||||||
|
+Diff:
|
||||||
|
+gitrepo/
|
||||||
|
+gitrepo/.git_B
|
||||||
|
+gitrepo/_C
|
||||||
|
+],
|
||||||
|
+[])
|
||||||
|
+
|
||||||
|
+AT_CLEANUP
|
||||||
|
--
|
||||||
|
2.41.0
|
||||||
|
|
@ -1,15 +1,3 @@
|
|||||||
Index: tar-1.33/Makefile.in
|
|
||||||
===================================================================
|
|
||||||
--- tar-1.33.orig/Makefile.in
|
|
||||||
+++ tar-1.33/Makefile.in
|
|
||||||
@@ -348,6 +348,7 @@ am__DIST_COMMON = $(srcdir)/Make.rules $
|
|
||||||
$(top_srcdir)/build-aux/install-sh \
|
|
||||||
$(top_srcdir)/build-aux/missing ABOUT-NLS AUTHORS COPYING \
|
|
||||||
ChangeLog INSTALL NEWS README THANKS TODO build-aux/ar-lib \
|
|
||||||
+ README-tests \
|
|
||||||
build-aux/compile build-aux/config.guess \
|
|
||||||
build-aux/config.rpath build-aux/config.sub build-aux/depcomp \
|
|
||||||
build-aux/install-sh build-aux/mdate-sh build-aux/missing \
|
|
||||||
Index: tar-1.33/README-tests
|
Index: tar-1.33/README-tests
|
||||||
===================================================================
|
===================================================================
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
|
@ -1,71 +0,0 @@
|
|||||||
From 79d1ac38c19faad64f0e993180bf1ad27f217072 Mon Sep 17 00:00:00 2001
|
|
||||||
From: James Abbatiello <abbeyj@gmail.com>
|
|
||||||
Date: Fri, 10 Jun 2022 18:25:13 -0700
|
|
||||||
Subject: tar: fix race condition
|
|
||||||
|
|
||||||
Problem reported in:
|
|
||||||
https://lists.gnu.org/r/bug-tar/2022-03/msg00000.html
|
|
||||||
* src/extract.c (make_directories): Retry the file creation as
|
|
||||||
long as the directory exists, regardless of whether tar itself
|
|
||||||
created the directory.
|
|
||||||
Copyright-paperwork-exempt: Yes
|
|
||||||
---
|
|
||||||
src/extract.c | 16 ++++++++--------
|
|
||||||
1 file changed, 8 insertions(+), 8 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/extract.c b/src/extract.c
|
|
||||||
index 0753dec..fda4617 100644
|
|
||||||
--- a/src/extract.c
|
|
||||||
+++ b/src/extract.c
|
|
||||||
@@ -638,10 +638,9 @@ fixup_delayed_set_stat (char const *src, char const *dst)
|
|
||||||
|
|
||||||
/* After a file/link/directory creation has failed due to ENOENT,
|
|
||||||
create all required directories. Return zero if all the required
|
|
||||||
- directories were created, nonzero (issuing a diagnostic) otherwise.
|
|
||||||
- Set *INTERDIR_MADE if at least one directory was created. */
|
|
||||||
+ directories were created, nonzero (issuing a diagnostic) otherwise. */
|
|
||||||
static int
|
|
||||||
-make_directories (char *file_name, bool *interdir_made)
|
|
||||||
+make_directories (char *file_name)
|
|
||||||
{
|
|
||||||
char *cursor0 = file_name + FILE_SYSTEM_PREFIX_LEN (file_name);
|
|
||||||
char *cursor; /* points into the file name */
|
|
||||||
@@ -685,7 +684,6 @@ make_directories (char *file_name, bool *interdir_made)
|
|
||||||
desired_mode, AT_SYMLINK_NOFOLLOW);
|
|
||||||
|
|
||||||
print_for_mkdir (file_name, cursor - file_name, desired_mode);
|
|
||||||
- *interdir_made = true;
|
|
||||||
parent_end = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
@@ -841,8 +839,11 @@ maybe_recoverable (char *file_name, bool regular, bool *interdir_made)
|
|
||||||
|
|
||||||
case ENOENT:
|
|
||||||
/* Attempt creating missing intermediate directories. */
|
|
||||||
- if (make_directories (file_name, interdir_made) == 0)
|
|
||||||
- return RECOVER_OK;
|
|
||||||
+ if (make_directories (file_name) == 0)
|
|
||||||
+ {
|
|
||||||
+ *interdir_made = true;
|
|
||||||
+ return RECOVER_OK;
|
|
||||||
+ }
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
@@ -1944,12 +1945,11 @@ rename_directory (char *src, char *dst)
|
|
||||||
else
|
|
||||||
{
|
|
||||||
int e = errno;
|
|
||||||
- bool interdir_made;
|
|
||||||
|
|
||||||
switch (e)
|
|
||||||
{
|
|
||||||
case ENOENT:
|
|
||||||
- if (make_directories (dst, &interdir_made) == 0)
|
|
||||||
+ if (make_directories (dst) == 0)
|
|
||||||
{
|
|
||||||
if (renameat (chdir_fd, src, chdir_fd, dst) == 0)
|
|
||||||
return true;
|
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
@ -1,65 +0,0 @@
|
|||||||
From edf38d13a47becec81b2c3a2b74f54771e1cbee4 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Sergey Poznyakoff <gray@gnu.org>
|
|
||||||
Date: Sat, 11 Feb 2023 13:03:23 +0200
|
|
||||||
Subject: Prevent dead loop in extract_file
|
|
||||||
|
|
||||||
* src/extract.c (maybe_recoverable): If make_directories indicates
|
|
||||||
success, suppose some intermediate directories have been made, even
|
|
||||||
if in fact they have not. That's necessary to avoid dead loops when
|
|
||||||
maybe_recoverable is called with the same arguments again.
|
|
||||||
---
|
|
||||||
src/extract.c | 13 +++++++------
|
|
||||||
1 file changed, 7 insertions(+), 6 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/extract.c b/src/extract.c
|
|
||||||
index 2d43947..aec5de6 100644
|
|
||||||
--- a/src/extract.c
|
|
||||||
+++ b/src/extract.c
|
|
||||||
@@ -682,7 +682,7 @@ fixup_delayed_set_stat (char const *src, char const *dst)
|
|
||||||
directories were created, nonzero (issuing a diagnostic) otherwise.
|
|
||||||
Set *INTERDIR_MADE if at least one directory was created. */
|
|
||||||
static int
|
|
||||||
-make_directories (char *file_name, bool *interdir_made)
|
|
||||||
+make_directories (char *file_name)
|
|
||||||
{
|
|
||||||
char *cursor0 = file_name + FILE_SYSTEM_PREFIX_LEN (file_name);
|
|
||||||
char *cursor; /* points into the file name */
|
|
||||||
@@ -726,7 +726,6 @@ make_directories (char *file_name, bool *interdir_made)
|
|
||||||
desired_mode, AT_SYMLINK_NOFOLLOW);
|
|
||||||
|
|
||||||
print_for_mkdir (file_name, cursor - file_name, desired_mode);
|
|
||||||
- *interdir_made = true;
|
|
||||||
parent_end = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
@@ -882,8 +881,11 @@ maybe_recoverable (char *file_name, bool regular, bool *interdir_made)
|
|
||||||
|
|
||||||
case ENOENT:
|
|
||||||
/* Attempt creating missing intermediate directories. */
|
|
||||||
- if (make_directories (file_name, interdir_made) == 0)
|
|
||||||
- return RECOVER_OK;
|
|
||||||
+ if (make_directories (file_name) == 0)
|
|
||||||
+ {
|
|
||||||
+ *interdir_made = true;
|
|
||||||
+ return RECOVER_OK;
|
|
||||||
+ }
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
@@ -1985,12 +1987,11 @@ rename_directory (char *src, char *dst)
|
|
||||||
else
|
|
||||||
{
|
|
||||||
int e = errno;
|
|
||||||
- bool interdir_made;
|
|
||||||
|
|
||||||
switch (e)
|
|
||||||
{
|
|
||||||
case ENOENT:
|
|
||||||
- if (make_directories (dst, &interdir_made) == 0)
|
|
||||||
+ if (make_directories (dst) == 0)
|
|
||||||
{
|
|
||||||
if (renameat (chdir_fd, src, chdir_fd, dst) == 0)
|
|
||||||
return true;
|
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
@ -1,47 +0,0 @@
|
|||||||
From 5e8a915b16c5f06d2a16d98cdc2af666199caabb Mon Sep 17 00:00:00 2001
|
|
||||||
From: Sergey Poznyakoff <gray@gnu.org>
|
|
||||||
Date: Sat, 11 Feb 2023 14:21:05 +0200
|
|
||||||
Subject: Changes in extended header decoder
|
|
||||||
|
|
||||||
* src/xheader.c (decode_time): Fix error detection.
|
|
||||||
(raw_path_decoder): Ignore empty paths.
|
|
||||||
---
|
|
||||||
src/xheader.c | 15 ++++++++++++---
|
|
||||||
1 file changed, 12 insertions(+), 3 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/xheader.c b/src/xheader.c
|
|
||||||
index 7ff216b..a195f3e 100644
|
|
||||||
--- a/src/xheader.c
|
|
||||||
+++ b/src/xheader.c
|
|
||||||
@@ -1059,6 +1059,12 @@ decode_time (struct timespec *ts, char const *arg, char const *keyword)
|
|
||||||
keyword, arg));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
+ if (*arg_lim)
|
|
||||||
+ {
|
|
||||||
+ ERROR ((0, 0, _("Malformed extended header: invalid %s=%s"),
|
|
||||||
+ keyword, arg));
|
|
||||||
+ return false;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
*ts = t;
|
|
||||||
return true;
|
|
||||||
@@ -1247,9 +1253,12 @@ path_coder (struct tar_stat_info const *st, char const *keyword,
|
|
||||||
static void
|
|
||||||
raw_path_decoder (struct tar_stat_info *st, char const *arg)
|
|
||||||
{
|
|
||||||
- decode_string (&st->orig_file_name, arg);
|
|
||||||
- decode_string (&st->file_name, arg);
|
|
||||||
- st->had_trailing_slash = strip_trailing_slashes (st->file_name);
|
|
||||||
+ if (*arg)
|
|
||||||
+ {
|
|
||||||
+ decode_string (&st->orig_file_name, arg);
|
|
||||||
+ decode_string (&st->file_name, arg);
|
|
||||||
+ st->had_trailing_slash = strip_trailing_slashes (st->file_name);
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:63bebd26879c5e1eea4352f0d03c991f966aeb3ddeb3c7445c902568d5411d28
|
|
||||||
size 2226068
|
|
@ -1,7 +0,0 @@
|
|||||||
-----BEGIN PGP SIGNATURE-----
|
|
||||||
Version: GnuPG v1
|
|
||||||
|
|
||||||
iEYEABECAAYFAmAnuBMACgkQNgKwf1XQxzJIVgCfR5Z7coRkU2+aOW4KNhumGl/1
|
|
||||||
jn4AoI9OuQPpyzZN1CIwejDYxbV7u59P
|
|
||||||
=mfma
|
|
||||||
-----END PGP SIGNATURE-----
|
|
BIN
tar-1.35.tar.xz
(Stored with Git LFS)
Normal file
BIN
tar-1.35.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
tar-1.35.tar.xz.sig
Normal file
BIN
tar-1.35.tar.xz.sig
Normal file
Binary file not shown.
@ -1,76 +0,0 @@
|
|||||||
From d935dc7d1c150b3425dd43dc13a4dd2e2b712c26 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Paul Eggert <eggert@cs.ucla.edu>
|
|
||||||
Date: Mon, 13 Jun 2022 17:02:54 -0700
|
|
||||||
Subject: Avoid EOVERFLOW problems in some symlink tests
|
|
||||||
|
|
||||||
* src/extract.c (is_directory_link): New arg ST. Caller changed.
|
|
||||||
(is_directory_link, open_output_file):
|
|
||||||
Use readlinkat, not fstatat, to determine whether a string
|
|
||||||
names a symlink. This avoids EOVERFLOW issues.
|
|
||||||
(extract_dir): Avoid duplicate calls to fstatat when
|
|
||||||
keep_directory_symlink_option && fstatat_flags == 0
|
|
||||||
and the file is a symlink to an existing file.
|
|
||||||
---
|
|
||||||
src/extract.c | 28 ++++++++++++----------------
|
|
||||||
1 file changed, 12 insertions(+), 16 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/extract.c b/src/extract.c
|
|
||||||
index fda4617..6d2543f 100644
|
|
||||||
--- a/src/extract.c
|
|
||||||
+++ b/src/extract.c
|
|
||||||
@@ -982,18 +982,12 @@ apply_nonancestor_delayed_set_stat (char const *file_name, bool after_links)
|
|
||||||
|
|
||||||
|
|
||||||
static bool
|
|
||||||
-is_directory_link (const char *file_name)
|
|
||||||
+is_directory_link (char const *file_name, struct stat *st)
|
|
||||||
{
|
|
||||||
- struct stat st;
|
|
||||||
- int e = errno;
|
|
||||||
- int res;
|
|
||||||
-
|
|
||||||
- res = (fstatat (chdir_fd, file_name, &st, AT_SYMLINK_NOFOLLOW) == 0 &&
|
|
||||||
- S_ISLNK (st.st_mode) &&
|
|
||||||
- fstatat (chdir_fd, file_name, &st, 0) == 0 &&
|
|
||||||
- S_ISDIR (st.st_mode));
|
|
||||||
- errno = e;
|
|
||||||
- return res;
|
|
||||||
+ char buf[1];
|
|
||||||
+ return (0 <= readlinkat (chdir_fd, file_name, buf, sizeof buf)
|
|
||||||
+ && fstatat (chdir_fd, file_name, st, 0) == 0
|
|
||||||
+ && S_ISDIR (st->st_mode));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Given struct stat of a directory (or directory member) whose ownership
|
|
||||||
@@ -1066,11 +1060,14 @@ extract_dir (char *file_name, int typeflag)
|
|
||||||
|| old_files_option == OVERWRITE_OLD_FILES))
|
|
||||||
{
|
|
||||||
struct stat st;
|
|
||||||
+ st.st_mode = 0;
|
|
||||||
|
|
||||||
- if (keep_directory_symlink_option && is_directory_link (file_name))
|
|
||||||
+ if (keep_directory_symlink_option
|
|
||||||
+ && is_directory_link (file_name, &st))
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
- if (deref_stat (file_name, &st) == 0)
|
|
||||||
+ if ((st.st_mode != 0 && fstatat_flags == 0)
|
|
||||||
+ || deref_stat (file_name, &st) == 0)
|
|
||||||
{
|
|
||||||
current_mode = st.st_mode;
|
|
||||||
current_mode_mask = ALL_MODE_BITS;
|
|
||||||
@@ -1178,9 +1175,8 @@ open_output_file (char const *file_name, int typeflag, mode_t mode,
|
|
||||||
if (! HAVE_WORKING_O_NOFOLLOW
|
|
||||||
&& overwriting_old_files && ! dereference_option)
|
|
||||||
{
|
|
||||||
- struct stat st;
|
|
||||||
- if (fstatat (chdir_fd, file_name, &st, AT_SYMLINK_NOFOLLOW) == 0
|
|
||||||
- && S_ISLNK (st.st_mode))
|
|
||||||
+ char buf[1];
|
|
||||||
+ if (0 <= readlinkat (chdir_fd, file_name, buf, sizeof buf))
|
|
||||||
{
|
|
||||||
errno = ELOOP;
|
|
||||||
return -1;
|
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
@ -2,7 +2,7 @@ Index: tar-1.29/scripts/backup-specs
|
|||||||
===================================================================
|
===================================================================
|
||||||
--- tar-1.29.orig/scripts/backup-specs
|
--- tar-1.29.orig/scripts/backup-specs
|
||||||
+++ tar-1.29/scripts/backup-specs
|
+++ tar-1.29/scripts/backup-specs
|
||||||
@@ -6,17 +6,17 @@
|
@@ -6,7 +6,7 @@
|
||||||
ADMINISTRATOR="root@localhost"
|
ADMINISTRATOR="root@localhost"
|
||||||
|
|
||||||
# (Optional) Path to tar binary.
|
# (Optional) Path to tar binary.
|
||||||
@ -11,15 +11,3 @@ Index: tar-1.29/scripts/backup-specs
|
|||||||
|
|
||||||
# (Optional) Path to rsh binary or its equivalent. You may wish to
|
# (Optional) Path to rsh binary or its equivalent. You may wish to
|
||||||
# set it to ssh as shown in the example below, to improve security.
|
# set it to ssh as shown in the example below, to improve security.
|
||||||
# In this case you will have to use public key authentication.
|
|
||||||
-RSH=/usr/local/bin/ssh
|
|
||||||
+RSH=/usr/bin/ssh
|
|
||||||
|
|
||||||
# (Optional) Path to rsh binary on remote mashines. This will be
|
|
||||||
# passed via --rsh-command option to the remote invocation of
|
|
||||||
# tar
|
|
||||||
-RSH_COMMAND=/usr/local/bin/ssh
|
|
||||||
+RSH_COMMAND=/usr/bin/ssh
|
|
||||||
|
|
||||||
# Name of temporary file to hold volume numbers. This needs to be accessible
|
|
||||||
# by all the machines which have filesystems to be dumped.
|
|
||||||
|
@ -1,174 +1,79 @@
|
|||||||
From 17debecd7300e94f590b8ce167a8c0735cb6d57d Mon Sep 17 00:00:00 2001
|
|
||||||
From: Sergey Poznyakoff <gray@gnu.org>
|
|
||||||
Date: Sat, 22 Oct 2022 12:06:45 +0300
|
|
||||||
Subject: Fix savannah bug #63123
|
|
||||||
|
|
||||||
The bug was introduced by commit 79d1ac38c1, which didn't take into
|
|
||||||
account all the consequences of returning RECOVER_OK on EEXIST, in
|
|
||||||
particular interactions with the delayed_set_stat logic.
|
|
||||||
|
|
||||||
The commit 79d1ac38c1 is reverted (the bug it was intended to fix
|
|
||||||
was actually fixed by 79a442d7b0). Instead:
|
|
||||||
|
|
||||||
* src/extract.c (maybe_recoverable): Don't call maybe_recoverable
|
|
||||||
if EEXIST is reported when UNLINK_FIRST_OLD_FILES option is set.
|
|
||||||
---
|
|
||||||
src/extract.c | 108 +++++++++++++++++++++++++++++++---------------------------
|
|
||||||
1 file changed, 58 insertions(+), 50 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/extract.c b/src/extract.c
|
diff --git a/src/extract.c b/src/extract.c
|
||||||
index 78de47f..37ab295 100644
|
index 0261134f..f913575c 100644
|
||||||
--- a/src/extract.c
|
--- a/src/extract.c
|
||||||
+++ b/src/extract.c
|
+++ b/src/extract.c
|
||||||
@@ -679,9 +679,10 @@ fixup_delayed_set_stat (char const *src, char const *dst)
|
@@ -711,7 +711,7 @@ fixup_delayed_set_stat (char const *src, char const *dst)
|
||||||
|
directories were created, nonzero (issuing a diagnostic) otherwise.
|
||||||
/* After a file/link/directory creation has failed due to ENOENT,
|
Set *INTERDIR_MADE if at least one directory was created. */
|
||||||
create all required directories. Return zero if all the required
|
|
||||||
- directories were created, nonzero (issuing a diagnostic) otherwise. */
|
|
||||||
+ directories were created, nonzero (issuing a diagnostic) otherwise.
|
|
||||||
+ Set *INTERDIR_MADE if at least one directory was created. */
|
|
||||||
static int
|
static int
|
||||||
-make_directories (char *file_name)
|
-make_directories (char *file_name)
|
||||||
+make_directories (char *file_name, bool *interdir_made)
|
+make_directories (char *file_name, bool *interdir_made)
|
||||||
{
|
{
|
||||||
char *cursor0 = file_name + FILE_SYSTEM_PREFIX_LEN (file_name);
|
char *cursor0 = file_name + FILE_SYSTEM_PREFIX_LEN (file_name);
|
||||||
char *cursor; /* points into the file name */
|
char *cursor; /* points into the file name */
|
||||||
@@ -725,6 +726,7 @@ make_directories (char *file_name)
|
@@ -755,6 +755,7 @@ make_directories (char *file_name)
|
||||||
desired_mode, AT_SYMLINK_NOFOLLOW);
|
desired_mode, AT_SYMLINK_NOFOLLOW);
|
||||||
|
|
||||||
print_for_mkdir (file_name, cursor - file_name, desired_mode);
|
print_for_mkdir (file_name, desired_mode);
|
||||||
+ *interdir_made = true;
|
+ *interdir_made = true;
|
||||||
parent_end = NULL;
|
parent_end = NULL;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -879,12 +881,9 @@ maybe_recoverable (char *file_name, bool regular, bool *interdir_made)
|
@@ -910,11 +911,8 @@ maybe_recoverable (char *file_name, bool regular, bool *interdir_made)
|
||||||
FALLTHROUGH;
|
|
||||||
|
|
||||||
case ENOENT:
|
case ENOENT:
|
||||||
- /* Attempt creating missing intermediate directories. */
|
/* Attempt creating missing intermediate directories. */
|
||||||
- if (make_directories (file_name) == 0)
|
- if (make_directories (file_name) == 0)
|
||||||
- {
|
- {
|
||||||
- *interdir_made = true;
|
- *interdir_made = true;
|
||||||
- return RECOVER_OK;
|
|
||||||
- }
|
|
||||||
+ /* Attempt creating missing intermediate directories. */
|
|
||||||
+ if (make_directories (file_name, interdir_made) == 0)
|
+ if (make_directories (file_name, interdir_made) == 0)
|
||||||
+ return RECOVER_OK;
|
return RECOVER_OK;
|
||||||
|
- }
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@@ -1072,61 +1071,69 @@ extract_dir (char *file_name, int typeflag)
|
@@ -1109,7 +1107,7 @@ extract_dir (char *file_name, int typeflag)
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (errno == EEXIST
|
|
||||||
- && (interdir_made
|
|
||||||
+ if (errno == EEXIST)
|
|
||||||
+ {
|
|
||||||
+ if (interdir_made
|
|
||||||
|| keep_directory_symlink_option
|
|
||||||
|| old_files_option == NO_OVERWRITE_DIR_OLD_FILES
|
|| old_files_option == NO_OVERWRITE_DIR_OLD_FILES
|
||||||
|| old_files_option == DEFAULT_OLD_FILES
|
|| old_files_option == DEFAULT_OLD_FILES
|
||||||
- || old_files_option == OVERWRITE_OLD_FILES))
|
|| old_files_option == OVERWRITE_OLD_FILES)
|
||||||
- {
|
- {
|
||||||
- struct stat st;
|
+ {
|
||||||
- st.st_mode = 0;
|
struct stat st;
|
||||||
-
|
st.st_mode = 0;
|
||||||
- if (keep_directory_symlink_option
|
|
||||||
- && is_directory_link (file_name, &st))
|
@@ -1117,21 +1115,21 @@ extract_dir (char *file_name, int typeflag)
|
||||||
- return 0;
|
&& is_directory_link (file_name, &st))
|
||||||
-
|
return 0;
|
||||||
|
|
||||||
- if ((st.st_mode != 0 && fstatat_flags == 0)
|
- if ((st.st_mode != 0 && fstatat_flags == 0)
|
||||||
- || deref_stat (file_name, &st) == 0)
|
- || deref_stat (file_name, &st) == 0)
|
||||||
+ || old_files_option == OVERWRITE_OLD_FILES)
|
- {
|
||||||
{
|
|
||||||
- current_mode = st.st_mode;
|
|
||||||
- current_mode_mask = ALL_MODE_BITS;
|
|
||||||
+ struct stat st;
|
|
||||||
+ st.st_mode = 0;
|
|
||||||
+
|
|
||||||
+ if (keep_directory_symlink_option
|
|
||||||
+ && is_directory_link (file_name, &st))
|
|
||||||
+ return 0;
|
|
||||||
|
|
||||||
- if (S_ISDIR (current_mode))
|
|
||||||
+ if ((st.st_mode != 0 && fstatat_flags == 0)
|
+ if ((st.st_mode != 0 && fstatat_flags == 0)
|
||||||
+ || deref_stat (file_name, &st) == 0)
|
+ || deref_stat (file_name, &st) == 0)
|
||||||
{
|
+ {
|
||||||
|
current_mode = st.st_mode;
|
||||||
|
current_mode_mask = ALL_MODE_BITS;
|
||||||
|
|
||||||
|
if (S_ISDIR (current_mode))
|
||||||
|
- {
|
||||||
- if (interdir_made)
|
- if (interdir_made)
|
||||||
- {
|
- {
|
||||||
- repair_delayed_set_stat (file_name, &st);
|
- repair_delayed_set_stat (file_name, &st);
|
||||||
- return 0;
|
- return 0;
|
||||||
- }
|
- }
|
||||||
- else if (old_files_option == NO_OVERWRITE_DIR_OLD_FILES)
|
- else if (old_files_option == NO_OVERWRITE_DIR_OLD_FILES)
|
||||||
+ current_mode = st.st_mode;
|
|
||||||
+ current_mode_mask = ALL_MODE_BITS;
|
|
||||||
+
|
|
||||||
+ if (S_ISDIR (current_mode))
|
|
||||||
{
|
{
|
||||||
- /* Temporarily change the directory mode to a safe
|
|
||||||
- value, to be able to create files in it, should
|
|
||||||
- the need be.
|
|
||||||
- */
|
|
||||||
- mode = safe_dir_mode (&st);
|
|
||||||
- status = fd_chmod(-1, file_name, mode,
|
|
||||||
- AT_SYMLINK_NOFOLLOW, DIRTYPE);
|
|
||||||
- if (status == 0)
|
|
||||||
+ if (interdir_made)
|
+ if (interdir_made)
|
||||||
{
|
+ {
|
||||||
- /* Store the actual directory mode, to be restored
|
|
||||||
- later.
|
|
||||||
- */
|
|
||||||
- current_stat_info.stat = st;
|
|
||||||
- current_mode = mode & ~ current_umask;
|
|
||||||
- current_mode_mask = MODE_RWX;
|
|
||||||
- atflag = AT_SYMLINK_NOFOLLOW;
|
|
||||||
- break;
|
|
||||||
+ repair_delayed_set_stat (file_name, &st);
|
+ repair_delayed_set_stat (file_name, &st);
|
||||||
+ return 0;
|
+ return 0;
|
||||||
}
|
+ }
|
||||||
- else
|
|
||||||
+ else if (old_files_option == NO_OVERWRITE_DIR_OLD_FILES)
|
+ else if (old_files_option == NO_OVERWRITE_DIR_OLD_FILES)
|
||||||
{
|
|
||||||
- chmod_error_details (file_name, mode);
|
|
||||||
+ /* Temporarily change the directory mode to a safe
|
|
||||||
+ value, to be able to create files in it, should
|
|
||||||
+ the need be.
|
|
||||||
+ */
|
|
||||||
+ mode = safe_dir_mode (&st);
|
|
||||||
+ status = fd_chmod (-1, file_name, mode,
|
|
||||||
+ AT_SYMLINK_NOFOLLOW, DIRTYPE);
|
|
||||||
+ if (status == 0)
|
|
||||||
+ {
|
+ {
|
||||||
+ /* Store the actual directory mode, to be restored
|
/* Temporarily change the directory mode to a safe
|
||||||
+ later.
|
value, to be able to create files in it, should
|
||||||
+ */
|
the need be.
|
||||||
+ current_stat_info.stat = st;
|
@@ -2007,11 +2005,12 @@ rename_directory (char *src, char *dst)
|
||||||
+ current_mode = mode & ~ current_umask;
|
|
||||||
+ current_mode_mask = MODE_RWX;
|
|
||||||
+ atflag = AT_SYMLINK_NOFOLLOW;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ else
|
|
||||||
+ {
|
|
||||||
+ chmod_error_details (file_name, mode);
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
+ break;
|
|
||||||
}
|
|
||||||
- break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
+ else if (old_files_option == UNLINK_FIRST_OLD_FILES)
|
|
||||||
+ {
|
|
||||||
+ status = 0;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
errno = EEXIST;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1978,11 +1985,12 @@ rename_directory (char *src, char *dst)
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int e = errno;
|
int e = errno;
|
||||||
@ -182,6 +87,3 @@ index 78de47f..37ab295 100644
|
|||||||
{
|
{
|
||||||
if (renameat (chdir_fd, src, chdir_fd, dst) == 0)
|
if (renameat (chdir_fd, src, chdir_fd, dst) == 0)
|
||||||
return true;
|
return true;
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
||||||
|
@ -1,117 +0,0 @@
|
|||||||
From 79a442d7b0e92622794bfa41dee18a28e450a0dc Mon Sep 17 00:00:00 2001
|
|
||||||
From: Paul Eggert <eggert@cs.ucla.edu>
|
|
||||||
Date: Thu, 9 Jun 2022 22:09:34 -0700
|
|
||||||
Subject: tar: fix race condition
|
|
||||||
|
|
||||||
Problem reported by James Abbatiello in:
|
|
||||||
https://lists.gnu.org/r/bug-tar/2022-03/msg00000.html
|
|
||||||
* src/extract.c (make_directories): Do not assume that when
|
|
||||||
mkdirat fails with errno == EEXIST that there is an existing file
|
|
||||||
that can be statted. It could be a dangling symlink. Instead,
|
|
||||||
wait until the end and stat it.
|
|
||||||
---
|
|
||||||
src/extract.c | 61 ++++++++++++++++++++++++++++++++++++++---------------------
|
|
||||||
2 files changed, 43 insertions(+), 23 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/src/extract.c b/src/extract.c
|
|
||||||
index e7be463..0753dec 100644
|
|
||||||
--- a/src/extract.c
|
|
||||||
+++ b/src/extract.c
|
|
||||||
@@ -636,8 +636,7 @@ fixup_delayed_set_stat (char const *src, char const *dst)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
-/* After a file/link/directory creation has failed, see if
|
|
||||||
- it's because some required directory was not present, and if so,
|
|
||||||
+/* After a file/link/directory creation has failed due to ENOENT,
|
|
||||||
create all required directories. Return zero if all the required
|
|
||||||
directories were created, nonzero (issuing a diagnostic) otherwise.
|
|
||||||
Set *INTERDIR_MADE if at least one directory was created. */
|
|
||||||
@@ -646,6 +645,8 @@ make_directories (char *file_name, bool *interdir_made)
|
|
||||||
{
|
|
||||||
char *cursor0 = file_name + FILE_SYSTEM_PREFIX_LEN (file_name);
|
|
||||||
char *cursor; /* points into the file name */
|
|
||||||
+ char *parent_end = NULL;
|
|
||||||
+ int parent_errno;
|
|
||||||
|
|
||||||
for (cursor = cursor0; *cursor; cursor++)
|
|
||||||
{
|
|
||||||
@@ -685,31 +686,47 @@ make_directories (char *file_name, bool *interdir_made)
|
|
||||||
|
|
||||||
print_for_mkdir (file_name, cursor - file_name, desired_mode);
|
|
||||||
*interdir_made = true;
|
|
||||||
+ parent_end = NULL;
|
|
||||||
}
|
|
||||||
- else if (errno == EEXIST)
|
|
||||||
- status = 0;
|
|
||||||
else
|
|
||||||
- {
|
|
||||||
- /* Check whether the desired file exists. Even when the
|
|
||||||
- file exists, mkdir can fail with some errno value E other
|
|
||||||
- than EEXIST, so long as E describes an error condition
|
|
||||||
- that also applies. */
|
|
||||||
- int e = errno;
|
|
||||||
- struct stat st;
|
|
||||||
- status = fstatat (chdir_fd, file_name, &st, 0);
|
|
||||||
- if (status)
|
|
||||||
- {
|
|
||||||
- errno = e;
|
|
||||||
- mkdir_error (file_name);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
+ switch (errno)
|
|
||||||
+ {
|
|
||||||
+ case ELOOP: case ENAMETOOLONG: case ENOENT: case ENOTDIR:
|
|
||||||
+ /* FILE_NAME doesn't exist and couldn't be created; fail now. */
|
|
||||||
+ mkdir_error (file_name);
|
|
||||||
+ *cursor = '/';
|
|
||||||
+ return status;
|
|
||||||
+
|
|
||||||
+ default:
|
|
||||||
+ /* FILE_NAME may be an existing directory so do not fail now.
|
|
||||||
+ Instead, arrange to check at loop exit, assuming this is
|
|
||||||
+ the last loop iteration. */
|
|
||||||
+ parent_end = cursor;
|
|
||||||
+ parent_errno = errno;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
*cursor = '/';
|
|
||||||
- if (status)
|
|
||||||
- return status;
|
|
||||||
}
|
|
||||||
|
|
||||||
- return 0;
|
|
||||||
+ if (!parent_end)
|
|
||||||
+ return 0;
|
|
||||||
+
|
|
||||||
+ /* Although we did not create the parent directory, some other
|
|
||||||
+ process may have created it, so check whether it exists now. */
|
|
||||||
+ *parent_end = '\0';
|
|
||||||
+ struct stat st;
|
|
||||||
+ int stat_status = fstatat (chdir_fd, file_name, &st, 0);
|
|
||||||
+ if (!stat_status && !S_ISDIR (st.st_mode))
|
|
||||||
+ stat_status = -1;
|
|
||||||
+ if (stat_status)
|
|
||||||
+ {
|
|
||||||
+ errno = parent_errno;
|
|
||||||
+ mkdir_error (file_name);
|
|
||||||
+ }
|
|
||||||
+ *parent_end = '/';
|
|
||||||
+
|
|
||||||
+ return stat_status;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Return true if FILE_NAME (with status *STP, if STP) is not a
|
|
||||||
@@ -824,7 +841,7 @@ maybe_recoverable (char *file_name, bool regular, bool *interdir_made)
|
|
||||||
|
|
||||||
case ENOENT:
|
|
||||||
/* Attempt creating missing intermediate directories. */
|
|
||||||
- if (make_directories (file_name, interdir_made) == 0 && *interdir_made)
|
|
||||||
+ if (make_directories (file_name, interdir_made) == 0)
|
|
||||||
return RECOVER_OK;
|
|
||||||
break;
|
|
||||||
|
|
||||||
--
|
|
||||||
cgit v1.1
|
|
||||||
|
|
55
tar.changes
55
tar.changes
@ -1,3 +1,58 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Dec 6 16:04:39 UTC 2023 - Joshua Smith <jsmithfpv@gmail.com>
|
||||||
|
|
||||||
|
- GNU tar 1.34:
|
||||||
|
* Fail when building GNU tar if the platform supports 64-bit
|
||||||
|
time_t but the build only uses 32-bit time_t.
|
||||||
|
* Leave the devmajor and devminor fields empty (rather than
|
||||||
|
zero) for non-special files, as this is more compatible with
|
||||||
|
traditional tar.
|
||||||
|
Fixes:
|
||||||
|
* Fix interaction of --update with --wildcards.
|
||||||
|
* When extracting archives into an empty directory, do not create
|
||||||
|
hard links to files outside that directory.
|
||||||
|
* Handle partial reads from regular files.
|
||||||
|
* Warn file changed as we read it less often. Formerly, tar
|
||||||
|
warned if the file's size or ctime changed. However, this
|
||||||
|
generated a false positive if tar read a file while another
|
||||||
|
process hard-linked to it, changing its ctime. Now, tar warns
|
||||||
|
if the file's size, mtime, user ID, group ID, or mode changes.
|
||||||
|
Although neither heuristic is perfect, the new one should work
|
||||||
|
better in practice.
|
||||||
|
* Fix --ignore-failed-read to ignore file-changed read errors
|
||||||
|
as far as exit status is concerned. You can now suppress
|
||||||
|
file-changed issues entirely with --ignore-failed-read
|
||||||
|
--warning=no-file-changed.
|
||||||
|
* Fix --remove-files to not remove a file that changed while we
|
||||||
|
read it.
|
||||||
|
* Fix --atime-preserve=replace to not fail if there was no need
|
||||||
|
to replace, either because we did not read the file, or the
|
||||||
|
atime did not change.
|
||||||
|
* Fix race when creating a parent directory while another process
|
||||||
|
is also doing so.
|
||||||
|
* Fix handling of prefix keywords not followed by "." in pax
|
||||||
|
headers.
|
||||||
|
* Fix handling of out-of-range sparse entries in pax headers.
|
||||||
|
* Fix handling of --transform='s/s/@/2'.
|
||||||
|
* Fix treatment of options ending in slash in files-from list.
|
||||||
|
* Fix crash on tar --checkpoint-action exec=\".
|
||||||
|
* Fix low-memory crash when reading incremental dumps.
|
||||||
|
* Fix --exclude-vcs-ignores memory allocation misuse.
|
||||||
|
- Added patch:
|
||||||
|
* add_forgotten-tests.patch: added 2 tests that upstream forgot in the release.
|
||||||
|
- Update patch:
|
||||||
|
* tar-backup-spec-fix-paths.patch: upstream fixed 2/3rd of paths
|
||||||
|
* tar-fix-extract-unlink.patch
|
||||||
|
some of this is overwritten by bsc1202436-1 and some was fixed
|
||||||
|
upstream
|
||||||
|
* add_readme-tests.patch as Makefile.in no longer exists
|
||||||
|
- Removed:
|
||||||
|
* tar-fix-race-condition.patch
|
||||||
|
* tar-avoid-overflow-in-symlinks-tests.patch
|
||||||
|
* bsc1200657.patch
|
||||||
|
* bsc1202436-2.patch
|
||||||
|
* bsc1202436-1.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Tue Jul 25 13:54:28 UTC 2023 - Andreas Schwab <schwab@suse.de>
|
Tue Jul 25 13:54:28 UTC 2023 - Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
|
31
tar.spec
31
tar.spec
@ -19,7 +19,7 @@
|
|||||||
# For correct subpackages docs installation into tar doc directory
|
# For correct subpackages docs installation into tar doc directory
|
||||||
%global _docdir_fmt %{name}
|
%global _docdir_fmt %{name}
|
||||||
Name: tar
|
Name: tar
|
||||||
Version: 1.34
|
Version: 1.35
|
||||||
Release: 0
|
Release: 0
|
||||||
Summary: GNU implementation of ((t)ape (ar)chiver)
|
Summary: GNU implementation of ((t)ape (ar)chiver)
|
||||||
License: GPL-3.0-or-later
|
License: GPL-3.0-or-later
|
||||||
@ -40,24 +40,16 @@ Patch3: %{name}-ignore_lone_zero_blocks.patch
|
|||||||
Patch5: add_readme-tests.patch
|
Patch5: add_readme-tests.patch
|
||||||
Patch6: tar-PIE.patch
|
Patch6: tar-PIE.patch
|
||||||
Patch7: tests-skip-time01-on-32bit-time_t.patch
|
Patch7: tests-skip-time01-on-32bit-time_t.patch
|
||||||
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1200657
|
|
||||||
# fix race condition while creating intermediate subdirectories
|
|
||||||
Patch8: tar-fix-race-condition.patch
|
|
||||||
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1203600
|
|
||||||
# Unexpected inconsistency when making directory
|
|
||||||
Patch9: tar-avoid-overflow-in-symlinks-tests.patch
|
|
||||||
Patch10: bsc1200657.patch
|
|
||||||
Patch11: tar-fix-extract-unlink.patch
|
Patch11: tar-fix-extract-unlink.patch
|
||||||
# PATCH-FIX-SUSE danilo.spinella@suse.com bsc#1202436
|
# PATCH-FIX-SUSE danilo.spinella@suse.com bsc#1202436
|
||||||
Patch12: go-testsuite-test-hang.patch
|
Patch12: go-testsuite-test-hang.patch
|
||||||
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1202436
|
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1202436
|
||||||
Patch13: bsc1202436.patch
|
Patch13: bsc1202436.patch
|
||||||
Patch14: bsc1202436-1.patch
|
|
||||||
Patch15: bsc1202436-2.patch
|
|
||||||
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1207753
|
# PATCH-FIX-UPSTREAM danilo.spinella@suse.com bsc#1207753
|
||||||
# tar has a one-byte out-of-bounds read that results in use of
|
# tar has a one-byte out-of-bounds read that results in use of
|
||||||
# uninitialized memory for a conditional jump
|
# uninitialized memory for a conditional jump
|
||||||
Patch16: fix-CVE-2022-48303.patch
|
Patch16: fix-CVE-2022-48303.patch
|
||||||
|
Patch17: add_forgotten-tests.patch
|
||||||
BuildRequires: automake >= 1.15
|
BuildRequires: automake >= 1.15
|
||||||
BuildRequires: libacl-devel
|
BuildRequires: libacl-devel
|
||||||
BuildRequires: libselinux-devel
|
BuildRequires: libselinux-devel
|
||||||
@ -120,24 +112,7 @@ it may as well access remote devices or files.
|
|||||||
%lang_package
|
%lang_package
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
# TODO: Use autosetup
|
%autosetup -p1
|
||||||
%setup -q
|
|
||||||
%patch0 -p1
|
|
||||||
%patch1 -p1
|
|
||||||
%patch2 -p1
|
|
||||||
%patch3 -p1
|
|
||||||
%patch5 -p1
|
|
||||||
%patch6 -p1
|
|
||||||
%patch7 -p1
|
|
||||||
%patch8 -p1
|
|
||||||
%patch9 -p1
|
|
||||||
%patch10 -p1
|
|
||||||
%patch11 -p1
|
|
||||||
%patch12 -p1
|
|
||||||
%patch13 -p1
|
|
||||||
%patch14 -p1
|
|
||||||
%patch15 -p1
|
|
||||||
%patch16 -p1
|
|
||||||
cp %{S:3} tests
|
cp %{S:3} tests
|
||||||
|
|
||||||
%build
|
%build
|
||||||
|
Loading…
Reference in New Issue
Block a user