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

one.empty3.library.core.script.Pile Maven / Gradle / Ivy

There is a newer version: 2023.5
Show newest version
/*
 * Copyright (c) 2023. Manuel Daniel Dahmen
 *
 *
 *    Copyright 2012-2023 Manuel Daniel Dahmen
 *
 *    Licensed under the Apache License, Version 2.0 (the "License");
 *    you may not use this file except in compliance with the License.
 *    You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 *    Unless required by applicable law or agreed to in writing, software
 *    distributed under the License is distributed on an "AS IS" BASIS,
 *    WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *    See the License for the specific language governing permissions and
 *    limitations under the License.
 */

/*

 Vous êtes libre de :

 */
package one.empty3.library.core.script;

import java.util.ArrayList;

/*__
 * *
 * AUTHOR DAHMEN MANUEL DATE 18 AVRIL 2012
 */
public class Pile implements Interprete, Definition {

    private ArrayList objects = new ArrayList();
    private ArrayList types;
    private ArrayList variables;
    private ArrayList operateurs;
    private int pos;

    public void addOperateurs(ArrayList o) {
        //this.operateurs.merge(o);
    }

    public void addTypes(ArrayList types) {
        //this.types.merge(types);
    }

    public void addVariable(ArrayList v) {
        //this.variables.merge(v);
    }

    public InterpreteConstants constant() {
        return null;
    }

    public Double evaluer(int posO)
            throws Exception {
        posO = objects.size() - 1;
        ArrayList vals;
        vals = new ArrayList();
        while (posO >= 0) {
            Object o = objects.get(posO);
            if (o instanceof Operateur) {
                Operateur op = (Operateur) o;
                String id = op.id;
                if (op.nbrOperandes > 0) {
                    for (int j = 0; j < op.nbrOperandes; j++) {
                        posO--;
                        vals.add(evaluer(posO));
                    }
                }
                if (id.equals("+")) {
                    return vals.get(0) + vals.get(1);
                }
                if (id.equals("-")) {
                    return vals.get(0) - vals.get(1);
                }
                if (id.equals("*")) {
                    return vals.get(0) * vals.get(1);
                }
                if (id.equals("/")) {
                    return vals.get(0) / vals.get(1);
                }
                if (id.equals("**")) {
                    return Math.exp(Math.log(vals.get(0)) * vals.get(1));
                }
                if (id.equals("sin")) {
                    return Math.sin(vals.get(0));
                }
                if (id.equals("cos")) {
                    return Math.cos(vals.get(0));
                }

            } else if (o instanceof Variable) {
                vals.add(((Variable) o).evaluer());
            }

        }
        throw new Exception("Erreur dans la pile post-fixée");
    }

    public Operateur getOperateur(String s) {
        for (int i = 0; i < operateurs.size(); i++) {
            if (operateurs.get(i).id.toUpperCase().equals(s.toUpperCase())) {
                return operateurs.get(i);
            }
        }
        return null;
    }

    public int getPosition() {
        return pos;
    }

    public Type getType(String s) {
        for (int i = 0; i < operateurs.size(); i++) {
            if (types.get(i).nom.toUpperCase().equals(s.toUpperCase())) {
                return types.get(i);
            }
        }
        return null;
    }

    public Variable getVariable(String s) {
        for (int i = 0; i < variables.size(); i++) {
            if (variables.get(i).id.toUpperCase().equals(s.toUpperCase())) {
                return variables.get(i);
            }
        }
        return null;
    }

    public Object interprete(String text, int pos)
            throws InterpreteException {
        loadOperateurs();
        InterpretesBase ib = new InterpretesBase();
        ArrayList pattern = new ArrayList();
        pattern.add(ib.BLANK);
        pattern.add(ib.LEFTPARENTHESIS);
        pattern.add(ib.BLANK);
        ib.compile(pattern);
        ib.read(text, pos);
        pos = this.pos;

        boolean cont = true;
        while (cont) {
            try {
                ib = new InterpretesBase();
                pattern = new ArrayList();
                pattern.add(ib.BLANK);
                pattern.add(ib.LEFTPARENTHESIS);
                pattern.add(ib.BLANK);
                ib.compile(pattern);
                ib.read(text, pos);
                pos = this.pos;
                cont = false;
            } catch (InterpreteException ex) {
                cont = true;
            }

            boolean pass = false;
            Double d = 0.0;
            try {
                d = interpreteDouble(text, pos);
                pass = true;
            } catch (InterpreteException ex) {
                pass = false;
            }
            if (pass) {
                objects.add(d);
            }
            String s = null;
            pass = false;
            try {
                s = interpreteIdentifier(text, pos);
                Operateur o = getOperateur(s);
                Variable v = getVariable(s);
                if (o != null) {
                    objects.add(o);
                    pass = true;
                } else if (v != null) {
                    objects.add(v);
                    pass = true;
                }
            } catch (InterpreteException ex) {
                pass = false;
            }
            if (pass) {
                objects.add(d);
            }
            pos = this.pos;
        }
        return null;
    }

    public Double interpreteDouble(String text, int pos)
            throws InterpreteException {
        Double ret = 0.0;
        InterpretesBase ib = new InterpretesBase();
        ArrayList pattern = new ArrayList();
        pattern.add(ib.BLANK);
        pattern.add(ib.DECIMAL);
        pattern.add(ib.BLANK);
        ib.compile(pattern);
        ret = (Double) ib.read(text, pos).get(1);
        this.pos = pos;
        return ret;
    }

    public String interpreteIdentifier(String text, int pos)
            throws InterpreteException {
        String ret = "";
        InterpreteIdentifier ii = new InterpreteIdentifier();
        ret = (String) ii.interprete(text, pos);
        this.pos = pos;
        return ret;
    }

    public String interpreteOperateur(String text, int pos)
            throws InterpreteException {
        String ret = "";
        InterpreteIdentifier ii = new InterpreteIdentifier();
        ret = (String) ii.interprete(text, pos);
        this.pos = pos;
        return ret;
    }

    public void loadDefVarCst(LoaderDef ld) {
        ld.load(this);
    }

    public void loadOperateurs() {
        types = new ArrayList();
        Type t = new Type();
        t.nom = "Double";
        t.type = Double.class;
        types.add(t);
        t = new Type();
        t.nom = "variable";
        t.type = Double.class;
    }

    @Override
    public void setConstant(InterpreteConstants c) {
    }

    @Override
    public void setRepertoire(String r) {
        throw new UnsupportedOperationException("Not supported yet.");
    }

    public interface LoaderDef {

        void load(Definition d);
    }

    public class Operateur {

        public String id;
        public int nbrOperandes;
        public ArrayList types;
    }

    public class Type {

        public String nom;
        public Class type;
    }

    public class Variable {

        public String id;
        public Type type;
        public Object value;

        public Double evaluer() {
            return (Double) value;
        }
    }
}