summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDoug Goldstein <cardoe@gentoo.org>2013-08-02 13:25:34 +0000
committerDoug Goldstein <cardoe@gentoo.org>2013-08-02 13:25:34 +0000
commit8140d8acd6386e30dd432440a2440c9dde97ff44 (patch)
tree006b82817a9a8985c8ad18a741ddf44d96108355 /sys-devel/patch
parentVersion bump. (diff)
downloadgentoo-2-8140d8acd6386e30dd432440a2440c9dde97ff44.tar.gz
gentoo-2-8140d8acd6386e30dd432440a2440c9dde97ff44.tar.bz2
gentoo-2-8140d8acd6386e30dd432440a2440c9dde97ff44.zip
Fixes to prevent leaving empty directories around when the wrong patch level is used or if --dry-run is specified. bug #478548
(Portage version: 2.1.12.2/cvs/Linux x86_64, signed Manifest commit with key D7DFA8D318FA9AEF!)
Diffstat (limited to 'sys-devel/patch')
-rw-r--r--sys-devel/patch/ChangeLog12
-rw-r--r--sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories-automake.patch25
-rw-r--r--sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories.patch75
-rw-r--r--sys-devel/patch/files/patch-2.7.1-dry-run-mode-create-temp-files-in-temp-dir.patch24
-rw-r--r--sys-devel/patch/patch-2.7.1-r2.ebuild36
5 files changed, 171 insertions, 1 deletions
diff --git a/sys-devel/patch/ChangeLog b/sys-devel/patch/ChangeLog
index 8707bf90b5bb..cba6bf676308 100644
--- a/sys-devel/patch/ChangeLog
+++ b/sys-devel/patch/ChangeLog
@@ -1,6 +1,16 @@
# ChangeLog for sys-devel/patch
# Copyright 1999-2013 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/sys-devel/patch/ChangeLog,v 1.63 2013/05/21 17:35:57 vapier Exp $
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/patch/ChangeLog,v 1.64 2013/08/02 13:25:34 cardoe Exp $
+
+*patch-2.7.1-r2 (02 Aug 2013)
+
+ 02 Aug 2013; Doug Goldstein <cardoe@gentoo.org>
+ +files/patch-2.7.1-Fix-removing-empty-directories-automake.patch,
+ +files/patch-2.7.1-Fix-removing-empty-directories.patch,
+ +files/patch-2.7.1-dry-run-mode-create-temp-files-in-temp-dir.patch,
+ +patch-2.7.1-r2.ebuild:
+ Fixes to prevent leaving empty directories around when the wrong patch level
+ is used or if --dry-run is specified. bug #478548
21 May 2013; Mike Frysinger <vapier@gentoo.org> patch-2.7.1-r1.ebuild:
Do not let $ED from the EAPI mess up the search for `ed` #470210 by Roman
diff --git a/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories-automake.patch b/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories-automake.patch
new file mode 100644
index 000000000000..8a6578e7f7cb
--- /dev/null
+++ b/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories-automake.patch
@@ -0,0 +1,25 @@
+Simple patch to prevent sys-devel/patch needing to depend on autotools to
+be built, which would likely make stage1 people unhappy.
+
+By: Doug Goldstein <cardoe@gentoo.org>
+Ref: bug #478548
+---
+--- a/tests/Makefile.in 2012-09-28 11:41:32.000000000 -0500
++++ b/tests/Makefile.in 2013-07-31 07:55:44.879904245 -0500
+@@ -1104,6 +1104,7 @@
+ reject-format \
+ remember-backup-files \
+ remember-reject-files \
++ remove-directories \
+ symlinks \
+ unmodified-files
+
+@@ -1352,6 +1353,8 @@
+ @p='remember-backup-files'; $(am__check_pre) $(LOG_COMPILE) "$$tst" $(am__check_post)
+ remember-reject-files.log: remember-reject-files
+ @p='remember-reject-files'; $(am__check_pre) $(LOG_COMPILE) "$$tst" $(am__check_post)
++remove-directories.log: remove-directories
++ @p='remove-directories'; $(am__check_pre) $(LOG_COMPILE) "$$tst" $(am__check_post)
+ symlinks.log: symlinks
+ @p='symlinks'; $(am__check_pre) $(LOG_COMPILE) "$$tst" $(am__check_post)
+ unmodified-files.log: unmodified-files
diff --git a/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories.patch b/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories.patch
new file mode 100644
index 000000000000..00193b7ce531
--- /dev/null
+++ b/sys-devel/patch/files/patch-2.7.1-Fix-removing-empty-directories.patch
@@ -0,0 +1,75 @@
+From 2f40ef66bea54be23a24f616cde021d8d7fc25be Mon Sep 17 00:00:00 2001
+From: Andreas Gruenbacher <agruen@linbit.com>
+Date: Sun, 10 Mar 2013 18:02:54 +0000
+Subject: Fix removing empty directories
+
+Reported by Thomas Moschny <thomas.moschny@gmx.de>:
+src/patch.c (main): Temporary output files are created in the same directory as
+the output file. Make sure to remove them before removing empty files and
+their empty ancestor directories; else the directories won't be empty.
+tests/remove-directories: Add directory removal test case.
+tests/Makefile.am (TESTS): Add new test case.
+---
+diff --git a/src/patch.c b/src/patch.c
+index 0255fbb..010c14a 100644
+--- a/src/patch.c
++++ b/src/patch.c
+@@ -646,8 +646,8 @@ main (int argc, char **argv)
+ if (outstate.ofp && (ferror (outstate.ofp) || fclose (outstate.ofp) != 0))
+ write_fatal ();
+ output_files (NULL);
+- delete_files ();
+ cleanup ();
++ delete_files ();
+ if (somefailed)
+ exit (1);
+ return 0;
+diff --git a/tests/Makefile.am b/tests/Makefile.am
+index 5cea52d..cfc4f37 100644
+--- a/tests/Makefile.am
++++ b/tests/Makefile.am
+@@ -50,6 +50,7 @@ TESTS = \
+ reject-format \
+ remember-backup-files \
+ remember-reject-files \
++ remove-directories \
+ symlinks \
+ unmodified-files
+
+diff --git a/tests/remove-directories b/tests/remove-directories
+new file mode 100644
+index 0000000..6acdc49
+--- a/dev/null
++++ b/tests/remove-directories
+@@ -0,0 +1,29 @@
++# Copyright (C) 2013 Free Software Foundation, Inc.
++#
++# Copying and distribution of this file, with or without modification,
++# in any medium, are permitted without royalty provided the copyright
++# notice and this notice are preserved.
++
++. $srcdir/test-lib.sh
++
++require_cat
++use_local_patch
++use_tmpdir
++
++# ==============================================================
++# Remove empty parent diectories when removing a file
++
++mkdir dir
++echo foobar > dir/file
++cat > apatch <<EOF
++--- dir/file
+++++ /dev/null
++@@ -1 +0,0 @@
++-foobar
++EOF
++
++check 'patch -p0 -E < apatch' <<EOF
++patching file dir/file
++EOF
++
++ncheck '! test -e dir'
+--
+cgit v0.9.0.2
diff --git a/sys-devel/patch/files/patch-2.7.1-dry-run-mode-create-temp-files-in-temp-dir.patch b/sys-devel/patch/files/patch-2.7.1-dry-run-mode-create-temp-files-in-temp-dir.patch
new file mode 100644
index 000000000000..e0ce04bcacee
--- /dev/null
+++ b/sys-devel/patch/files/patch-2.7.1-dry-run-mode-create-temp-files-in-temp-dir.patch
@@ -0,0 +1,24 @@
+From afdfa9ec8e5f9acea4afaa0db758a4ed752dbe65 Mon Sep 17 00:00:00 2001
+From: Andreas Gruenbacher <agruen@linbit.com>
+Date: Tue, 30 Jul 2013 10:46:19 +0000
+Subject: In dry-run mode, create temporary files in a temporary directory
+
+* src/util.c (make_tempfile): Do not create temporary files in the final output
+directory when in dry-run mode: the path may be read-only. In addition, we do
+not want to leave intermediary empty output directories around.
+---
+diff --git a/src/util.c b/src/util.c
+index 1cc1a68..0af6013 100644
+--- a/src/util.c
++++ b/src/util.c
+@@ -1599,7 +1599,7 @@ make_tempfile (char const **name, char letter, char const *real_name,
+ int try_makedirs_errno = ENOENT;
+ char *template;
+
+- if (real_name)
++ if (real_name && ! dry_run)
+ {
+ char *dirname, *basename;
+
+--
+cgit v0.9.0.2
diff --git a/sys-devel/patch/patch-2.7.1-r2.ebuild b/sys-devel/patch/patch-2.7.1-r2.ebuild
new file mode 100644
index 000000000000..5268e9f048bd
--- /dev/null
+++ b/sys-devel/patch/patch-2.7.1-r2.ebuild
@@ -0,0 +1,36 @@
+# Copyright 1999-2013 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/sys-devel/patch/patch-2.7.1-r2.ebuild,v 1.1 2013/08/02 13:25:34 cardoe Exp $
+
+EAPI=4
+
+inherit flag-o-matic eutils autotools
+
+DESCRIPTION="Utility to apply diffs to files"
+HOMEPAGE="http://www.gnu.org/software/patch/patch.html"
+SRC_URI="mirror://gnu/patch/${P}.tar.xz"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~amd64-fbsd ~sparc-fbsd ~x86-fbsd ~ppc-aix ~x64-freebsd ~x86-freebsd ~hppa-hpux ~ia64-hpux ~x86-interix ~amd64-linux ~arm-linux ~ia64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
+IUSE="static test xattr"
+
+RDEPEND="xattr? ( sys-apps/attr )"
+DEPEND="${RDEPEND}
+ test? ( sys-apps/ed )"
+
+src_prepare() {
+ epatch "${FILESDIR}/${P}-Fix-removing-empty-directories.patch"
+ epatch "${FILESDIR}/${P}-Fix-removing-empty-directories-automake.patch"
+ epatch "${FILESDIR}/${P}-dry-run-mode-create-temp-files-in-temp-dir.patch"
+}
+
+src_configure() {
+ use static && append-ldflags -static
+
+ # Do not let $ED mess up the search for `ed` 470210.
+ ac_cv_path_ED=$(type -P ed) \
+ econf \
+ $(use_enable xattr) \
+ --program-prefix="$(use userland_BSD && echo g)"
+}