1 /* xfts.c -- a wrapper for fts_open
3 Copyright (C) 2003, 2005, 2006 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 2, or (at your option)
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, write to the Free Software Foundation,
17 Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */
19 /* Written by Jim Meyering. */
29 #define _(msgid) gettext (msgid)
35 /* Fail with a proper diagnostic if fts_open fails. */
38 xfts_open (char * const *argv
, int options
,
39 int (*compar
) (const FTSENT
**, const FTSENT
**))
41 FTS
*fts
= fts_open (argv
, options
| FTS_CWDFD
, compar
);
44 /* This can fail in three ways: out of memory, invalid bit_flags,
45 and one or more of the FILES is an empty string. We could try
46 to decipher that errno==EINVAL means invalid bit_flags and
47 errno==ENOENT means there's an empty string, but that seems wrong.
48 Ideally, fts_open would return a proper error indicator. For now,
49 we'll presume that the bit_flags are valid and just check for
51 bool invalid_arg
= false;
58 error (EXIT_FAILURE
, 0, _("invalid argument: %s"), quote (""));