Java 类com.intellij.psi.impl.source.codeStyle.javadoc.CommentFormatter 实例源码

项目:intellij-ce-playground    文件:FormatCommentsProcessor.java   
/**
 * Formats PsiDocComments of current ASTNode element and all his children PsiDocComments
 */
@NotNull
private static TextRange formatCommentsInner(@NotNull Project project, @NotNull ASTNode element, @NotNull final TextRange markedRange) {
  TextRange resultTextRange = markedRange;
  final PsiElement elementPsi = element.getPsi();
  boolean shouldFormat = markedRange.contains(element.getTextRange());

  if (shouldFormat) {
    final ASTNode rangeAnchor;
    // There are two possible cases:
    //   1. Given element correspond to comment's owner (e.g. field or method);
    //   2. Given element corresponds to comment itself;
    // However, doc comment formatter replaces old comment with the new one, hence, old element becomes invalid. That's why we need
    // to calculate text length delta not for the given comment element (it's invalid because removed from the AST tree) but for
    // its parent.
    if (elementPsi instanceof PsiDocComment) {
      rangeAnchor = element.getTreeParent();
    }
    else {
      rangeAnchor = element;
    }
    TextRange before = rangeAnchor.getTextRange();
    new CommentFormatter(project).processComment(element);
    int deltaRange = rangeAnchor.getTextRange().getLength() - before.getLength();
    resultTextRange = new TextRange(markedRange.getStartOffset(), markedRange.getEndOffset() + deltaRange);
  }


  // If element is Psi{Method, Field, DocComment} and was formatted there is no reason to continue - we formatted all possible javadocs.
  // If element is out of range its children are also out of range. So in both cases formatting is finished. It's just for optimization.
  if ((shouldFormat && (elementPsi instanceof  PsiMethod || elementPsi instanceof PsiField || elementPsi instanceof PsiDocComment))
      || markedRange.getEndOffset() < element.getStartOffset())
  {
    return resultTextRange;
  }

  ASTNode current = element.getFirstChildNode();
  while (current != null) {
    // When element is PsiClass its PsiDocComment is formatted up to this moment, so we didn't need to format it again.
    if (!(shouldFormat && current.getPsi() instanceof PsiDocComment && elementPsi instanceof PsiClass)) {
      resultTextRange = formatCommentsInner(project, current, resultTextRange);
    }
    current = current.getTreeNext();
  }

  return resultTextRange;
}
项目:tools-idea    文件:FormatCommentsProcessor.java   
/**
 * Formats PsiDocComments of current ASTNode element and all his children PsiDocComments
 */
@NotNull
private static TextRange formatCommentsInner(@NotNull Project project, @NotNull ASTNode element, @NotNull final TextRange markedRange) {
  TextRange resultTextRange = markedRange;
  final PsiElement elementPsi = element.getPsi();
  boolean shouldFormat = markedRange.contains(element.getTextRange());

  if (shouldFormat) {
    final ASTNode rangeAnchor;
    // There are two possible cases:
    //   1. Given element correspond to comment's owner (e.g. field or method);
    //   2. Given element corresponds to comment itself;
    // However, doc comment formatter replaces old comment with the new one, hence, old element becomes invalid. That's why we need
    // to calculate text length delta not for the given comment element (it's invalid because removed from the AST tree) but for
    // its parent.
    if (elementPsi instanceof PsiDocComment) {
      rangeAnchor = element.getTreeParent();
    }
    else {
      rangeAnchor = element;
    }
    TextRange before = rangeAnchor.getTextRange();
    new CommentFormatter(project).processComment(element);
    int deltaRange = rangeAnchor.getTextRange().getLength() - before.getLength();
    resultTextRange = new TextRange(markedRange.getStartOffset(), markedRange.getEndOffset() + deltaRange);
  }


  // If element is Psi{Method, Field, DocComment} and was formatted there is no reason to continue - we formatted all possible javadocs.
  // If element is out of range its children are also out of range. So in both cases formatting is finished. It's just for optimization.
  if ((shouldFormat && (elementPsi instanceof  PsiMethod || elementPsi instanceof PsiField || elementPsi instanceof PsiDocComment))
      || markedRange.getEndOffset() < element.getStartOffset())
  {
    return resultTextRange;
  }

  ASTNode current = element.getFirstChildNode();
  while (current != null) {
    // When element is PsiClass its PsiDocComment is formatted up to this moment, so we didn't need to format it again.
    if (!(shouldFormat && current.getPsi() instanceof PsiDocComment && elementPsi instanceof PsiClass)) {
      resultTextRange = formatCommentsInner(project, current, resultTextRange);
    }
    current = current.getTreeNext();
  }

  return resultTextRange;
}
项目:consulo-java    文件:FormatCommentsProcessor.java   
/**
 * Formats PsiDocComments of current ASTNode element and all his children PsiDocComments
 */
@NotNull
private static TextRange formatCommentsInner(@NotNull Project project, @NotNull ASTNode element, @NotNull final TextRange markedRange)
{
    TextRange resultTextRange = markedRange;
    final PsiElement elementPsi = element.getPsi();
    boolean shouldFormat = markedRange.contains(element.getTextRange());

    if(shouldFormat)
    {
        final ASTNode rangeAnchor;
        // There are two possible cases:
        //   1. Given element correspond to comment's owner (e.g. field or method);
        //   2. Given element corresponds to comment itself;
        // However, doc comment formatter replaces old comment with the new one, hence, old element becomes invalid. That's why we need
        // to calculate text length delta not for the given comment element (it's invalid because removed from the AST tree) but for
        // its parent.
        if(elementPsi instanceof PsiDocComment)
        {
            rangeAnchor = element.getTreeParent();
        }
        else
        {
            rangeAnchor = element;
        }
        TextRange before = rangeAnchor.getTextRange();
        new CommentFormatter(elementPsi).processComment(element);
        int deltaRange = rangeAnchor.getTextRange().getLength() - before.getLength();
        resultTextRange = new TextRange(markedRange.getStartOffset(), markedRange.getEndOffset() + deltaRange);
    }


    // If element is Psi{Method, Field, DocComment} and was formatted there is no reason to continue - we formatted all possible javadocs.
    // If element is out of range its children are also out of range. So in both cases formatting is finished. It's just for optimization.
    if((shouldFormat && (elementPsi instanceof PsiMethod || elementPsi instanceof PsiField || elementPsi instanceof PsiDocComment)) ||
            markedRange.getEndOffset() < element.getStartOffset())
    {
        return resultTextRange;
    }

    ASTNode current = element.getFirstChildNode();
    while(current != null)
    {
        // When element is PsiClass its PsiDocComment is formatted up to this moment, so we didn't need to format it again.
        if(!(shouldFormat && current.getPsi() instanceof PsiDocComment && elementPsi instanceof PsiClass))
        {
            resultTextRange = formatCommentsInner(project, current, resultTextRange);
        }
        current = current.getTreeNext();
    }

    return resultTextRange;
}