From b4bd8d00d929d196a265e4a0cb813a3f3897f379 Mon Sep 17 00:00:00 2001 From: Tim Waugh Date: Mon, 30 Jun 2008 12:02:59 +0000 Subject: [PATCH] - Don't fail if setfilecon() returns EPERM (bug #453365), although the setfilecon man page suggests that ENOTSUP will be returned in this case. --- patch-selinux.patch | 15 ++++----------- patch.spec | 7 ++++++- 2 files changed, 10 insertions(+), 12 deletions(-) diff --git a/patch-selinux.patch b/patch-selinux.patch index 86538af..afebcf3 100644 --- a/patch-selinux.patch +++ b/patch-selinux.patch @@ -1,21 +1,19 @@ -diff -up patch-2.5.4/patch.c.selinux patch-2.5.4/patch.c ---- patch-2.5.4/patch.c.selinux 2008-06-12 11:09:17.000000000 +0100 -+++ patch-2.5.4/patch.c 2008-06-12 11:09:17.000000000 +0100 -@@ -414,6 +414,13 @@ main (int argc, char **argv) +--- patch-2.5.4/patch.c 2008-06-12 11:09:17.000000000 +0100 ++++ patch-2.5.4/patch.c 2008-06-30 10:56:48.000000000 +0100 +@@ -414,6 +414,13 @@ if (! inerrno && chmod (outname, instat.st_mode) != 0) pfatal ("Can't set permissions on file %s", quotearg (outname)); + if (! inerrno && incontext && + setfilecon (outname, incontext) != 0) + { -+ if (errno != ENODATA && errno != ENOTSUP) ++ if (errno != ENOTSUP && errno != EPERM) + pfatal ("Can't set security context on file %s", + quotearg (outname)); + } } } } -diff -up patch-2.5.4/util.c.selinux patch-2.5.4/util.c --- patch-2.5.4/util.c.selinux 2008-06-12 11:09:17.000000000 +0100 +++ patch-2.5.4/util.c 2008-06-12 11:12:01.000000000 +0100 @@ -375,7 +375,8 @@ version_controller (char const *filename @@ -42,7 +40,6 @@ diff -up patch-2.5.4/util.c.selinux patch-2.5.4/util.c } return 1; -diff -up patch-2.5.4/util.h.selinux patch-2.5.4/util.h --- patch-2.5.4/util.h.selinux 1999-08-30 07:20:08.000000000 +0100 +++ patch-2.5.4/util.h 2008-06-12 11:09:17.000000000 +0100 @@ -21,7 +21,7 @@ char *fetchname PARAMS ((char *, int, ti @@ -54,7 +51,6 @@ diff -up patch-2.5.4/util.h.selinux patch-2.5.4/util.h int create_file PARAMS ((char const *, int, mode_t)); int systemic PARAMS ((char const *)); char *format_linenum PARAMS ((char[LINENUM_LENGTH_BOUND + 1], LINENUM)); -diff -up patch-2.5.4/Makefile.in.selinux patch-2.5.4/Makefile.in --- patch-2.5.4/Makefile.in.selinux 1999-08-30 07:37:54.000000000 +0100 +++ patch-2.5.4/Makefile.in 2008-06-12 11:09:17.000000000 +0100 @@ -36,7 +36,7 @@ DEFS = @DEFS@ @@ -66,7 +62,6 @@ diff -up patch-2.5.4/Makefile.in.selinux patch-2.5.4/Makefile.in PACKAGE = @PACKAGE@ U = @U@ VERSION = @VERSION@ -diff -up patch-2.5.4/inp.c.selinux patch-2.5.4/inp.c --- patch-2.5.4/inp.c.selinux 2008-06-12 11:09:17.000000000 +0100 +++ patch-2.5.4/inp.c 2008-06-12 11:11:08.000000000 +0100 @@ -154,7 +154,20 @@ get_input_file (char const *filename, ch @@ -108,7 +103,6 @@ diff -up patch-2.5.4/inp.c.selinux patch-2.5.4/inp.c } else if (! S_ISREG (instat.st_mode)) fatal ("File %s is not a regular file -- can't patch", -diff -up patch-2.5.4/pch.c.selinux patch-2.5.4/pch.c --- patch-2.5.4/pch.c.selinux 2008-06-12 11:09:17.000000000 +0100 +++ patch-2.5.4/pch.c 2008-06-12 11:11:48.000000000 +0100 @@ -258,7 +258,12 @@ there_is_another_patch (void) @@ -142,7 +136,6 @@ diff -up patch-2.5.4/pch.c.selinux patch-2.5.4/pch.c } for (i = OLD; i <= INDEX; i++) -diff -up patch-2.5.4/common.h.selinux patch-2.5.4/common.h --- patch-2.5.4/common.h.selinux 1999-08-30 07:20:08.000000000 +0100 +++ patch-2.5.4/common.h 2008-06-12 11:09:17.000000000 +0100 @@ -39,6 +39,8 @@ diff --git a/patch.spec b/patch.spec index 13d7c0b..62a3c34 100644 --- a/patch.spec +++ b/patch.spec @@ -1,7 +1,7 @@ Summary: The GNU patch command, for modifying/upgrading files Name: patch Version: 2.5.4 -Release: 34%{?dist} +Release: 35%{?dist} License: GPLv2+ URL: http://www.gnu.org/software/patch/patch.html Group: Development/Tools @@ -68,6 +68,11 @@ rm -rf $RPM_BUILD_ROOT %{_mandir}/*/* %changelog +* Mon Jun 30 2008 Tim Waugh 2.5.4-35 +- Don't fail if setfilecon() returns EPERM (bug #453365), although the + setfilecon man page suggests that ENOTSUP will be returned in this + case. + * Mon Jun 16 2008 Tim Waugh 2.5.4-34 - Only write simple backups for each file once during a run (bug #234822).