X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2FSequence.java;h=a029274a0a01f7cbe48db426e645c1def564e64a;hp=5680d6c5f17ca3cb51eb40af4e03c4177adddf2c;hb=0620c2d97d6df986d74dbe13160afb1435096431;hpb=2c1c0293545f3d12c23220fd05c663e6aa3f3de1 diff --git a/src/edu/berkeley/sbp/Sequence.java b/src/edu/berkeley/sbp/Sequence.java index 5680d6c..a029274 100644 --- a/src/edu/berkeley/sbp/Sequence.java +++ b/src/edu/berkeley/sbp/Sequence.java @@ -1,3 +1,5 @@ +// Copyright 2006 all rights reserved; see LICENSE file for BSD-style license + package edu.berkeley.sbp; import edu.berkeley.sbp.util.*; import edu.berkeley.sbp.*; @@ -12,7 +14,12 @@ public abstract class Sequence implements Iterable, SequenceOrElement { protected final Element[] elements; - final HashSet hated = new HashSet(); + public boolean needed_or_hated = false; + + 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(); @@ -63,14 +70,20 @@ public abstract class Sequence implements Iterable, SequenceOrElement { //////////////////////////////////////////////////////////////////////////////// /** return a new sequence identical to this one, but with a positive conjunct s */ - public Sequence and(Sequence s) { Sequence ret = dup(); ret.needs.add(s); return ret; } + public Sequence and(Sequence s) { Sequence ret = dup(); ret.needs.add(s); s.needed_or_hated=true; return ret; } /** return a new sequence identical to this one, but with a negative conjunct s */ - public Sequence andnot(Sequence s) { Sequence ret = dup(); ret.hates.add(s); s.hated.add(ret); return ret; } + public Sequence andnot(Sequence s) { Sequence ret = dup(); ret.hates.add(s); s.hated.add(ret); s.needed_or_hated=true; return ret; } /** return a new sequence identical to this one, but with a follow-set restricted to a */ public Sequence followedBy(Atom a) { Sequence ret = dup(); ret.follow = a; return ret; } + boolean hatesAny(Iterable it) { + if (hates.isEmpty()) return false; + for(Sequence s : it) if (hates.contains(s)) return true; + return false; + } + Iterable needs() { return needs; } Iterable hates() { return hates; } @@ -84,10 +97,10 @@ public abstract class Sequence implements Iterable, SequenceOrElement { // DO NOT MESS WITH THE FOLLOWING LINE!!! private Forest.Many epsilonForm = null; - Forest epsilonForm() { + Forest epsilonForm(Input.Region loc) { if (epsilonForm!=null) return epsilonForm; epsilonForm = new Forest.Many(); - epsilonForm.merge(firstp().rewrite(null, false)); + epsilonForm.merge(firstp().rewrite(loc, false)); return epsilonForm; } @@ -99,11 +112,25 @@ 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() { + public Forest zero(Input.Region reg) { if (zero != null) return zero; if (pos > 0) throw new Error(); - return zero = rewrite(null); + return zero = rewrite(reg); } @@ -135,10 +162,10 @@ public abstract class Sequence implements Iterable, SequenceOrElement { final Forest rewrite(Input.Region loc) { return rewrite(loc, true); } private final Forest rewrite(Input.Region loc, boolean epsilonCheck) { - if (epsilonCheck && this==firstp()) return epsilonForm(); + if (epsilonCheck && this==firstp()) return epsilonForm(loc); for(int i=0; i ret = Sequence.this.postReduce(loc, holder, this);