blob: 5550589af132e04409a2ccb21cff1ea5ece3318b [file] [log] [blame]
/*
* Copyright 2000-2013 JetBrains s.r.o.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.jetbrains.python.parsing;
import com.intellij.lang.PsiBuilder;
import com.intellij.openapi.diagnostic.Logger;
import com.intellij.psi.tree.IElementType;
import com.jetbrains.python.PyBundle;
import com.jetbrains.python.PyElementTypes;
import com.jetbrains.python.PyTokenTypes;
import com.jetbrains.python.psi.PyElementType;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
/**
* @author yole
*/
public class Parsing {
protected ParsingContext myContext;
protected PsiBuilder myBuilder;
private static final Logger LOG = Logger.getInstance("#com.jetbrains.python.parsing.Parsing");
protected Parsing(ParsingContext context) {
myContext = context;
myBuilder = context.getBuilder();
}
public ParsingContext getParsingContext() {
return myContext;
}
public ExpressionParsing getExpressionParser() {
return getParsingContext().getExpressionParser();
}
public StatementParsing getStatementParser() {
return getParsingContext().getStatementParser();
}
public FunctionParsing getFunctionParser() {
return getParsingContext().getFunctionParser();
}
protected boolean checkMatches(final IElementType token, final String message) {
if (myBuilder.getTokenType() == token) {
myBuilder.advanceLexer();
return true;
}
myBuilder.error(message);
return false;
}
protected boolean parseIdentifierOrSkip() {
if (myBuilder.getTokenType() == PyTokenTypes.IDENTIFIER) {
myBuilder.advanceLexer();
return true;
}
else {
final PsiBuilder.Marker nameExpected = myBuilder.mark();
if (myBuilder.getTokenType() != PyTokenTypes.STATEMENT_BREAK) {
myBuilder.advanceLexer();
}
nameExpected.error(PyBundle.message("PARSE.expected.identifier"));
return false;
}
}
protected void assertCurrentToken(final PyElementType tokenType) {
LOG.assertTrue(myBuilder.getTokenType() == tokenType);
}
protected boolean atToken(@Nullable final IElementType tokenType) {
return myBuilder.getTokenType() == tokenType;
}
protected boolean atToken(@NotNull final IElementType tokenType, @NotNull String tokenText) {
return myBuilder.getTokenType() == tokenType && tokenText.equals(myBuilder.getTokenText());
}
protected boolean atAnyOfTokens(final IElementType... tokenTypes) {
IElementType currentTokenType = myBuilder.getTokenType();
for (IElementType tokenType : tokenTypes) {
if (currentTokenType == tokenType) return true;
}
return false;
}
protected boolean matchToken(final IElementType tokenType) {
if (myBuilder.getTokenType() == tokenType) {
myBuilder.advanceLexer();
return true;
}
return false;
}
protected void nextToken() {
myBuilder.advanceLexer();
}
protected static void buildTokenElement(IElementType type, PsiBuilder builder) {
final PsiBuilder.Marker marker = builder.mark();
builder.advanceLexer();
marker.done(type);
}
protected IElementType getReferenceType() {
return PyElementTypes.REFERENCE_EXPRESSION;
}
}