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

com.tangosol.dev.compiler.java.MultiplyExpression Maven / Gradle / Ivy

There is a newer version: 24.09
Show newest version
/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */


package com.tangosol.dev.compiler.java;


import com.tangosol.dev.assembler.CodeAttribute;
import com.tangosol.dev.assembler.Dmul;
import com.tangosol.dev.assembler.Fmul;
import com.tangosol.dev.assembler.Imul;
import com.tangosol.dev.assembler.Lmul;
import com.tangosol.dev.compiler.CompilerException;
import com.tangosol.dev.compiler.Context;
import com.tangosol.util.ErrorList;


/**
* Implements the Multiply (*) expression.
*
* @version 1.00, 10/05/98
* @author  Cameron Purdy
*/
public class MultiplyExpression extends MultiplicativeExpression
    {
    // ----- construction ---------------------------------------------------

    /**
    * Construct a MultiplyExpression.
    *
    * @param left      the left expression
    * @param operator  the operator token
    * @param right     the right expression
    */
    public MultiplyExpression(Expression left, Token operator, Expression right)
        {
        super(left, operator, right);
        }


    // ----- code generation ------------------------------------------------

    /**
    * Perform final optimizations and code generation.
    *
    * @param ctx       the compiler context
    * @param code      the assembler code attribute to compile to
    * @param fReached  true if this language element is reached (JLS 14.19)
    * @param errlist   the error list to log errors to
    *
    * @return true if the element can complete normally (JLS 14.1)
    *
    * @exception CompilerException  thrown if an error occurs that should
    *            stop the compilation process
    */
    protected boolean compile(Context ctx, CodeAttribute code, boolean fReached, ErrorList errlist)
            throws CompilerException
        {
        if (!ctx.isDebug() && isConstant())
            {
            return super.compile(ctx, code, fReached, errlist);
            }
        else
            {
            // Code generation for the operator '*' is as follows:
            //
            //              [left]
            //              [right]
            //              ?mul

            getLeftExpression ().compile(ctx, code, fReached, errlist);
            getRightExpression().compile(ctx, code, fReached, errlist);

            switch (getType().getTypeString().charAt(0))
                {
                case 'I':
                    code.add(new Imul());
                    break;

                case 'J':
                    code.add(new Lmul());
                    break;

                case 'F':
                    code.add(new Fmul());
                    break;

                case 'D':
                    code.add(new Dmul());
                    break;

                default:
                    throw new IllegalStateException();
                }
            }

        // normal completion possible if reachable
        return fReached;
        }


    // ----- Expression methods ---------------------------------------------

    /**
    * Determine the constant value of the expression.
    *
    * @return the constant value of the expression
    */
    public Object getValue()
        {
        boolean fVal;

        Expression left  = getLeftExpression();
        Expression right = getRightExpression();

        Number nbrLeft  = (Number) left .getValue();
        Number nbrRight = (Number) right.getValue();

        switch (left.getType().getTypeString().charAt(0))
            {
            case 'I':
                return Integer.valueOf(nbrLeft.intValue() * nbrRight.intValue());

            case 'J':
                return Long.valueOf(nbrLeft.longValue() * nbrRight.longValue());

            case 'F':
                return new Float(nbrLeft.floatValue() * nbrRight.floatValue());

            case 'D':
                return new Double(nbrLeft.doubleValue() * nbrRight.doubleValue());

            default:
                throw new IllegalStateException();
            }
        }


    // ----- data members ---------------------------------------------------

    /**
    * The class name.
    */
    private static final String CLASS = "MultiplyExpression";
    }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy