90 lines
2.2 KiB
Diff
90 lines
2.2 KiB
Diff
|
--- ctags/jscript.c.orig 2008-10-13 00:27:38.000000000 +0200
|
||
|
+++ ctags/jscript.c 2014-09-30 13:49:34.837349283 +0200
|
||
|
@@ -1,5 +1,5 @@
|
||
|
/*
|
||
|
- * $Id: jscript.c 666 2008-05-15 17:47:31Z dfishburn $
|
||
|
+ * $Id: jscript.c 791 2012-10-24 01:13:13Z dfishburn $
|
||
|
*
|
||
|
* Copyright (c) 2003, Darren Hiebert
|
||
|
*
|
||
|
@@ -215,6 +215,7 @@
|
||
|
* Tag generation functions
|
||
|
*/
|
||
|
|
||
|
+/*
|
||
|
static void makeConstTag (tokenInfo *const token, const jsKind kind)
|
||
|
{
|
||
|
if (JsKinds [kind].enabled && ! token->ignoreTag )
|
||
|
@@ -238,12 +239,13 @@
|
||
|
|
||
|
if (JsKinds [kind].enabled && ! token->ignoreTag )
|
||
|
{
|
||
|
- /*
|
||
|
+ *
|
||
|
* If a scope has been added to the token, change the token
|
||
|
* string to include the scope when making the tag.
|
||
|
- */
|
||
|
+ *
|
||
|
if ( vStringLength(token->scope) > 0 )
|
||
|
{
|
||
|
+ *
|
||
|
fulltag = vStringNew ();
|
||
|
vStringCopy(fulltag, token->scope);
|
||
|
vStringCatS (fulltag, ".");
|
||
|
@@ -251,8 +253,54 @@
|
||
|
vStringTerminate(fulltag);
|
||
|
vStringCopy(token->string, fulltag);
|
||
|
vStringDelete (fulltag);
|
||
|
+ *
|
||
|
+ jsKind parent_kind = JSTAG_CLASS;
|
||
|
+
|
||
|
+ *
|
||
|
+ * if we're creating a function (and not a method),
|
||
|
+ * guess we're inside another function
|
||
|
+ *
|
||
|
+ if (kind == JSTAG_FUNCTION)
|
||
|
+ parent_kind = JSTAG_FUNCTION;
|
||
|
+
|
||
|
+ e.extensionFields.scope[0] = JsKinds [parent_kind].name;
|
||
|
+ e.extensionFields.scope[1] = vStringValue (token->scope);
|
||
|
}
|
||
|
- makeConstTag (token, kind);
|
||
|
+ * makeConstTag (token, kind); *
|
||
|
+ makeTagEntry (&e);
|
||
|
+ }
|
||
|
+}
|
||
|
+*/
|
||
|
+
|
||
|
+static void makeJsTag (tokenInfo *const token, const jsKind kind)
|
||
|
+{
|
||
|
+ if (JsKinds [kind].enabled && ! token->ignoreTag )
|
||
|
+ {
|
||
|
+ const char *const name = vStringValue (token->string);
|
||
|
+ tagEntryInfo e;
|
||
|
+ initTagEntry (&e, name);
|
||
|
+
|
||
|
+ e.lineNumber = token->lineNumber;
|
||
|
+ e.filePosition = token->filePosition;
|
||
|
+ e.kindName = JsKinds [kind].name;
|
||
|
+ e.kind = JsKinds [kind].letter;
|
||
|
+
|
||
|
+ if ( vStringLength(token->scope) > 0 )
|
||
|
+ {
|
||
|
+ jsKind parent_kind = JSTAG_CLASS;
|
||
|
+
|
||
|
+ /*
|
||
|
+ * If we're creating a function (and not a method),
|
||
|
+ * guess we're inside another function
|
||
|
+ */
|
||
|
+ if (kind == JSTAG_FUNCTION)
|
||
|
+ parent_kind = JSTAG_FUNCTION;
|
||
|
+
|
||
|
+ e.extensionFields.scope[0] = JsKinds [parent_kind].name;
|
||
|
+ e.extensionFields.scope[1] = vStringValue (token->scope);
|
||
|
+ }
|
||
|
+
|
||
|
+ makeTagEntry (&e);
|
||
|
}
|
||
|
}
|
||
|
|