ep->type = NELT_FILE;
ep->v.file.name = name;
ep->v.file.term = term;
+ ep->v.file.fp = NULL;
}
\f
/* Names from external name file. */
static struct file_id_list *file_id_list;
-static void
+static int
add_file_id (const char *filename)
{
struct file_id_list *p;
for (p = file_id_list; p; p = p->next)
if (p->ino == st.st_ino && p->dev == st.st_dev)
{
- FATAL_ERROR ((0, 0, _("%s: file list already read"),
- quotearg_colon (filename)));
+ ERROR ((0, 0, _("%s: file list already read"),
+ quotearg_colon (filename)));
+ return 1;
}
p = xmalloc (sizeof *p);
p->next = file_id_list;
p->ino = st.st_ino;
p->dev = st.st_dev;
file_id_list = p;
+ return 0;
}
\f
enum read_file_list_state /* Result of reading file name from the list file */
if (wordsplit (str, &ws, WRDSF_DEFFLAGS|WRDSF_DOOFFS))
FATAL_ERROR ((0, 0, _("cannot split string '%s': %s"),
str, wordsplit_strerror (&ws)));
- ws.ws_wordv[0] = "tar";
+ ws.ws_wordv[0] = program_invocation_short_name;
more_options (ws.ws_wordc+ws.ws_offs, ws.ws_wordv);
for (i = 0; i < ws.ws_wordc+ws.ws_offs; i++)
ws.ws_wordv[i] = NULL;
static int
read_next_name (struct name_elt *ent, struct name_elt *ret)
{
- enum read_file_list_state read_state;
-
if (!ent->v.file.fp)
{
if (!strcmp (ent->v.file.name, "-"))
}
else
{
- add_file_id (ent->v.file.name);
+ if (add_file_id (ent->v.file.name))
+ return 1;
if ((ent->v.file.fp = fopen (ent->v.file.name, "r")) == NULL)
open_fatal (ent->v.file.name);
}
struct name_elt *ep;
ep = &name_array[scanned];
- if (ep->type == NELT_FMASK)
+
+ switch (ep->type)
{
+ case NELT_FMASK:
matching_flags = ep->v.matching_flags;
++scanned;
continue;
- }
-
- switch (ep->type)
- {
+
case NELT_FILE:
if (read_next_name (ep, &entry) == 0)
return &entry;