]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
Fix a bug in how pr -m -s works.
authorJim Meyering <jim@meyering.net>
Sun, 18 Mar 2007 15:21:26 +0000 (16:21 +0100)
committerJim Meyering <jim@meyering.net>
Sun, 18 Mar 2007 15:21:26 +0000 (16:21 +0100)
* NEWS: Describe how the fix affects pr.
* src/pr.c (init_parameters): The --merge (-m) option does
not imply --expand-tabs (-e), so don't set "untabify_input".
Reported by Wis Macomson.
* tests/misc/pr: New file.  Test for the above fix.
* tests/misc/Makefile.am (TESTS): Add pr.
* THANKS: Update.

ChangeLog
NEWS
THANKS
src/pr.c
tests/misc/Makefile.am
tests/misc/pr [new file with mode: 0755]

index c061c929160e2313d3cc46cce07101a88281dedc..aad91cfd7c208950955c7203abcd218595e054ca 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,14 @@
+2007-03-18  Jim Meyering  <jim@meyering.net>
+
+       Fix a bug in how pr -m -s works.
+       * NEWS: Describe how the fix affects pr.
+       * src/pr.c (init_parameters): The --merge (-m) option does
+       not imply --expand-tabs (-e), so don't set "untabify_input".
+       Reported by Wis Macomson.
+       * tests/misc/pr: New file.  Test for the above fix.
+       * tests/misc/Makefile.am (TESTS): Add pr.
+       * THANKS: Update.
+
 2007-03-17  Jim Meyering  <jim@meyering.net>
 
        Detect use of AC_CONFIG_AUX_DIR also when its argument is quoted.
diff --git a/NEWS b/NEWS
index 57c51e12873e056b9cf0b2f66063a49ffff661f4..4efb18f213097ec47785bcecc6550de5d6d5176a 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -10,6 +10,10 @@ GNU coreutils NEWS                                    -*- outline -*-
   the DF_BLOCK_SIZE, BLOCK_SIZE, and BLOCKSIZE environment variables.  It
   is still affected by POSIXLY_CORRECT, though.
 
+  Using pr -m -s (i.e. merging files, with TAB as the output separator)
+  no longer inserts extraneous spaces between output columns.
+
+
 * Noteworthy changes in release 6.8 (2007-02-24) [not-unstable]
 
 ** Bug fixes
diff --git a/THANKS b/THANKS
index 1d7aae34146a7a2533fa9016a7021f4140ea8f46..ad05b13503128223c486e1836a362e8af992c913 100644 (file)
--- a/THANKS
+++ b/THANKS
@@ -519,6 +519,7 @@ William Bader                       william@nscs.fast.net
 William Dowling                     will@franklin.com
 William Lewis                       wiml@omnigroup.com
 wiregauze                           wiregauze@yahoo.com
+Wis Macomson                        wis.macomson@intel.com
 Wojciech Purczynski                 cliph@isec.pl
 Wolfram Kleff                       kleff@cs.uni-bonn.de
 Won-kyu Park                        wkpark@chem.skku.ac.kr
index bd694f49f5ea0a96f44aac2420a5e029cead23c1..e0aea224e493dc90769408824d4c09a7f6172fb0 100644 (file)
--- a/src/pr.c
+++ b/src/pr.c
@@ -1,5 +1,5 @@
 /* pr -- convert text files for printing.
-   Copyright (C) 88, 91, 1995-2006 Free Software Foundation, Inc.
+   Copyright (C) 88, 91, 1995-2007 Free Software Foundation, Inc.
 
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
@@ -1265,7 +1265,6 @@ init_parameters (int number_of_files)
         col_sep_string = column_separator;
 
       truncate_lines = true;
-      untabify_input = true;
       tabify_output = true;
     }
   else
index 1aa3516f8d313c3fc9fa0037ad9270afa95fc062..4d6a754a8ca52acde7dcb030a5ae936e15431932 100644 (file)
@@ -40,6 +40,7 @@ TESTS_ENVIRONMENT = \
 # will execute the test script rather than the standard utility.
 
 TESTS = \
+  pr \
   df-P \
   pwd-unreadable-parent \
   cut \
diff --git a/tests/misc/pr b/tests/misc/pr
new file mode 100755 (executable)
index 0000000..a40ea31
--- /dev/null
@@ -0,0 +1,61 @@
+#!/bin/sh
+# -*- perl -*-
+# Exercise a bug with pr -m -s
+
+# Copyright (C) 2007 Free Software Foundation, Inc.
+
+# This program 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 2 of the License, or
+# (at your option) any later version.
+
+# This program 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, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+
+: ${PERL=perl}
+: ${srcdir=.}
+
+. $srcdir/../envvar-check
+
+$PERL -e 1 > /dev/null 2>&1 || {
+  echo 1>&2 "$0: configure didn't find a usable version of Perl," \
+    "so can't run this test"
+  exit 77
+}
+
+exec $PERL -w -I$srcdir/.. -MCoreutils -- - <<\EOF
+#/
+require 5.003;
+use strict;
+
+(my $program_name = $0) =~ s|.*/||;
+
+$ENV{PROG} = 'pr';
+my $ME = $ENV{PROG};
+
+# Turn off localization of executable's ouput.
+@ENV{qw(LANGUAGE LANG LC_ALL)} = ('C') x 3;
+
+my @Tests =
+  (
+   ['merge-w-tabs', '-m -s -t',
+    {IN=>{1=>"a\tb\tc\n"}},
+    {IN=>{2=>"m\tn\to\n"}},
+    {IN=>{3=>"x\ty\tz\n"}},
+     {OUT=>join("\t", qw(a b c m n o x y z)) . "\n"} ],
+  );
+
+my $save_temps = $ENV{DEBUG};
+my $verbose = $ENV{VERBOSE};
+
+my $prog = $ENV{PROG} || die "$0: \$PROG not specified in environment\n";
+my $fail = run_tests ($program_name, $prog, \@Tests, $save_temps, $verbose);
+exit $fail;
+EOF