X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2FSequence.java;h=3e260f14bbd6500196a197e2afb858bb5bf2d7df;hp=2c36c8db00c2dd2917eaf25e8e7e3e072a7f4b31;hb=9d727bd14c659cdc6c34153b988e8d3fdb8067f5;hpb=a4cd33f348d3802ed746e517c23205958a4ceeb4 diff --git a/src/edu/berkeley/sbp/Sequence.java b/src/edu/berkeley/sbp/Sequence.java index 2c36c8d..3e260f1 100644 --- a/src/edu/berkeley/sbp/Sequence.java +++ b/src/edu/berkeley/sbp/Sequence.java @@ -98,7 +98,10 @@ public abstract class Sequence implements Iterable, SequenceOrElement { public Iterator iterator() { return new ArrayIterator(elements); } protected Sequence(Element[] elements) { this.elements = elements; - this.firstp = new Position(0); + for(int i=0; i, SequenceOrElement { class Position implements IntegerMappable { public int ord = -1; - public int compareTo(Position p, Walk.Cache cache) { - Position position = this; - Position rposition = p; - int ret = 0; - if (Reduction.canKill(cache, position, rposition) && - Reduction.canKill(cache, rposition, position)) throw new Error(); - if (Reduction.canKill(cache, position, rposition)) ret = 1; - else if (Reduction.canKill(cache, rposition, position)) ret = -1; - if (Reduction.canNeed(cache, position, rposition)) ret = 1; - else if (Reduction.canNeed(cache, rposition, position)) ret = -1; - return ret; - } private Forest zero = null; public Forest zero(Input.Region reg) { if (zero != null) return zero; - if (pos > 0) throw new Error(); + if (pos > 0) throw new RuntimeException("Position.zero(): pos>0"); return zero = rewrite(reg); } - final int pos; private final Position next; private final Position prev; final Forest[] holder; - private Position(int pos) { + private Position(int pos, Position prev) { this.pos = pos; - this.next = pos==elements.length ? null : new Position(pos+1); + this.next = pos==elements.length ? null : new Position(pos+1, this); this.holder = new Forest[elements.length]; this.prev = prev; } @@ -178,9 +168,7 @@ public abstract class Sequence implements Iterable, SequenceOrElement { if (holder[i]==null) holder[i] = elements[i].epsilonForm(loc); if (holder[i]==null) throw new Error("bad " + i); } - Forest ret = Sequence.this.postReduce(loc, holder, this); - //for(int k=0; k, SequenceOrElement { Forest[] args2 = new Forest[count]; int j = 0; for(int i=0; i