Code Search for Developers
 
 
  

RelClang.java from gzz at Krugle


Show RelClang.java syntax highlighted

/*
RelClang.java
 *    
 *    Copyright (c) 2003, Kimmo Wideroos
 *    
 *    This file is part of Gzz.
 *    
 *    Gzz is free software; you can redistribute it and/or modify it under
 *    the terms of the GNU Lesser General Public License as published by
 *    the Free Software Foundation; either version 2 of the License, or
 *    (at your option) any later version.
 *    
 *    Gzz is distributed in the hope that it will be useful, but WITHOUT
 *    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 *    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General
 *    Public License for more details.
 *    
 *    You should have received a copy of the GNU Lesser General
 *    Public License along with Gzz; if not, write to the Free
 *    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 *    MA  02111-1307  USA
 *    
 *    
 */
/*
 * Written by Kimmo Wideroos
 */

public class RelClang {

    static String rel_args = "d.rel_args";

    static private Hashtable AllPrimitives = new Hashtable();

    static {
	AllPrimitives.put("sum", (Object)new Sum());
    }

    private class BalanceTrigger implements ZZObs {
	private ZZCell c;
	private String cText;
	public void chg() {
	    if(!c.t().equals(cText)) return;
	    cText = c.t();
	    uniqueKey = getUniqueKey(c);
	    balanceEquations(c, uniqueKey);
	}
	public void init(ZZCell c) {
	    this.c = c;
	    cText = c.t();
	}
    }

    static public void balanceRelations(ZZCell rootvar, String changeKey) {
	ZZCell relroot, c;
	ZZCell[] modified;
	int solvable, n=0;
	touch(rootvar, changeKey);
	for(c=rootvar.s("d.clone"); c!=null; c=c.s("d.clone")) {
	    relroot = c.h(rel_args);
	    notBalanced[0].addElement(relroot);
	    n ++;
	}
	int level = 0;
	while(n > 0) {
	    while(notBalanced[level].size() == 0) {
		level++;
		if(level > 4) level = 0;
	    }
	    solvable = -1; 
	    // balance function changes 'solvable'
	    to_be_balanced = balance(relroot, solvable);
	    solvable = solvable > 4 ? 4 : solvable;
	    if(solvable == -1) throw ZZError("Couldn't solve!!");
	    if(solvable == 0) {
		// root relation is in balance
		n--;
		for(i=0; i<to_be_balanced.lenght; i++) {
		    tbb = to_be_balanced[i];
		    notBalanced[4].addElement(tbb);
		    n++;
		}
	    }
	    else {
		notBalanced[solvable].addElement(relroot);
	    }
	}
    }
    private ZZCell[] balance(ZZCell rel, int retval) {
	String op;
	opName = rel.t();
	rp = (RelPrimitive)AllPrimitives.get((Object)opName);
	Data data = new Data(rel.s(rel_args));
	return rp.solve(data);
    } 

    private void touch(ZZCell c, String uniqueKey) {
        c.getOrNewCell(rel_fingerprint).setText(uniqueKey);
    }

    private boolean isTouched(ZZCell c, String uniqueKey) {
        if(c.getOrNewCell(rel_fingerprint).t().equals(uniqueKey)) 
            return true;
        return false;
    }



    public class Sum(Data dt) {
        for(int i=dt.len-1; i>=0; i--) {
            if(isTouched(dt.c())) touched++;
            else notTouched = i;
        }
        if(touched==dt.len-1) {
            
        }
    }  

				   
} 




See more files for this project here

gzz

An implementation of Ted Nelson's ZZstructure. ZZstructure is a new type of programming platform for structured data.

Project homepage: http://savannah.nongnu.org/projects/gzz
Programming language(s): C++,Java,Python
License: lgpl21

  Awt.zob
  AwtArtefact.java
  AwtArtefactFlobFactory.java
  AwtCursorIdentifier.java
  AwtCursors.java
  AwtDim.java
  AwtLayer.java
  AwtLinkCache.java
  AwtLinkFlobFactory.java
  AwtLinkRelation.java
  AwtMetrics.zob
  AwtMetricsFC.java
  AwtMetricsFC2.java
  AwtMetricsNormal.java
  AwtNile.java
  AwtNileView.java
  AwtNoteFlobFactory.java
  AwtOp.java
  AwtOpAND.java
  AwtOpOR.java
  AwtOperators.java
  AwtRelation.java
  AwtSetRelation.java
  AwtUtil.java
  AwtView2.java
  RelClang.java
  ZObCellRepr.java