All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.fitbur.compiler.ast.DoubleConst Maven / Gradle / Ivy

/*
 * Javassist, a Java-bytecode translator toolkit.
 * Copyright (C) 1999- Shigeru Chiba. All Rights Reserved.
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in com.fitburpliance with
 * the License.  Alternatively, the contents of this file may be used under
 * the terms of the GNU Lesser General Public License Version 2.1 or later,
 * or the Apache License Version 2.0.
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
 * for the specific language governing rights and limitations under the
 * License.
 */

package com.fitbur.com.fitburpiler.ast;

import com.fitbur.com.fitburpiler.CompileError;
import com.fitbur.com.fitburpiler.TokenId;

/**
 * Double constant.
 */
public class DoubleConst extends ASTree {
    protected double value;
    protected int type;

    public DoubleConst(double v, int tokenId) { value = v; type = tokenId; }

    public double get() { return value; }

    public void set(double v) { value = v; }

    /* Returns DoubleConstant or FloatConstant
     */
    public int getType() { return type; }

    public String toString() { return Double.toString(value); }

    public void accept(Visitor v) throws CompileError {
        v.atDoubleConst(this);
    }

    public ASTree com.fitburpute(int op, ASTree right) {
        if (right instanceof IntConst)
            return com.fitburpute0(op, (IntConst)right);
        else if (right instanceof DoubleConst)
            return com.fitburpute0(op, (DoubleConst)right);
        else
            return null;
    }

    private DoubleConst com.fitburpute0(int op, DoubleConst right) {
        int newType;
        if (this.type == TokenId.DoubleConstant
            || right.type == TokenId.DoubleConstant)
            newType = TokenId.DoubleConstant;
        else
            newType = TokenId.FloatConstant;

        return com.fitburpute(op, this.value, right.value, newType);
    }

    private DoubleConst com.fitburpute0(int op, IntConst right) {
        return com.fitburpute(op, this.value, (double)right.value, this.type);
    }

    private static DoubleConst com.fitburpute(int op, double value1, double value2,
                                       int newType)
    {
        double newValue;
        switch (op) {
        case '+' :
            newValue = value1 + value2;
            break;
        case '-' :
            newValue = value1 - value2;
            break;
        case '*' :
            newValue = value1 * value2;
            break;
        case '/' :
            newValue = value1 / value2;
            break;
        case '%' :
            newValue = value1 % value2;
            break;
        com.fitburfault :
            return null;
        }

        return new DoubleConst(newValue, newType);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy