From 147167e78f381033ea2827c9646ce511b9ebd95d Mon Sep 17 00:00:00 2001 From: Ondrej Vasik Date: Thu, 27 Mar 2008 14:38:08 +0000 Subject: [PATCH] do not keep system defined LS_COLORS for whole session, some upstream fixes - selinux context in mkdir, backslashes in ptx and paste --- coreutils-6.10-lonebackslash.patch | 103 +++++++++++++++++++++++++++++ coreutils-colorls.csh | 7 +- coreutils-colorls.sh | 4 +- coreutils.spec | 12 +++- 4 files changed, 120 insertions(+), 6 deletions(-) create mode 100644 coreutils-6.10-lonebackslash.patch diff --git a/coreutils-6.10-lonebackslash.patch b/coreutils-6.10-lonebackslash.patch new file mode 100644 index 0000000..effb70a --- /dev/null +++ b/coreutils-6.10-lonebackslash.patch @@ -0,0 +1,103 @@ +diff -urNp coreutils-6.10-orig/src/mkdir.c coreutils-6.10/src/mkdir.c +--- coreutils-6.10-orig/src/mkdir.c 2008-03-27 14:42:40.000000000 +0100 ++++ coreutils-6.10/src/mkdir.c 2008-03-27 14:51:48.000000000 +0100 +@@ -211,7 +211,7 @@ main (int argc, char **argv) + if (scontext && setfscreatecon (scontext) < 0) + error (EXIT_FAILURE, errno, + _("failed to set default file creation context to %s"), +- quote (optarg)); ++ quote (scontext)); + + if (options.make_ancestor_function || specified_mode) + { +diff -urNp coreutils-6.10-orig/src/paste.c coreutils-6.10/src/paste.c +--- coreutils-6.10-orig/src/paste.c 2007-11-25 14:23:31.000000000 +0100 ++++ coreutils-6.10/src/paste.c 2008-03-27 14:47:02.000000000 +0100 +@@ -42,6 +42,7 @@ + #include + #include "system.h" + #include "error.h" ++#include "quotearg.h" + + /* The official name of this program (e.g., no `g' prefix). */ + #define PROGRAM_NAME "paste" +@@ -79,12 +80,17 @@ static struct option const longopts[] = + /* Set globals delims and delim_end. Copy STRPTR to DELIMS, converting + backslash representations of special characters in STRPTR to their actual + values. The set of possible backslash characters has been expanded beyond +- that recognized by the Unix version. */ ++ that recognized by the Unix version. ++ Return 0 upon success. ++ If the string ends in an odd number of backslashes, ignore the ++ final backslash and return nonzero. */ + +-static void ++static int + collapse_escapes (char const *strptr) + { + char *strout = xstrdup (strptr); ++ bool backslash_at_end = false; ++ + delims = strout; + + while (*strptr) +@@ -123,6 +129,15 @@ collapse_escapes (char const *strptr) + *strout++ = '\v'; + break; + ++ case '\\': ++ *strout++ = '\\'; ++ break; ++ ++ case '\0': ++ backslash_at_end = true; ++ goto done; ++ ++ + default: + *strout++ = *strptr; + break; +@@ -130,7 +145,11 @@ collapse_escapes (char const *strptr) + strptr++; + } + } ++ ++ done:; ++ + delim_end = strout; ++ return backslash_at_end ? 1 : 0; + } + + /* Report a write error and exit. */ +@@ -481,7 +500,15 @@ main (int argc, char **argv) + if (optind == argc) + argv[argc++] = "-"; + +- collapse_escapes (delim_arg); ++ if (collapse_escapes (delim_arg)) ++ { ++ /* Don't use the default quoting style, because that would double the ++ number of displayed backslashes, making the diagnostic look bogus. */ ++ set_quoting_style (NULL, escape_quoting_style); ++ error (EXIT_FAILURE, 0, ++ _("delimiter list ends with an unescaped backslash: %s"), ++ quotearg_colon (delim_arg)); ++ } + + if (!serial_merge) + ok = paste_parallel (argc - optind, &argv[optind]); +diff -urNp coreutils-6.10-orig/src/ptx.c coreutils-6.10/src/ptx.c +--- coreutils-6.10-orig/src/ptx.c 2007-11-25 14:23:31.000000000 +0100 ++++ coreutils-6.10/src/ptx.c 2008-03-27 14:53:24.000000000 +0100 +@@ -387,6 +387,11 @@ copy_unescaped_string (const char *strin + string++; + break; + ++ case '\0': /* lone backslash at end of string */ ++ /* ignore it */ ++ break; ++ ++ + default: + *cursor++ = '\\'; + *cursor++ = *string++; diff --git a/coreutils-colorls.csh b/coreutils-colorls.csh index 61e8561..2d259a8 100755 --- a/coreutils-colorls.csh +++ b/coreutils-colorls.csh @@ -1,8 +1,9 @@ #! /bin/csh -f # color-ls initialization -if ( $?LS_COLORS ) then - if ( "$LS_COLORS" != "" ) then - #do not override user specified LS_COLORS and use them +if ( $?USER_LS_COLORS ) then + if ( "$USER_LS_COLORS" != "" ) then + #when USER_LS_COLORS defined do not override user + #specified LS_COLORS and use them goto finish endif endif diff --git a/coreutils-colorls.sh b/coreutils-colorls.sh index 1b3f0bb..5829bfe 100755 --- a/coreutils-colorls.sh +++ b/coreutils-colorls.sh @@ -1,7 +1,7 @@ # color-ls initialization -#do not override user LS_COLORS, but use them. -if [ -z "$LS_COLORS" ]; then +#when USER_LS_COLORS defined do not override user LS_COLORS, but use them. +if [ -z "$USER_LS_COLORS" ]; then alias ll='ls -l' 2>/dev/null alias l.='ls -d .*' 2>/dev/null diff --git a/coreutils.spec b/coreutils.spec index 6f47575..88cd928 100644 --- a/coreutils.spec +++ b/coreutils.spec @@ -1,7 +1,7 @@ Summary: The GNU core utilities: a set of tools commonly used in shell scripts Name: coreutils Version: 6.10 -Release: 15%{?dist} +Release: 16%{?dist} License: GPLv3+ Group: System Environment/Base Url: http://www.gnu.org/software/coreutils/ @@ -21,6 +21,7 @@ Source203: coreutils-runuser-l.pamd Patch1: coreutils-6.10-verbose.patch Patch2: coreutils-dddoubleclose.patch Patch3: coreutils-mvatomic.patch +Patch4: coreutils-6.10-lonebackslash.patch # Our patches Patch100: coreutils-chgrp.patch @@ -101,6 +102,7 @@ cd %name-%version %patch1 -p1 -b .verbose %patch2 -p1 -b .doubleclose %patch3 -p1 -b .atomic +%patch4 -p1 -b .backslash # Our patches %patch100 -p1 -b .chgrp @@ -297,6 +299,14 @@ fi /sbin/runuser %changelog +* Thu Mar 27 2008 Ondrej Vasik - 6.10-16 +- keep LS_COLORS when USER_LS_COLORS defined +- someupstream fixes: +- mkdir -Z invalid-selinux-context dir no longer segfaults +- ptx with odd number of backslashes no longer leads to buffer + overflow +- paste -d'\' file" no longer ovveruns memory + * Wed Mar 26 2008 Ondrej Vasik - 6.10-15 - covered correct handling for some test conditions failures e.g. root build+selinux active and not running mcstrans(d)