From 1644e589050ddfce4bbd5ebbe10a4e041499e386 Mon Sep 17 00:00:00 2001 From: =?utf8?q?P=C3=A1draig=20Brady?=
Date: Wed, 11 Mar 2009 11:39:33 +0000
Subject: [PATCH] cat: Fix immediate output of processed data
Introduced by commit 790892db, 2006-06-08 "Ensure that cat works ...".
* NEWS: Mention the bugfix.
* src/cat.c (cat): Fix the typo which stopped the writing
of processed data before a blocking read() is done.
* tests/misc/cat-buf: Add to ensure processed data is not buffered.
* tests/Makefile.am: Reference the new test.
---
NEWS | 5 +++++
src/cat.c | 2 +-
tests/Makefile.am | 1 +
tests/misc/cat-buf | 41 +++++++++++++++++++++++++++++++++++++++++
4 files changed, 48 insertions(+), 1 deletion(-)
create mode 100755 tests/misc/cat-buf
diff --git a/NEWS b/NEWS
index b6cdcbce7f..540c5a3cbd 100644
--- a/NEWS
+++ b/NEWS
@@ -4,6 +4,11 @@ GNU coreutils NEWS -*- outline -*-
** Bug fixes
+ cat once again immediately outputs data it has processed.
+ Previously it would have been buffered and only output if enough
+ data was read, or on process exit.
+ [bug introduced in coreutils-6.0]
+
comm's new --check-order option would fail to detect disorder on any pair
of lines where one was a prefix of the other. For example, this would
fail to report the disorder: printf 'Xb\nX\n'>k; comm --check-order k k
diff --git a/src/cat.c b/src/cat.c
index 18fa1f1501..bdc011017b 100644
--- a/src/cat.c
+++ b/src/cat.c
@@ -333,7 +333,7 @@ cat (
input_pending = true;
#endif
- if (input_pending)
+ if (!input_pending)
write_pending (outbuf, &bpout);
/* Read more input into INBUF. */
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 07e9473414..10be0c60fa 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -149,6 +149,7 @@ TESTS = \
misc/wc-files0-from \
misc/wc-files0 \
misc/cat-proc \
+ misc/cat-buf \
misc/base64 \
misc/basename \
misc/close-stdout \
diff --git a/tests/misc/cat-buf b/tests/misc/cat-buf
new file mode 100755
index 0000000000..fb9ae881e1
--- /dev/null
+++ b/tests/misc/cat-buf
@@ -0,0 +1,41 @@
+#!/bin/sh
+# Ensure that cat outputs processed data immediately.
+
+# Copyright (C) 2009 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 3 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, see