From 9c393fa1944e5decb2838de7cbcf6b371717fd77 Mon Sep 17 00:00:00 2001 From: Ondřej Vašík Date: Mon, 10 Mar 2008 17:03:41 +0100 Subject: install, rmdir: write --verbose output to stdout, not to stderr. MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * src/install.c (announce_mkdir): Write verbose output to stdout, not to stderr. * src/mkdir.c (announce mkdir): Use prog_fprintf for verbose output. * src/prog-fprintf.c (prog_fprintf): New function and file. * src/prog-fprintf.h: New file. * src/rmdir.c (main): Write verbose output to stdout, not to stderr. Quote directory name in a diagnostic. * src/rmdir.c (remove_parents): Write verbose output to stdout, not to stderr. * doc/coreutils.texi: Mention that shred verbose output is to stderr. * NEWS: Mention the changes. Signed-off-by: Ondřej Vašík --- src/Makefile.am | 6 +++++- src/install.c | 5 +++-- src/mkdir.c | 16 ++-------------- src/prog-fprintf.c | 37 +++++++++++++++++++++++++++++++++++++ src/prog-fprintf.h | 24 ++++++++++++++++++++++++ src/rmdir.c | 7 ++++--- 6 files changed, 75 insertions(+), 20 deletions(-) create mode 100644 src/prog-fprintf.c create mode 100644 src/prog-fprintf.h (limited to 'src') diff --git a/src/Makefile.am b/src/Makefile.am index c85f85365..44d802e15 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -54,6 +54,7 @@ noinst_HEADERS = \ fs.h \ group-list.h \ ls.h \ + prog-fprintf.h \ remove.h \ system.h \ wheel-size.h \ @@ -203,7 +204,7 @@ copy_sources = copy.c cp-hash.c # to install before applying any user-specified name transformations. transform = s/ginstall/install/; @program_transform_name@ -ginstall_SOURCES = install.c $(copy_sources) +ginstall_SOURCES = install.c prog-fprintf.c $(copy_sources) # This is for the '[' program. Automake transliterates '[' to '_'. __SOURCES = lbracket.c @@ -221,6 +222,9 @@ chgrp_SOURCES = chgrp.c chown-core.c mv_SOURCES = mv.c remove.c $(copy_sources) rm_SOURCES = rm.c remove.c +mkdir_SOURCES = mkdir.c prog-fprintf.c +rmdir_SOURCES = rmdir.c prog-fprintf.c + uname_SOURCES = uname.c uname-uname.c arch_SOURCES = uname.c uname-arch.c diff --git a/src/install.c b/src/install.c index db08751e4..1d04373b1 100644 --- a/src/install.c +++ b/src/install.c @@ -1,5 +1,5 @@ /* install - copy files and set attributes - Copyright (C) 89, 90, 91, 1995-2007 Free Software Foundation, Inc. + Copyright (C) 89, 90, 91, 1995-2008 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 @@ -34,6 +34,7 @@ #include "mkancesdirs.h" #include "mkdir-p.h" #include "modechange.h" +#include "prog-fprintf.h" #include "quote.h" #include "quotearg.h" #include "savewd.h" @@ -762,7 +763,7 @@ announce_mkdir (char const *dir, void *options) { struct cp_options const *x = options; if (x->verbose) - error (0, 0, _("creating directory %s"), quote (dir)); + prog_fprintf (stdout, _("creating directory %s"), quote (dir)); } /* Make ancestor directory DIR, whose last file name component is diff --git a/src/mkdir.c b/src/mkdir.c index 378106501..395259413 100644 --- a/src/mkdir.c +++ b/src/mkdir.c @@ -27,6 +27,7 @@ #include "lchmod.h" #include "mkdir-p.h" #include "modechange.h" +#include "prog-fprintf.h" #include "quote.h" #include "savewd.h" @@ -79,19 +80,6 @@ Mandatory arguments to long options are mandatory for short options too.\n\ exit (status); } -/* Verbose formatted output of variable count of arguments. */ -static void -verbose_output (FILE *fp, char const *fmt, ...) -{ - va_list ap; - fputs (program_name, fp); - fputs (": ", fp); - va_start (ap, fmt); - vfprintf (fp, fmt, ap); - va_end (ap); - fputc ('\n', fp); -} - /* Options passed to subsidiary functions. */ struct mkdir_options { @@ -118,7 +106,7 @@ announce_mkdir (char const *dir, void *options) { struct mkdir_options const *o = options; if (o->created_directory_format) - verbose_output (stdout, o->created_directory_format, quote (dir)); + prog_fprintf (stdout, o->created_directory_format, quote (dir)); } /* Make ancestor directory DIR, whose last component is COMPONENT, diff --git a/src/prog-fprintf.c b/src/prog-fprintf.c new file mode 100644 index 000000000..85aceb61f --- /dev/null +++ b/src/prog-fprintf.c @@ -0,0 +1,37 @@ +/* prog-fprintf.c - common formating output functions and definitions + Copyright (C) 2008 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 . */ + +#include +#include +#include + +#include "prog-fprintf.h" + +extern char *program_name; + +/* Display program name followed by variable list. + Used for e.g. verbose output */ +void +prog_fprintf (FILE *fp, char const *fmt, ...) +{ + va_list ap; + fputs (program_name, fp); + fputs (": ", fp); + va_start (ap, fmt); + vfprintf (fp, fmt, ap); + va_end (ap); + fputc ('\n', fp); +} diff --git a/src/prog-fprintf.h b/src/prog-fprintf.h new file mode 100644 index 000000000..d5c3d425a --- /dev/null +++ b/src/prog-fprintf.h @@ -0,0 +1,24 @@ +/* prog-fprintf.h - common formating output functions and definitions + Copyright (C) 2008 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 . */ + +#ifndef PROG_FPRINTF_H +# define PROG_FPRINTF_H + +# include + +extern void prog_fprintf (FILE *fp, char const *fmt, ...); + +#endif diff --git a/src/rmdir.c b/src/rmdir.c index bb1a0c8b3..5f7f54116 100644 --- a/src/rmdir.c +++ b/src/rmdir.c @@ -1,6 +1,6 @@ /* rmdir -- remove directories - Copyright (C) 90, 91, 1995-2002, 2004, 2005, 2006, 2007 Free Software + Copyright (C) 90, 91, 1995-2002, 2004-2008 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify @@ -30,6 +30,7 @@ #include "system.h" #include "error.h" +#include "prog-fprintf.h" #include "quote.h" /* The official name of this program (e.g., no `g' prefix). */ @@ -134,7 +135,7 @@ remove_parents (char *dir) /* Give a diagnostic for each attempted removal if --verbose. */ if (verbose) - error (0, 0, _("removing directory, %s"), quote (dir)); + prog_fprintf (stdout, _("removing directory, %s"), quote (dir)); ok = (rmdir (dir) == 0); @@ -233,7 +234,7 @@ main (int argc, char **argv) /* Give a diagnostic for each attempted removal if --verbose. */ if (verbose) - error (0, 0, _("removing directory, %s"), dir); + prog_fprintf (stdout, _("removing directory, %s"), quote (dir)); if (rmdir (dir) != 0) { -- cgit v1.2.3-70-g09d2