summaryrefslogtreecommitdiff
path: root/lib-src
diff options
context:
space:
mode:
authorFrancesco Potortì <pot@gnu.org>1995-06-21 12:15:15 +0000
committerFrancesco Potortì <pot@gnu.org>1995-06-21 12:15:15 +0000
commitb2db879bf58809ab78845c7f8932d58041a1ff67 (patch)
tree8e72ff07a57cf004c7fddb5c80d20883833a214d /lib-src
parent87180daee694962c6bd3e9ab642406296e2dfd51 (diff)
downloademacs-b2db879bf58809ab78845c7f8932d58041a1ff67.tar.gz
* etags.c (find_entries): rewind before rereading the input file.
Diffstat (limited to 'lib-src')
-rw-r--r--lib-src/etags.c26
1 files changed, 14 insertions, 12 deletions
diff --git a/lib-src/etags.c b/lib-src/etags.c
index 7c049568a2a..9a17863c457 100644
--- a/lib-src/etags.c
+++ b/lib-src/etags.c
@@ -110,6 +110,13 @@ extern int errno;
#define intoken(arg) (_itk[arg]) /* T if char can be in token */
#define endtoken(arg) (_etk[arg]) /* T if char ends tokens */
+#ifdef DOS_NT
+# define absolutefn(fn) (fn[0] == '/' || (isalpha (fn[0]) && fn[1] == ':'))
+#else
+# define absolutefn(fn) (fn[0] == '/')
+#endif
+
+
/*
* xnew -- allocate storage
*
@@ -392,7 +399,7 @@ struct lang_entry lang_extensions[] =
{ "cs", Cstar_entries },
{ "hs", Cstar_entries },
- /* .f and .for are FORTRAN. */
+ /* .F, .f and .for are FORTRAN. */
{ "F", Fortran_functions },
{ "f", Fortran_functions },
{ "for", Fortran_functions },
@@ -1033,11 +1040,7 @@ process_file (file)
{
char *filename;
-#ifdef DOS_NT
- if (file[0] == '/' || (isalpha (file[0]) && file[1] == ':'))
-#else
- if (file[0] == '/')
-#endif
+ if (absolutefn (file))
{
/* file is an absolute filename. Canonicalise it. */
filename = absolute_filename (file, cwd);
@@ -1131,7 +1134,10 @@ find_entries (file, inf)
/* No Fortran entries found. Try C. */
if (old_last_node == last_node)
- default_C_entries (inf);
+ {
+ rewind (inf);
+ default_C_entries (inf);
+ }
fclose (inf);
}
@@ -3751,11 +3757,7 @@ absolute_filename (file, cwd)
{
char *slashp, *cp, *res;
-#ifdef DOS_NT
- if (file[0] == '/' || (isalpha (file[0]) && file[1] == ':'))
-#else
- if (file[0] == '/')
-#endif
+ if (absolutefn (file))
res = concat (file, "", "");
else
res = concat (cwd, file, "");