(name_file): Removed variable.
(read_name_from_file): Removed function. All callers changed. (name_close): Removed function. All callers changed.
This commit is contained in:
118
src/names.c
118
src/names.c
@@ -212,7 +212,6 @@ name_add (const char *name)
|
||||
|
||||
/* Names from external name file. */
|
||||
|
||||
static FILE *name_file; /* file to read names from */
|
||||
static char *name_buffer; /* buffer to hold the current file name */
|
||||
static size_t name_buffer_length; /* allocated length of name_buffer */
|
||||
|
||||
@@ -233,17 +232,6 @@ name_init (void)
|
||||
{
|
||||
name_buffer = xmalloc (NAME_FIELD_SIZE + 2);
|
||||
name_buffer_length = NAME_FIELD_SIZE;
|
||||
|
||||
if (files_from_option)
|
||||
{
|
||||
if (!strcmp (files_from_option, "-"))
|
||||
{
|
||||
request_stdin ("-T");
|
||||
name_file = stdin;
|
||||
}
|
||||
else if (name_file = fopen (files_from_option, "r"), !name_file)
|
||||
open_fatal (files_from_option);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
@@ -253,47 +241,6 @@ name_term (void)
|
||||
free (name_array);
|
||||
}
|
||||
|
||||
/* Read the next filename from name_file and null-terminate it. Put
|
||||
it into name_buffer, reallocating and adjusting name_buffer_length
|
||||
if necessary. Return 0 at end of file, 1 otherwise. */
|
||||
static int
|
||||
read_name_from_file (void)
|
||||
{
|
||||
int character;
|
||||
size_t counter = 0;
|
||||
|
||||
/* FIXME: getc may be called even if character was EOF the last time here. */
|
||||
|
||||
/* FIXME: This + 2 allocation might serve no purpose. */
|
||||
|
||||
while (character = getc (name_file),
|
||||
character != EOF && character != filename_terminator)
|
||||
{
|
||||
if (counter == name_buffer_length)
|
||||
{
|
||||
if (name_buffer_length * 2 < name_buffer_length)
|
||||
xalloc_die ();
|
||||
name_buffer_length *= 2;
|
||||
name_buffer = xrealloc (name_buffer, name_buffer_length + 2);
|
||||
}
|
||||
name_buffer[counter++] = character;
|
||||
}
|
||||
|
||||
if (counter == 0 && character == EOF)
|
||||
return 0;
|
||||
|
||||
if (counter == name_buffer_length)
|
||||
{
|
||||
if (name_buffer_length * 2 < name_buffer_length)
|
||||
xalloc_die ();
|
||||
name_buffer_length *= 2;
|
||||
name_buffer = xrealloc (name_buffer, name_buffer_length + 2);
|
||||
}
|
||||
name_buffer[counter] = '\0';
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
/* Get the next name from ARGV or the file of names. Result is in
|
||||
static storage and can't be relied upon across two calls.
|
||||
|
||||
@@ -311,40 +258,28 @@ name_next (int change_dirs)
|
||||
if (filename_terminator == '\0')
|
||||
change_dirs = 0;
|
||||
|
||||
while (1)
|
||||
while (name_index != names)
|
||||
{
|
||||
/* Get a name, either from file or from saved arguments. */
|
||||
|
||||
if (name_index == names)
|
||||
size_t source_len;
|
||||
source = name_array[name_index++];
|
||||
source_len = strlen (source);
|
||||
if (name_buffer_length < source_len)
|
||||
{
|
||||
if (! name_file)
|
||||
break;
|
||||
if (! read_name_from_file ())
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
size_t source_len;
|
||||
source = name_array[name_index++];
|
||||
source_len = strlen (source);
|
||||
if (name_buffer_length < source_len)
|
||||
{
|
||||
do
|
||||
{
|
||||
name_buffer_length *= 2;
|
||||
if (! name_buffer_length)
|
||||
xalloc_die ();
|
||||
}
|
||||
while (name_buffer_length < source_len);
|
||||
|
||||
free (name_buffer);
|
||||
name_buffer = xmalloc (name_buffer_length + 2);
|
||||
do
|
||||
{
|
||||
name_buffer_length *= 2;
|
||||
if (! name_buffer_length)
|
||||
xalloc_die ();
|
||||
}
|
||||
strcpy (name_buffer, source);
|
||||
while (name_buffer_length < source_len);
|
||||
|
||||
free (name_buffer);
|
||||
name_buffer = xmalloc (name_buffer_length + 2);
|
||||
}
|
||||
strcpy (name_buffer, source);
|
||||
|
||||
/* Zap trailing slashes. */
|
||||
|
||||
|
||||
cursor = name_buffer + strlen (name_buffer) - 1;
|
||||
while (cursor > name_buffer && ISSLASH (*cursor))
|
||||
*cursor-- = '\0';
|
||||
@@ -359,30 +294,17 @@ name_next (int change_dirs)
|
||||
chdir_flag = 1;
|
||||
else
|
||||
{
|
||||
unquote_string (name_buffer);
|
||||
if (unquote_option)
|
||||
unquote_string (name_buffer);
|
||||
if (incremental_option)
|
||||
register_individual_file (name_buffer);
|
||||
return name_buffer;
|
||||
}
|
||||
}
|
||||
|
||||
/* No more names in file. */
|
||||
|
||||
if (name_file && chdir_flag)
|
||||
FATAL_ERROR ((0, 0, _("Missing file name after -C")));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Close the name file, if any. */
|
||||
void
|
||||
name_close (void)
|
||||
{
|
||||
if (name_file && name_file != stdin)
|
||||
if (fclose (name_file) != 0)
|
||||
close_error (name_buffer);
|
||||
}
|
||||
|
||||
/* Gather names in a list for scanning. Could hash them later if we
|
||||
really care.
|
||||
|
||||
@@ -557,14 +479,14 @@ name_match (const char *file_name)
|
||||
struct name *cursor = namelist;
|
||||
|
||||
if (!cursor)
|
||||
return ! files_from_option;
|
||||
return 1;
|
||||
|
||||
if (cursor->fake)
|
||||
{
|
||||
chdir_do (cursor->change_dir);
|
||||
namelist = 0;
|
||||
nametail = &namelist;
|
||||
return ! files_from_option;
|
||||
return 1;
|
||||
}
|
||||
|
||||
cursor = namelist_match (file_name, length);
|
||||
|
||||
Reference in New Issue
Block a user