From: Jim Meyering Date: Fri, 17 Oct 2003 13:41:11 +0000 (+0000) Subject: *** empty log message *** X-Git-Tag: v5.1.0~346 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=50bb29092df49d906e52975fd06d95107366c019;p=thirdparty%2Fcoreutils.git *** empty log message *** --- diff --git a/lib/xfts.c b/lib/xfts.c new file mode 100644 index 0000000000..e90ac6e354 --- /dev/null +++ b/lib/xfts.c @@ -0,0 +1,66 @@ +/* xfts.c -- a wrapper for fts_open + + Copyright (C) 2003 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, 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ + +/* Written by Jim Meyering. */ + +#if HAVE_CONFIG_H +# include +#endif + +#include + +#include "exit.h" +#include "error.h" + +#include "gettext.h" +#define _(msgid) gettext (msgid) + +#include "quote.h" +#include "xalloc.h" +#include "xfts.h" + +/* Fail with a proper diagnostic if fts_open fails. */ + +FTS * +xfts_open (char * const *argv, int options, + int (*compar) (const FTSENT **, const FTSENT **)) +{ + FTS *fts = fts_open (argv, options, compar); + if (fts == NULL) + { + /* This can fail in three ways: out of memory, invalid bit_flags, + and one or more of the FILES is an empty string. We could try + to decipher that errno==EINVAL means invalid bit_flags and + errno==ENOENT means there's an empty string, but that seems wrong. + Ideally, fts_open would return a proper error indicator. For now, + we'll presume that the bit_flags are valid and just check for + empty strings. */ + bool invalid_arg = false; + for (; *argv; ++argv) + { + if (**argv == '\0') + invalid_arg = true; + } + if (invalid_arg) + error (EXIT_FAILURE, 0, _("invalid argument: %s"), quote ("")); + else + xalloc_die (); + } + + return fts; +}