Package abstrasy.pcfx

Source Code of abstrasy.pcfx.PCFx_flatten

package abstrasy.pcfx;

import abstrasy.Node;
import abstrasy.PCoder;

/**
* Abstrasy Interpreter
*
* Copyright : Copyright (c) 2006-2012, Luc Bruninx.
*
* Concédée sous licence EUPL, version 1.1 uniquement (la «Licence»).
*
* Vous ne pouvez utiliser la présente oeuvre que conformément à la Licence.
* Vous pouvez obtenir une copie de la Licence à l’adresse suivante:
*
*   http://www.osor.eu/eupl
*
* Sauf obligation légale ou contractuelle écrite, le logiciel distribué sous
* la Licence est distribué "en l’état", SANS GARANTIES OU CONDITIONS QUELLES
* QU’ELLES SOIENT, expresses ou implicites.
*
* Consultez la Licence pour les autorisations et les restrictions
* linguistiques spécifiques relevant de la Licence.
*
*
* @author Luc Bruninx
* @version 1.0
*/

public class PCFx_flatten
    extends PCFx {
  public PCFx_flatten() {
  }

  private final static void flatten(Node r, Node from, Node temoin) throws Exception{
    // on est parti...
    for(int i=0;i<from.size();i++){
        Node c = from.elementAt(i);
        long ctype=c.getQType();
        if(ctype==Node.TYPE_CLIST){
            if(c.size()>0 && temoin.indexOf(c)<0){
                // seulement si une liste n'est pas quotée et n'est pas vide...
                    temoin.addElement(c);
                    flatten(r,c, temoin);
            }
        }
        else{
            // sinon...
            r.addElement(c.secure());
        }
     }
  }

  /**
   * eval
   *
   * @param startAt Node
   * @return Node
   * @throws Exception
   * @todo Implémenter cette méthode abstrasy.PCFx
   */
  public Node eval(Node startAt) throws Exception {
        /*
         * forme    (flatten list/delegable) -> list/delegabble
         *
         *   Permet d'applatir un arbre de listes (en une seule liste).
         *
         */
        startAt.isGoodArgsCnt(2);
    Node arg0 = startAt.getSubNode(1, Node.TYPE_CLIST | Node.VTYPE_DELEGABLE);
       
        /*
         * Cas où (compact! objet)... Il s'agit d'une surcharge...
         */
       
        if(arg0.isDelegable())
                return Node.VDelegable.evalMethod(arg0, PCoder.getMethod(PCoder.PC_FLATTEN), null);
       
        // liste
       
        Node r = Node.createCList();
        Node temoin=new Node();
        flatten(r,arg0,temoin);
        return r;
  }
}
TOP

Related Classes of abstrasy.pcfx.PCFx_flatten

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.