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

org.jclarion.clarion.runtime.expr.LabelExpr 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.sql.Types;
import java.util.Iterator;
import java.util.List;

import org.jclarion.clarion.BindProcedure;
import org.jclarion.clarion.ClarionBool;
import org.jclarion.clarion.ClarionDecimal;
import org.jclarion.clarion.ClarionFile;
import org.jclarion.clarion.ClarionNumber;
import org.jclarion.clarion.ClarionObject;
import org.jclarion.clarion.ClarionSQLFile;
import org.jclarion.clarion.ClarionString;
import org.jclarion.clarion.runtime.CExprImpl;
import org.jclarion.clarion.runtime.ObjectBindProcedure;
import org.jclarion.clarion.runtime.SQLBindProcedure;
import org.jclarion.clarion.runtime.ViewObjectBindProcedure;

public class LabelExpr extends CExpr {

    private String name;
    private List params;
    
    public LabelExpr(String name)
    {
        this.name=name;
    }

    public String getName()
    {
        return name;
    }
    
    public LabelExpr(String name,List params)
    {
        this.name=name;
        this.params=params;
    }

    private BindProcedure resolveProcedure()
    {
        return CExprImpl.getInstance().resolveBind(name,params!=null);
    }
    
    @Override
    public ClarionObject eval() {
        
        ClarionString r[];
        if (params==null) {
            r=new ClarionString[0];
        } else {
            r=new ClarionString[params.size()];
            int scan=0;
            for ( CExpr param : params ) {
                r[scan++]=param.eval().getString();
            }
        }
        
        ClarionObject co = resolveProcedure().execute(r);
        if (co==null) return new ClarionBool(false);
        return co;
    }

    @Override
    public int precendence() {
        return 9;
    }

    @Override
    public Iterator directChildren() {
        return new ZeroIterator();
    }
    
    public boolean generateString(StringBuilder out, boolean strict) {

        BindProcedure bp = resolveProcedure();
        
        if (bp instanceof ViewObjectBindProcedure) {
            ViewObjectBindProcedure vobp=(ViewObjectBindProcedure)bp;
            out.append(vobp.sqlColumn);
            return true;
        }

        if (bp instanceof ObjectBindProcedure) {
            ClarionObject o = eval();
            
            if (type!=null) {
                if (type==CExprType.STRING) {
                    ClarionSQLFile.encodeValue(out,o,java.sql.Types.VARCHAR);
                    return true;
                }

                if (type==CExprType.NUMERIC) {
                    ClarionSQLFile.encodeValue(out,o,java.sql.Types.BIGINT);
                    return true;
                }

                if (type==CExprType.DECIMAL) {
                    ClarionSQLFile.encodeValue(out,o,java.sql.Types.DECIMAL);
                    return true;
                }

                if (type==CExprType.DATE) {
                    ClarionSQLFile.encodeValue(out,o,java.sql.Types.DATE);
                    return true;
                }

                if (type==CExprType.TIME) {
                    ClarionSQLFile.encodeValue(out,o,java.sql.Types.TIME);
                    return true;
                }
            }
        
            if (o instanceof ClarionString) {
                ClarionSQLFile.encodeValue(out,o,java.sql.Types.VARCHAR);
                return true;
            }

            if (o instanceof ClarionNumber) {
                ClarionSQLFile.encodeValue(out,o,java.sql.Types.BIGINT);
                return true;
            }

            if (o instanceof ClarionDecimal) {
                ClarionSQLFile.encodeValue(out,o,java.sql.Types.DECIMAL);
                return true;
            }
        }

        if (bp instanceof SQLBindProcedure) {
            SQLBindProcedure sbp = (SQLBindProcedure)bp;
            
            CExpr r[];
            if (params==null) {
                r=new CExpr[0];
            } else {
                r=new CExpr[params.size()];
                params.toArray(r);
            }
            if (sbp.generateString(out,strict,r)) return true;
        }

        if (strict) return false;
        out.append("?");
        return true;
    }

    private CExprType type;


    @Override
    public void cast(CExprType type) {
        BindProcedure bp = resolveProcedure();
        if (bp instanceof ViewObjectBindProcedure) {
            throw new RuntimeException("Label casting not yet supported");
        }
        this.type=type;
    }
    
    @Override
    public CExprType getType() {
        if (type!=null) return type;
        
        BindProcedure bp = resolveProcedure();

        if (bp instanceof SQLBindProcedure) {
            return ((SQLBindProcedure)bp).getReturnType();
        }

        int sqlType=-1;
        
        if (bp instanceof ViewObjectBindProcedure) {
            sqlType=((ViewObjectBindProcedure)bp).sqlType;
        }

        
        ClarionObject obj=null;
        if (sqlType==-1) {
            obj = eval();
            if (obj.getOwner() instanceof ClarionFile) {
                sqlType = ((ClarionFile)obj.getOwner()).getSQLType(obj);
            }
        }
        
        switch (sqlType) {
            case Types.VARCHAR:
            case Types.VARBINARY:
                return CExprType.STRING;
            case Types.BIGINT:
                return CExprType.NUMERIC;
            case Types.DECIMAL:
                return CExprType.DECIMAL;
            case Types.DATE:
                return CExprType.DATE;
            case Types.TIME:
                return CExprType.TIME;
        }

        if (obj==null) obj=eval();
        
        if (obj instanceof ClarionNumber) return CExprType.NUMERIC;
        if (obj instanceof ClarionDecimal) return CExprType.DECIMAL;
        return CExprType.STRING;
    }

    @Override
    public boolean isRecastableType() {
        BindProcedure bp = resolveProcedure();
        if (bp instanceof ViewObjectBindProcedure) return false;
        if (bp instanceof SQLBindProcedure) return false;
        return true;
    }
    
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy