1 /* xfts.c -- a wrapper for fts_open
3 Copyright (C) 2003, 2005-2007, 2009 Free Software Foundation, Inc.
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>. */
18 /* Written by Jim Meyering. */
28 #define _(msgid) gettext (msgid)
34 /* Fail with a proper diagnostic if fts_open fails. */
37 xfts_open (char * const *argv
, int options
,
38 int (*compar
) (const FTSENT
**, const FTSENT
**))
40 FTS
*fts
= fts_open (argv
, options
| FTS_CWDFD
, compar
);
43 /* This can fail in three ways: out of memory, invalid bit_flags,
44 and one or more of the FILES is an empty string. We could try
45 to decipher that errno==EINVAL means invalid bit_flags and
46 errno==ENOENT means there's an empty string, but that seems wrong.
47 Ideally, fts_open would return a proper error indicator. For now,
48 we'll presume that the bit_flags are valid and just check for
50 bool invalid_arg
= false;
57 error (EXIT_FAILURE
, 0, _("invalid argument: %s"), quote (""));