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

org.jclarion.clarion.runtime.expr.SumExpr Maven / Gradle / Ivy

/**
 * Copyright 2010, by Andrew Barnham
 *
 * The contents of this file are subject to
 * GNU Lesser General Public License (LGPL), v.3
 * http://www.gnu.org/licenses/lgpl.txt
 * 
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND, either express or implied.
 */
package org.jclarion.clarion.runtime.expr;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.jclarion.clarion.ClarionObject;

public class SumExpr extends CExpr {

    public static CExpr construct(CExpr left,String op,CExpr right) {
        
        if (!(left instanceof SumExpr)) 
        {
            left=new SumExpr(left);
        }
        ((SumExpr)left).add(op,right);
        return left;
    }
    
    private enum Op { PLUS, MINUS, NONE };
    
    private static class BoolOp extends GenericOp
    {
        public Op op;
        
        public BoolOp(Op op,CExpr right)
        {
            this.op=op;
            this.right=right;
        }
    }
    
    private CExpr           base;
    private List    ops;
    
    public SumExpr(CExpr base)
    {
        this.base=base;
        this.ops=new ArrayList();
    }
    
    public void add(String op,CExpr right) {
        if (op.equalsIgnoreCase("+")) ops.add(new BoolOp(Op.PLUS,right));
        if (op.equalsIgnoreCase("-")) ops.add(new BoolOp(Op.MINUS,right));
    }

    @Override
    public ClarionObject eval() {
        
        ClarionObject result = base.eval();
        
        for ( BoolOp op : ops ) {

            if (op.op==Op.PLUS) {
                result=result.add(op.right.eval());
            }

            if (op.op==Op.MINUS) {
                result=result.subtract(op.right.eval());
            }
        }
        
        return result;
    }

    @Override
    public int precendence() {
        return 5;
    }
    
    @Override
    public Iterator directChildren() {
        return JoinIterator.generic(base,ops);
    }

    @Override
    public boolean generateString(StringBuilder out, boolean strict) {
        
        int startPos=out.length();
        
        BoolOp curr=new BoolOp(Op.NONE,base);
        Iterator scan = ops.iterator();
 
        while (curr!=null) {
            
            if (curr.op==Op.PLUS) out.append('+');
            if (curr.op==Op.MINUS) out.append('-');
            
            if (curr.right.precendence()




© 2015 - 2025 Weber Informatics LLC | Privacy Policy