GrovyDoc API
authorMaxim Medvedev <maxim.medvedev@jetbrains.com>
Tue, 26 Jan 2010 11:49:33 +0000 (14:49 +0300)
committerMaxim Medvedev <maxim.medvedev@jetbrains.com>
Tue, 26 Jan 2010 11:49:33 +0000 (14:49 +0300)
plugins/groovy/src/org/jetbrains/plugins/groovy/lang/groovydoc/psi/impl/GrDocCommentImpl.java
plugins/groovy/src/org/jetbrains/plugins/groovy/lang/groovydoc/psi/impl/GrDocInlinedTagImpl.java
plugins/groovy/src/org/jetbrains/plugins/groovy/lang/groovydoc/psi/impl/GrDocTagImpl.java

index 8199967bdd505ce77188fdac492aaeec2c11d82a..a71b2b1342b076d44a23649df68ddebabea8058a 100644 (file)
@@ -21,6 +21,7 @@ import com.intellij.psi.PsiElement;
 import com.intellij.psi.impl.source.tree.LazyParseablePsiElement;
 import com.intellij.psi.tree.IElementType;
 import com.intellij.psi.util.PsiTreeUtil;
+import com.intellij.util.text.CharArrayUtil;
 import org.jetbrains.annotations.NonNls;
 import org.jetbrains.annotations.NotNull;
 import org.jetbrains.annotations.Nullable;
@@ -90,7 +91,7 @@ public class GrDocCommentImpl extends LazyParseablePsiElement implements GroovyD
     if (!getText().contains(name)) return GrDocTag.EMPTY_ARRAY;
     ArrayList<GrDocTag> list = new ArrayList<GrDocTag>();
     for (PsiElement e = getFirstChild(); e != null; e = e.getNextSibling()) {
-      if (e instanceof GrDocTag && ((GrDocTag)e).getName().equals(name)) {
+      if (e instanceof GrDocTag && CharArrayUtil.regionMatches(((GrDocTag)e).getName(), 1, name)) {
         list.add((GrDocTag)e);
       }
     }
index 73f2c18d377cc58adfe7f4b0cc165bdb9909aa16..d64d54787176079b5cc63019ca172e526ea9af25 100644 (file)
@@ -18,23 +18,29 @@ package org.jetbrains.plugins.groovy.lang.groovydoc.psi.impl;
 
 import com.intellij.lang.ASTNode;
 import com.intellij.psi.PsiElement;
+import com.intellij.psi.tree.TokenSet;
 import com.intellij.util.IncorrectOperationException;
 import org.jetbrains.annotations.NonNls;
 import org.jetbrains.annotations.NotNull;
-import org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocComment;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocInlinedTag;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocTagValueToken;
-import org.jetbrains.plugins.groovy.lang.parser.GroovyElementTypes;
 import org.jetbrains.plugins.groovy.lang.psi.GroovyElementVisitor;
 import org.jetbrains.plugins.groovy.lang.psi.GroovyPsiElementFactory;
 
 import java.util.List;
 
+import static org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes.mGDOC_COMMENT_DATA;
+import static org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes.mGDOC_TAG_VALUE_TOKEN;
+import static org.jetbrains.plugins.groovy.lang.groovydoc.parser.GroovyDocElementTypes.*;
+
 /**
  * @author ilyas
  */
 public class GrDocInlinedTagImpl extends GroovyDocPsiElementImpl implements GrDocInlinedTag {
+  private static final TokenSet VALUE_BIT_SET = TokenSet
+    .create(mGDOC_TAG_VALUE_TOKEN, GDOC_METHOD_REF, GDOC_FIELD_REF, GDOC_PARAM_REF, GDOC_REFERENCE_ELEMENT, mGDOC_COMMENT_DATA,
+            GDOC_INLINED_TAG);
 
   public GrDocInlinedTagImpl(@NotNull ASTNode node) {
     super(node);
@@ -55,7 +61,7 @@ public class GrDocInlinedTagImpl extends GroovyDocPsiElementImpl implements GrDo
 
   @NotNull
   public PsiElement getNameElement() {
-    PsiElement element = findChildByType(GroovyDocTokenTypes.mGDOC_TAG_NAME);
+    PsiElement element = findChildByType(mGDOC_TAG_NAME);
     assert element != null;
     return element;
   }
@@ -69,7 +75,7 @@ public class GrDocInlinedTagImpl extends GroovyDocPsiElementImpl implements GrDo
   }
 
   public PsiElement[] getDataElements() {
-    final List<PsiElement> list = findChildrenByType(GroovyElementTypes.mGDOC_COMMENT_DATA);
+    final List<PsiElement> list = findChildrenByType(VALUE_BIT_SET);
     return list.toArray(new PsiElement[list.size()]);
   }
 
index 033b8b3b6dee192f378dbc39cab186b06df12057..51108d27cdb80a7d5c97d7f4c797f7732f3f5c7a 100644 (file)
@@ -18,24 +18,31 @@ package org.jetbrains.plugins.groovy.lang.groovydoc.psi.impl;
 
 import com.intellij.lang.ASTNode;
 import com.intellij.psi.PsiElement;
+import com.intellij.psi.tree.TokenSet;
 import com.intellij.util.IncorrectOperationException;
 import org.jetbrains.annotations.NonNls;
 import org.jetbrains.annotations.NotNull;
-import org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocComment;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocParameterReference;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocTag;
 import org.jetbrains.plugins.groovy.lang.groovydoc.psi.api.GrDocTagValueToken;
-import org.jetbrains.plugins.groovy.lang.parser.GroovyElementTypes;
 import org.jetbrains.plugins.groovy.lang.psi.GroovyElementVisitor;
 import org.jetbrains.plugins.groovy.lang.psi.GroovyPsiElementFactory;
 
 import java.util.List;
 
+import static org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes.mGDOC_COMMENT_DATA;
+import static org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes.mGDOC_TAG_NAME;
+import static org.jetbrains.plugins.groovy.lang.groovydoc.lexer.GroovyDocTokenTypes.mGDOC_TAG_VALUE_TOKEN;
+import static org.jetbrains.plugins.groovy.lang.parser.GroovyElementTypes.*;
+
 /**
  * @author ilyas
  */
 public class GrDocTagImpl extends GroovyDocPsiElementImpl implements GrDocTag {
+  private static final TokenSet VALUE_BIT_SET = TokenSet
+    .create(mGDOC_TAG_VALUE_TOKEN, GDOC_METHOD_REF, GDOC_FIELD_REF, GDOC_PARAM_REF, GDOC_REFERENCE_ELEMENT, mGDOC_COMMENT_DATA,
+            GDOC_INLINED_TAG);
 
   public GrDocTagImpl(@NotNull ASTNode node) {
     super(node);
@@ -56,7 +63,7 @@ public class GrDocTagImpl extends GroovyDocPsiElementImpl implements GrDocTag {
 
   @NotNull
   public PsiElement getNameElement() {
-    PsiElement element = findChildByType(GroovyDocTokenTypes.mGDOC_TAG_NAME);
+    PsiElement element = findChildByType(mGDOC_TAG_NAME);
     assert element != null;
     return element;
   }
@@ -73,7 +80,7 @@ public class GrDocTagImpl extends GroovyDocPsiElementImpl implements GrDocTag {
   }
 
   public PsiElement[] getDataElements() {
-    final List<PsiElement> list = findChildrenByType(GroovyElementTypes.mGDOC_COMMENT_DATA);
+    final List<PsiElement> list = findChildrenByType(VALUE_BIT_SET);
     return list.toArray(new PsiElement[list.size()]);
   }