/* * Copyright (C) 2007 JĂșlio Vilmar Gesser. * * This file is part of Java 1.5 parser and Abstract Syntax Tree. * * Java 1.5 parser and Abstract Syntax Tree is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Java 1.5 parser and Abstract Syntax Tree is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Java 1.5 parser and Abstract Syntax Tree. If not, see <http://www.gnu.org/licenses/>. */ /* * Created on 05/10/2006 */ package org.checkerframework.stubparser.ast.expr; import org.checkerframework.stubparser.ast.visitor.GenericVisitor; import org.checkerframework.stubparser.ast.visitor.VoidVisitor; /** * @author Julio Vilmar Gesser */ public final class UnaryExpr extends Expression { public static enum Operator { positive, // + negative, // - preIncrement, // ++ preDecrement, // -- not, // ! inverse, // ~ posIncrement, // ++ posDecrement, // -- } private Expression expr; private Operator op; public UnaryExpr() { } public UnaryExpr(Expression expr, Operator op) { this.expr = expr; this.op = op; } public UnaryExpr(int beginLine, int beginColumn, int endLine, int endColumn, Expression expr, Operator op) { super(beginLine, beginColumn, endLine, endColumn); this.expr = expr; this.op = op; } @Override public <R, A> R accept(GenericVisitor<R, A> v, A arg) { return v.visit(this, arg); } @Override public <A> void accept(VoidVisitor<A> v, A arg) { v.visit(this, arg); } public Expression getExpr() { return expr; } public Operator getOperator() { return op; } public void setExpr(Expression expr) { this.expr = expr; } public void setOperator(Operator op) { this.op = op; } }