X-Git-Url: http://git.megacz.com/?p=sbp.git;a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2FSequence.java;h=c41be4ff9d62da6ba0537477b13c3db22aaed42d;hp=0ce5f55c34e14380e1be527e6cfaabc00d6b0c4b;hb=2afdfe14e78fa0597186614937c679a09d74ecdf;hpb=dc9bb3a45ed306e2e35549076842b3e74efecb48 diff --git a/src/edu/berkeley/sbp/Sequence.java b/src/edu/berkeley/sbp/Sequence.java index 0ce5f55..c41be4f 100644 --- a/src/edu/berkeley/sbp/Sequence.java +++ b/src/edu/berkeley/sbp/Sequence.java @@ -20,7 +20,7 @@ public abstract class Sequence implements Iterable, SequenceOrElement { final HashSet needs = new HashSet(); final HashSet hates = new HashSet(); - // FIXME: these are ugly -- migrate into Cache + // FIXME: these are ugly -- migrate into Grammar HashMap canNeed = new HashMap(); HashMap canKill = new HashMap(); @@ -54,6 +54,11 @@ public abstract class Sequence implements Iterable, SequenceOrElement { ? new Unwrap(e, head, drop) : new RewritingSequence(head, e, drop); } + public static Sequence createLeft(Object head, Element[] e, boolean[] drop, boolean foster) { + return foster + ? new UnwrapLeft(e, head, drop) + : new RewritingSequence(head, e, drop); + } /** return a new sequence identical to this one, but with a positive conjunct s */ public Sequence and(Sequence s) { @@ -104,7 +109,7 @@ public abstract class Sequence implements Iterable, SequenceOrElement { this.firstp = new Position(0, null); } - abstract Forest epsilonForm(Input.Region loc, Cache cache); + abstract Forest epsilonForm(Input.Region loc, Grammar cache); protected abstract Forest postReduce(Input.Region loc, Forest[] args, Position p); @@ -154,7 +159,7 @@ public abstract class Sequence implements Iterable, SequenceOrElement { // Position ///////////////////////////////////////////////////////////////////////////////// - final Forest rewrite(Input.Region loc, Cache cache) { + final Forest rewrite(Input.Region loc, Grammar cache) { if (this==firstp()) epsilonForm(loc, cache); for(int i=0; i, SequenceOrElement { public Forest postReduce(Input.Region loc, Forest[] args, Position p) { return (Forest)Forest.create(loc, result, null, false); } - Forest epsilonForm(Input.Region loc, Cache cache) { + Forest epsilonForm(Input.Region loc, Grammar cache) { return Forest.create(loc, result, null, false); } } @@ -230,7 +235,7 @@ public abstract class Sequence implements Iterable, SequenceOrElement { public Singleton(Element[] e, int idx) { super(e); this.idx = idx; } public Forest postReduce(Input.Region loc, Forest[] args, Position p) { return args[idx]; } Sequence _clone() { return new Singleton(elements,idx); } - Forest epsilonForm(Input.Region loc, Cache cache) { + Forest epsilonForm(Input.Region loc, Grammar cache) { return ((Union)elements[idx]).epsilonForm(loc, cache); } } @@ -251,7 +256,28 @@ public abstract class Sequence implements Iterable, SequenceOrElement { for(int i=0; i Forest postReduce(Input.Region loc, Forest[] args, Position p) { + for(int i=0; i[] args2 = new Forest[count]; + int j = 0; + for(int i=0; i, SequenceOrElement { if (spacing) for(int i=0; i<50-len; i++) sb.append(' '); return sb; } - Forest epsilonForm(Input.Region loc, Cache cache) { + Forest epsilonForm(Input.Region loc, Grammar cache) { return Forest.create(loc, tag, new Forest[0], false); } }