- return Sequence.rewritingSequence(new TargetReducer(p, buildSequence(p), "reducer-"+this), p.elements, p.labels, p.drops);
- }
- public abstract Object plant(Object[] fields, int[] map);
- public boolean isRaw() { return false; }
- public Object invokeRaw(Iterable<Tree> t) { return null; }
- public class TargetReducer implements Functor<Iterable<Tree>,Object> {
- private Production p;
- private int[] map;
- private String name;
- public TargetReducer(Production p, int[] map, String name) {
- this.p = p;
- this.map = map;
- this.name = name;
- }
- public String toString() { return name; }
- public Object invoke(Iterable<Tree> t) {
- if (isRaw()) return invokeRaw(t);
- ArrayList ret = new ArrayList();
- for(Tree tc : t) {
- if (tc.head() != null && tc.head() instanceof Functor)
- ret.add(((Functor<Iterable<Tree>,Object>)tc.head()).invoke(tc.children()));
- else if (tc.numChildren() == 0)
- ret.add(tc.head());
- else {
- System.err.println("FIXME: don't know what to do about " + tc);
- ret.add(null);
- }
- }
- System.err.println("input tree: " + t);
- return plant(ret.toArray(new Object[0]), map);
- }
- }
- }
-
- public static class TargetClass extends Target {
- public final Class _class;
- public TargetClass(Class _class) { this._class = _class; }
- public String getName() { return _class.getSimpleName(); }
- public tag getTag() { return (tag)_class.getAnnotation(tag.class); }
- public nonterminal getNonTerminal() { return (nonterminal)_class.getAnnotation(nonterminal.class); }
- public String toString() { return _class.getSimpleName(); }
- public int[] buildSequence(Production p) {
- Field[] f = _class.getDeclaredFields();
- String[] names = new String[f.length];
- arg[] argtags = new arg[f.length];
- for(int i=0; i<f.length; i++) {
- names[i] = f[i].getName();
- argtags[i] = f[i].getAnnotation(arg.class);
- }
- int[] ret = buildSequence(p, names, argtags);
- if (ret!=null) return ret;
- for(Constructor c : _class.getConstructors())
- if (new TargetConstructor(c).buildSequence(p)!=null)
- return new TargetConstructor(c).buildSequence(p);
- return null;
- }
- public Object plant(Object[] fields, int[] map) {
- try {
- Object ret = _class.newInstance();
- Field[] f = _class.getFields();
- int j = 0;
- for(int i=0; i<f.length; i++)
- if (map[i] != -1) {
- Object tgt = Reflection.lub(fields[map[i]]);
- if (f[i].getType() == String.class) tgt = stringify(tgt);
- // FUGLY
- tgt = coerce(tgt, f[i].getType());
- System.err.println("setting a " + f[i].getType().getName() + " to " + Reflection.show(tgt));
- f[i].set(ret, tgt);
- }
- return ret;
- } catch (Exception e) {
- e.printStackTrace();
- throw new RuntimeException(e);
- }