X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;ds=inline;f=src%2Fedu%2Fberkeley%2Fsbp%2Fbind%2FBindable.java;h=a51996e144c4cac89f2cc3b5b94802f755741a6a;hb=87449191636461647906b08434a8ca7036cbadef;hp=c2c0a02400bf091cf3e06acf72160373041273cc;hpb=8abe88ea7a5d7b1fc20c45b05e6397dad81e7cdb;p=sbp.git
diff --git a/src/edu/berkeley/sbp/bind/Bindable.java b/src/edu/berkeley/sbp/bind/Bindable.java
index c2c0a02..a51996e 100644
--- a/src/edu/berkeley/sbp/bind/Bindable.java
+++ b/src/edu/berkeley/sbp/bind/Bindable.java
@@ -1,3 +1,5 @@
+// Copyright 2006 all rights reserved; see LICENSE file for BSD-style license
+
package edu.berkeley.sbp.bind;
import edu.berkeley.sbp.util.*;
@@ -8,6 +10,7 @@ import java.util.*;
import java.lang.annotation.*;
import java.lang.reflect.*;
import java.io.*;
+import java.security.*;
import static edu.berkeley.sbp.util.Reflection.*;
public abstract class Bindable implements ToJava {
@@ -20,6 +23,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,15 +37,18 @@ 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+"]"; }
public BindableMethod(Method _method) { this._method = _method; }
public String getSimpleName() { return _method.getName(); }
- public A getAnnotation(Class c) { return _method.getAnnotation(c); }
+ public A getAnnotation(final Class c) { return _method.getAnnotation(c); }
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 +64,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('$','.'));
@@ -87,6 +100,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