package de.skuzzle.polly.core.parser.ast.lang.operators; import de.skuzzle.polly.core.parser.Position; import de.skuzzle.polly.core.parser.ast.declarations.Namespace; import de.skuzzle.polly.core.parser.ast.declarations.types.Type; import de.skuzzle.polly.core.parser.ast.expressions.literals.Literal; import de.skuzzle.polly.core.parser.ast.expressions.literals.NumberLiteral; import de.skuzzle.polly.core.parser.ast.expressions.literals.StringLiteral; import de.skuzzle.polly.core.parser.ast.lang.BinaryOperator; import de.skuzzle.polly.core.parser.ast.visitor.ASTTraversalException; import de.skuzzle.polly.core.parser.ast.visitor.ExecutionVisitor; import de.skuzzle.polly.core.parser.problems.Problems; import de.skuzzle.polly.tools.collections.Stack; public class StringIndex extends BinaryOperator<StringLiteral, NumberLiteral> { public StringIndex() { super(OpType.INDEX); this.initTypes(Type.STRING, Type.STRING, Type.NUM); } @Override protected void exec(Stack<Literal> stack, Namespace ns, StringLiteral left, NumberLiteral right, Position resultPos, ExecutionVisitor execVisitor) throws ASTTraversalException { switch (this.getOp()) { case INDEX: int index = right.isInteger(execVisitor.getReporter()); if (index < 0 || index >= left.getValue().length()) { execVisitor.getReporter().runtimeProblem(Problems.INDEX_OUT_OF_BOUNDS, resultPos, index); } stack.push(new StringLiteral(resultPos, "" + left.getValue().charAt(index))); break; default: this.invalidOperatorType(this.getOp()); } } }