X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Fedu%2Fberkeley%2Fsbp%2Fbind%2FBindable.java;h=8f5cc86749efa2060ac98fda91c2bfb6ae308d1a;hb=23091054a6842031d168c2628216c2310149cc5d;hp=d045e16c408687dd54ebfd843fce4fa381910359;hpb=3b0359f6248ca6b2ef5250c24dd49b0fa434fd1f;p=sbp.git
diff --git a/src/edu/berkeley/sbp/bind/Bindable.java b/src/edu/berkeley/sbp/bind/Bindable.java
index d045e16..8f5cc86 100644
--- a/src/edu/berkeley/sbp/bind/Bindable.java
+++ b/src/edu/berkeley/sbp/bind/Bindable.java
@@ -20,6 +20,12 @@ public abstract class Bindable implements ToJava {
public abstract Annotation[][] getArgAnnotations();
public abstract String[] getArgNames();
+ public abstract Class[] getArgTypes();
+
+ public Binding createBinding() { return new SimpleBinding(); }
+ public Binding createBinding(final int[] map) { return new SimpleBinding(map); }
+ public Binding createBinding(final int[] map, Object prepend) { return new SimpleBinding(map, prepend); }
+
public static Bindable create(Object o) {
if (o instanceof Class) return new BindableClass((Class)o);
@@ -28,6 +34,8 @@ public abstract class Bindable implements ToJava {
return null;
}
+ // Subclasses //////////////////////////////////////////////////////////////////////////////
+
private static class BindableMethod extends Bindable {
private final Method _method;
public String toString() { return "BindableMethod["+_method+"]"; }
@@ -37,6 +45,7 @@ public abstract class Bindable implements ToJava {
public Object impose(Object[] fields) { return Reflection.impose(_method, fields); }
public Annotation[][] getArgAnnotations() { return _method.getParameterAnnotations(); }
public String[] getArgNames() { return new String[_method.getParameterTypes().length]; }
+ public Class[] getArgTypes() { return _method.getParameterTypes(); }
public void toJava(StringBuffer sb) {
sb.append("Bindable.create(");
sb.append(_method.getDeclaringClass().getName().replace('$','.'));
@@ -52,11 +61,12 @@ public abstract class Bindable implements ToJava {
private final Constructor _constructor;
public String toString() { return "BindableConstructor["+_constructor+"]"; }
public BindableConstructor(Constructor _constructor) { this._constructor = _constructor; }
- public String getSimpleName() { return _constructor.getName(); }
+ public String getSimpleName() { return _constructor.getDeclaringClass().getSimpleName(); }
public A getAnnotation(Class c) { return _constructor.getAnnotation(c); }
public Object impose(Object[] fields) { return Reflection.impose(_constructor, fields); }
public Annotation[][] getArgAnnotations() { return _constructor.getParameterAnnotations(); }
public String[] getArgNames() { return new String[_constructor.getParameterTypes().length]; }
+ public Class[] getArgTypes() { return _constructor.getParameterTypes(); }
public void toJava(StringBuffer sb) {
sb.append("Bindable.create(");
sb.append(_constructor.getDeclaringClass().getName().replace('$','.'));
@@ -70,12 +80,7 @@ public abstract class Bindable implements ToJava {
private final Class _class;
public String toString() { return "BindableClass["+_class+"]"; }
public BindableClass(Class _class) { this._class = _class; }
- public String getSimpleName() {
- String s = _class.getSimpleName();
- if (s.indexOf('$') != -1)
- return s.substring(s.indexOf('$')+1);
- return s;
- }
+ public String getSimpleName() { return _class.getSimpleName(); }
public A getAnnotation(Class c) { return (A)_class.getAnnotation(c); }
public Object impose(Object[] fields) { return Reflection.impose(_class, fields); }
public Annotation[][] getArgAnnotations() {
@@ -92,6 +97,13 @@ public abstract class Bindable implements ToJava {
ret[i] = fields[i].getName();
return ret;
}
+ public Class[] getArgTypes() {
+ Field[] fields = _class.getFields();
+ Class[] ret = new Class[fields.length];
+ for(int i=0; i