X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2FSequence.java;h=a029274a0a01f7cbe48db426e645c1def564e64a;hp=d3d8d8a136d124dfdca130cd15ad651e9f146aa0;hb=0620c2d97d6df986d74dbe13160afb1435096431;hpb=e84029a8b861075d6d0ed5040f919b2e4da4c98f diff --git a/src/edu/berkeley/sbp/Sequence.java b/src/edu/berkeley/sbp/Sequence.java index d3d8d8a..a029274 100644 --- a/src/edu/berkeley/sbp/Sequence.java +++ b/src/edu/berkeley/sbp/Sequence.java @@ -16,7 +16,10 @@ public abstract class Sequence implements Iterable, SequenceOrElement { public boolean needed_or_hated = false; - final HashSet hated = new HashSet(); + public HashMap canNeed = new HashMap(); + public HashMap canKill = new HashMap(); + + final HashSet hated = new HashSet(); final HashSet needs = new HashSet(); final HashSet hates = new HashSet(); @@ -109,6 +112,20 @@ public abstract class Sequence implements Iterable, SequenceOrElement { /** the imaginary position before or after an element of a sequence; corresponds to an "LR item" */ 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;