aboutsummaryrefslogtreecommitdiffstats
path: root/lib-src
diff options
context:
space:
mode:
authorKevin Ryde2012-12-02 09:47:56 +0800
committerChong Yidong2012-12-02 09:47:56 +0800
commit1cbaa705e733d496a6eab3a8f1521dec52953fcf (patch)
tree2de3295ab62e7387d56e7e6ae3589138e77c978a /lib-src
parent3e5490f7a5d4f527cfc17b12a15a54774a3e3c19 (diff)
downloademacs-1cbaa705e733d496a6eab3a8f1521dec52953fcf.tar.gz
emacs-1cbaa705e733d496a6eab3a8f1521dec52953fcf.zip
* lib-src/etags.c (Lisp_functions): Skip (defvar foo) declarations
unless the --declarations flag is enabled. (Lisp_help): Update. (skip_name): New function. * doc/emacs/maintaining.texi (Tag Syntax): Mention (defvar foo) handling. * doc/man/etags.1: Mention effect of --declarations in Lisp. Fixes: debbugs:5600
Diffstat (limited to 'lib-src')
-rw-r--r--lib-src/ChangeLog7
-rw-r--r--lib-src/etags.c27
2 files changed, 33 insertions, 1 deletions
diff --git a/lib-src/ChangeLog b/lib-src/ChangeLog
index 294661a6cb3..480ddabd44a 100644
--- a/lib-src/ChangeLog
+++ b/lib-src/ChangeLog
@@ -1,3 +1,10 @@
12012-12-02 Kevin Ryde <user42@zip.com.au>
2
3 * etags.c (Lisp_functions): Skip (defvar foo) declarations unless
4 the --declarations flag is enabled (Bug#5600).
5 (Lisp_help): Update.
6 (skip_name): New function.
7
12012-12-01 Kevin Ryde <user42@zip.com.au> 82012-12-01 Kevin Ryde <user42@zip.com.au>
2 9
3 * etags.c (Perl_functions): Support "use constant" (Bug#5055). 10 * etags.c (Perl_functions): Support "use constant" (Bug#5055).
diff --git a/lib-src/etags.c b/lib-src/etags.c
index ec185c9819f..d393c4d2e4a 100644
--- a/lib-src/etags.c
+++ b/lib-src/etags.c
@@ -353,6 +353,7 @@ static void put_entries (node *);
353static char *concat (const char *, const char *, const char *); 353static char *concat (const char *, const char *, const char *);
354static char *skip_spaces (char *); 354static char *skip_spaces (char *);
355static char *skip_non_spaces (char *); 355static char *skip_non_spaces (char *);
356static char *skip_name (char *);
356static char *savenstr (const char *, int); 357static char *savenstr (const char *, int);
357static char *savestr (const char *); 358static char *savestr (const char *);
358static char *etags_strchr (const char *, int); 359static char *etags_strchr (const char *, int);
@@ -619,7 +620,8 @@ static const char Lisp_help [] =
619"In Lisp code, any function defined with `defun', any variable\n\ 620"In Lisp code, any function defined with `defun', any variable\n\
620defined with `defvar' or `defconst', and in general the first\n\ 621defined with `defvar' or `defconst', and in general the first\n\
621argument of any expression that starts with `(def' in column zero\n\ 622argument of any expression that starts with `(def' in column zero\n\
622is a tag."; 623is a tag.\n\
624The `--declarations' option tags \"(defvar foo)\" constructs too.";
623 625
624static const char *Lua_suffixes [] = 626static const char *Lua_suffixes [] =
625 { "lua", "LUA", NULL }; 627 { "lua", "LUA", NULL };
@@ -4747,6 +4749,19 @@ Lisp_functions (FILE *inf)
4747 if (dbp[0] != '(') 4749 if (dbp[0] != '(')
4748 continue; 4750 continue;
4749 4751
4752 /* "(defvar foo)" is a declaration rather than a definition. */
4753 if (! declarations)
4754 {
4755 char *p = dbp + 1;
4756 if (LOOKING_AT (p, "defvar"))
4757 {
4758 p = skip_name (p); /* past var name */
4759 p = skip_spaces (p);
4760 if (*p == ')')
4761 continue;
4762 }
4763 }
4764
4750 if (strneq (dbp+1, "def", 3) || strneq (dbp+1, "DEF", 3)) 4765 if (strneq (dbp+1, "def", 3) || strneq (dbp+1, "DEF", 3))
4751 { 4766 {
4752 dbp = skip_non_spaces (dbp); 4767 dbp = skip_non_spaces (dbp);
@@ -6307,6 +6322,16 @@ skip_non_spaces (char *cp)
6307 return cp; 6322 return cp;
6308} 6323}
6309 6324
6325/* Skip any chars in the "name" class.*/
6326static char *
6327skip_name (char *cp)
6328{
6329 /* '\0' is a notinname() so loop stops there too */
6330 while (! notinname (*cp))
6331 cp++;
6332 return cp;
6333}
6334
6310/* Print error message and exit. */ 6335/* Print error message and exit. */
6311void 6336void
6312fatal (const char *s1, const char *s2) 6337fatal (const char *s1, const char *s2)