|
@@ -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)
|
|
|
- {
|
|
|
- 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)
|
|
|
{
|
|
|
- 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);
|