當前位置: 首頁>>代碼示例>>Java>>正文


Java Lexer類代碼示例

本文整理匯總了Java中com.intellij.lexer.Lexer的典型用法代碼示例。如果您正苦於以下問題:Java Lexer類的具體用法?Java Lexer怎麽用?Java Lexer使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


Lexer類屬於com.intellij.lexer包,在下文中一共展示了Lexer類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getMergeFunction

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Override
public MergeFunction getMergeFunction() {
  return ((final IElementType type, final Lexer originalLexer) -> {
    if (type == SoyTypes.OTHER || type == TokenType.WHITE_SPACE) {
      IElementType returnType =  type;
      while (originalLexer.getTokenType() == SoyTypes.OTHER
          || originalLexer.getTokenType() == TokenType.WHITE_SPACE) {
        if (originalLexer.getTokenType() == SoyTypes.OTHER) {
          returnType = SoyTypes.OTHER;
        }
        originalLexer.advance();
      }
      return returnType;
    }

    return type;
  });
}
 
開發者ID:google,項目名稱:bamboo-soy,代碼行數:19,代碼來源:SoyLexer.java

示例2: addWordHonoringEscapeSequences

import com.intellij.lexer.Lexer; //導入依賴的package包/類
public static void addWordHonoringEscapeSequences(CharSequence editorText,
                                                  TextRange literalTextRange,
                                                  int cursorOffset,
                                                  Lexer lexer,
                                                  List<TextRange> result) {
  lexer.start(editorText, literalTextRange.getStartOffset(), literalTextRange.getEndOffset());

  while (lexer.getTokenType() != null) {
    if (lexer.getTokenStart() <= cursorOffset && cursorOffset < lexer.getTokenEnd()) {
      if (StringEscapesTokenTypes.STRING_LITERAL_ESCAPES.contains(lexer.getTokenType())) {
        result.add(new TextRange(lexer.getTokenStart(), lexer.getTokenEnd()));
      }
      else {
        TextRange word = getWordSelectionRange(editorText, cursorOffset, JAVA_IDENTIFIER_PART_CONDITION);
        if (word != null) {
          result.add(new TextRange(Math.max(word.getStartOffset(), lexer.getTokenStart()),
                                   Math.min(word.getEndOffset(), lexer.getTokenEnd())));
        }
      }
      break;
    }
    lexer.advance();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:25,代碼來源:SelectWordUtil.java

示例3: checkCorrectRestart

import com.intellij.lexer.Lexer; //導入依賴的package包/類
protected void checkCorrectRestart(String text) {
  Lexer mainLexer = createLexer();
  String allTokens = printTokens(text, 0, mainLexer);

  Lexer auxLexer = createLexer();
  auxLexer.start(text);
  while (true) {
    IElementType type = auxLexer.getTokenType();
    if (type == null) {
      break;
    }
    if (auxLexer.getState() == 0) {
      int tokenStart = auxLexer.getTokenStart();
      String subTokens = printTokens(text, tokenStart, mainLexer);
      if (!allTokens.endsWith(subTokens)) {
        assertEquals("Restarting impossible from offset " + tokenStart + "; lexer state should not return 0 at this point", allTokens, subTokens);
      }
    }
    auxLexer.advance();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:22,代碼來源:LexerTestCase.java

示例4: getMergeFunction

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Override
public MergeFunction getMergeFunction() {
    return new MergeFunction() {

        @Override
        public IElementType merge(IElementType type, Lexer originalLexer) {
            if (!allMergables.contains(type)) {
                return type;
            }

            TokenSet merging = tokensToMerge.contains(type) ? tokensToMerge : tokensToMerge2;

            while (true) {
                final IElementType tokenType = originalLexer.getTokenType();
                if (!merging.contains(tokenType)) break;
                originalLexer.advance();
            }

            return merging == tokensToMerge ? LONGSTRING : LONGCOMMENT;
        }
    };
}
 
開發者ID:internetisalie,項目名稱:lua-for-idea,代碼行數:23,代碼來源:LuaParsingLexerMergingAdapter.java

示例5: createAST

import com.intellij.lexer.Lexer; //導入依賴的package包/類
private ASTNode createAST(String text) {
  ParserDefinition definition = new BuildParserDefinition();
  PsiParser parser = definition.createParser(getProject());
  Lexer lexer = definition.createLexer(getProject());
  PsiBuilderImpl psiBuilder =
      new PsiBuilderImpl(
          getProject(), null, definition, lexer, new CharTableImpl(), text, null, null);
  PsiBuilderAdapter adapter =
      new PsiBuilderAdapter(psiBuilder) {
        @Override
        public void error(String messageText) {
          super.error(messageText);
          errors.add(messageText);
        }
      };
  return parser.parse(definition.getFileNodeType(), adapter);
}
 
開發者ID:bazelbuild,項目名稱:intellij,代碼行數:18,代碼來源:BuildParserTest.java

示例6: parseQName

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Nullable
public static String parseQName(Lexer lexer) {
  String name;
  if (lexer.getTokenType() == XPathTokenTypes.NCNAME) {
    name = lexer.getTokenText();
    lexer.advance();
    if (lexer.getTokenType() == XPathTokenTypes.COL) {
      lexer.advance();
      assert lexer.getTokenType() == XPathTokenTypes.NCNAME;
      name += (":" + lexer.getTokenText());
      lexer.advance();
    }
  } else {
    name = null;
  }
  return name;
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:18,代碼來源:FunctionDeclarationParsing.java

示例7: registerHandler

import com.intellij.lexer.Lexer; //導入依賴的package包/類
protected void registerHandler(IElementType elementType, TokenHandler value) {
  final TokenHandler tokenHandler = tokenHandlers.get(elementType);

  if (tokenHandler != null) {
    final TokenHandler newHandler = value;
    value = new TokenHandler() {
      @Override
      public void handleElement(final Lexer lexer) {
        tokenHandler.handleElement(lexer);
        newHandler.handleElement(lexer);
      }
    };
  }

  tokenHandlers.put(elementType,value);
}
 
開發者ID:LichFaker,項目名稱:RtplPlugin,代碼行數:17,代碼來源:BaseHtmlLexer.java

示例8: doTest

import com.intellij.lexer.Lexer; //導入依賴的package包/類
private static void doTest(String text, String[] expectedTokens,Lexer lexer) {
  lexer.start(text);
  int idx = 0;
  while (lexer.getTokenType() != null) {
    if (idx >= expectedTokens.length) fail("Too many tokens");
    String tokenName = lexer.getTokenType().toString();
    String expectedTokenType = expectedTokens[idx++];
    String expectedTokenText = expectedTokens[idx++];
    assertEquals(expectedTokenType, tokenName);
    String tokenText = lexer.getBufferSequence().subSequence(lexer.getTokenStart(), lexer.getTokenEnd()).toString();
    assertEquals(expectedTokenText, tokenText);
    lexer.advance();
  }

  if (idx < expectedTokens.length) fail("Not enough tokens");
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:17,代碼來源:PropertiesLexerTest.java

示例9: testError2

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Test
public void testError2() {
    Lexer l = createLexer();

    startSkippingHeaders(l, "a: x\n" +
            "b: y\n" +
            "ab");

    assertAndAdvance(l, YamlTokenTypes.YAML_Key);
    assertAndAdvance(l, YamlTokenTypes.YAML_Value);
    assertAndAdvance(l, YamlTokenTypes.YAML_Whitespace);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar, 3, 5, "x\n");

    assertAndAdvance(l, YamlTokenTypes.YAML_Key);
    assertAndAdvance(l, YamlTokenTypes.YAML_Value);
    assertAndAdvance(l, YamlTokenTypes.YAML_Whitespace);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar, 8, 10, "y\n");

    // Simplified lexer ignores this error
    //assertAndAdvance(l, YamlTokenTypes.YAML_Error);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar);

    assertEquals(null, l.getTokenType());
}
 
開發者ID:vermut,項目名稱:intellij-snakeyaml,代碼行數:25,代碼來源:YamlHighlightingLexerTest.java

示例10: testError3

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Test
public void testError3() {
    Lexer l = createLexer();

    startSkippingHeaders(l, "a: x\n" +
            "b: y\n" +
            "@bad!");

    assertAndAdvance(l, YamlTokenTypes.YAML_Key);
    assertAndAdvance(l, YamlTokenTypes.YAML_Value);
    assertAndAdvance(l, YamlTokenTypes.YAML_Whitespace);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar, 3, 5, "x\n");

    assertAndAdvance(l, YamlTokenTypes.YAML_Key);
    assertAndAdvance(l, YamlTokenTypes.YAML_Value);
    assertAndAdvance(l, YamlTokenTypes.YAML_Whitespace);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar, 8, 10, "y\n");

    assertAndAdvance(l, YamlTokenTypes.YAML_Error);
    assertAndAdvance(l, YamlTokenTypes.YAML_Scalar);

    assertEquals(null, l.getTokenType());
}
 
開發者ID:vermut,項目名稱:intellij-snakeyaml,代碼行數:24,代碼來源:YamlHighlightingLexerTest.java

示例11: getErrorsCount

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Override
public int getErrorsCount(final CharSequence seq, Language fileLanguage, final Project project) {
  Lexer lexer = JavaParserDefinition.createLexer(LanguageLevel.HIGHEST);

  lexer.start(seq);
  if (lexer.getTokenType() != JavaTokenType.LBRACE) return IErrorCounterReparseableElementType.FATAL_ERROR;
  lexer.advance();
  int balance = 1;
  while (true) {
    IElementType type = lexer.getTokenType();
    if (type == null) break;
    if (balance == 0) return IErrorCounterReparseableElementType.FATAL_ERROR;
    if (type == JavaTokenType.LBRACE) {
      balance++;
    }
    else if (type == JavaTokenType.RBRACE) {
      balance--;
    }
    lexer.advance();
  }
  return balance;
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:23,代碼來源:JavaElementType.java

示例12: canStickJavaTokens

import com.intellij.lexer.Lexer; //導入依賴的package包/類
private static boolean canStickJavaTokens(ASTNode token1, ASTNode token2) {
  IElementType type1 = token1.getElementType();
  IElementType type2 = token2.getElementType();

  Pair<IElementType, IElementType> pair = Pair.create(type1, type2);
  Boolean res = myCanStickJavaTokensMatrix.get(pair);
  if (res == null) {
    if (!checkToken(token1) || !checkToken(token2)) return true;
    String text = token1.getText() + token2.getText();
    Lexer lexer = JavaParserDefinition.createLexer(LanguageLevel.HIGHEST);
    lexer.start(text);
    boolean canMerge = lexer.getTokenType() == type1;
    lexer.advance();
    canMerge &= lexer.getTokenType() == type2;
    res = canMerge;
    myCanStickJavaTokensMatrix.put(pair, res);
  }
  return res.booleanValue();
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:20,代碼來源:JavaSpacePropertyProcessor.java

示例13: createEmptyPsiField

import com.intellij.lexer.Lexer; //導入依賴的package包/類
protected PsiElement createEmptyPsiField() {
    final String text = "<undefined>";
    final IElementType type = CsvTypes.FIELD;
    final Project project = this.element.getProject();
    final PsiManager psiManager = PsiManager.getInstance(project);
    final DummyHolder dummyHolder = DummyHolderFactory.createHolder(psiManager, null);
    final FileElement fileElement = dummyHolder.getTreeElement();
    final ParserDefinition parserDefinition = LanguageParserDefinitions.INSTANCE.forLanguage(CsvLanguage.INSTANCE);
    final Lexer lexer = parserDefinition.createLexer(project);
    final PsiBuilder psiBuilder = PsiBuilderFactory.getInstance().createBuilder(project, fileElement, lexer, CsvLanguage.INSTANCE, text);
    final ASTNode node = parserDefinition.createParser(project).parse(type, psiBuilder);
    fileElement.rawAddChildren((com.intellij.psi.impl.source.tree.TreeElement)node);
    return node.getPsi();
}
 
開發者ID:SeeSharpSoft,項目名稱:intellij-csv-validator,代碼行數:15,代碼來源:CsvStructureViewElement.java

示例14: getHighlightingLexer

import com.intellij.lexer.Lexer; //導入依賴的package包/類
@Override
@NotNull
public Lexer getHighlightingLexer() {
  if (myIsDtd) {
    return new DtdLexer(true);
  } else if (myIsXHtml) {
    return new XHtmlHighlightingLexer();
  } else {
    return new XmlHighlightingLexer();
  }
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:12,代碼來源:XmlFileHighlighter.java

示例15: replaceTokenNotFollowedBy

import com.intellij.lexer.Lexer; //導入依賴的package包/類
private boolean replaceTokenNotFollowedBy(Lexer baseLexer, final IElementType replacement, IElementType nextToken) {
  if (!lookingAt(baseLexer, nextToken)) {
    treatAs(baseLexer, replacement);
    return true;
  }
  return false;
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:8,代碼來源:XPathLexer.java


注:本文中的com.intellij.lexer.Lexer類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。