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;
}
}