# HG changeset patch # User Jaroslav Tulach # Date 1365837294 -7200 # Node ID 094cd25a16d95f36934b80f6009779e621165cee # Parent cab175cc335888d48aa9e26460ba4a05c56c8335 Introducing KOProperty to allow us to call non-public methods and to do conversion of primitive types which is broken in WebView diff -r cab175cc3358 -r 094cd25a16d9 javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/KOProperty.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/KOProperty.java Sat Apr 13 09:14:54 2013 +0200 @@ -0,0 +1,51 @@ +/** + * Back 2 Browser Bytecode Translator + * Copyright (C) 2012 Jaroslav Tulach + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, version 2 of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. Look for COPYING file in the top folder. + * If not, see http://opensource.org/licenses/GPL-2.0. + */ + +package org.apidesign.bck2brwsr.htmlpage; + +import java.lang.reflect.Method; + +/** + * + * @author Jaroslav Tulach + */ +public final class KOProperty { + private final Object obj; + private final Method getter; + private final Method setter; + + KOProperty(Object obj, String getter, String setter) throws NoSuchMethodException { + this.obj = obj; + this.getter = obj.getClass().getDeclaredMethod(getter); + this.getter.setAccessible(true); + if (setter != null) { + this.setter = obj.getClass().getDeclaredMethod(setter, this.getter.getReturnType()); + this.setter.setAccessible(true); + } else { + this.setter = null; + } + } + + public Object get() throws Exception { + return getter.invoke(obj); + } + + public void set(Object value) throws Exception { + setter.invoke(obj, value); + } +} diff -r cab175cc3358 -r 094cd25a16d9 javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/Knockout.java --- a/javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/Knockout.java Fri Apr 12 16:13:50 2013 +0200 +++ b/javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/Knockout.java Sat Apr 13 09:14:54 2013 +0200 @@ -146,7 +146,8 @@ Object ko = e.executeScript("ko"); try { - bnd.call("bnd", ko, bindings, model, prop, strip(getter), strip(setter), primitive, array); + KOProperty kop = new KOProperty(model, strip(getter), strip(setter)); + bnd.call("bnd", ko, bindings, kop, prop, "get", "set", primitive, array); LOG.log(Level.FINE, "binding defined for {0}: {1}", new Object[]{prop, ((JSObject)bindings).getMember(prop)}); } catch (Throwable ex) { LOG.log(Level.FINE, "binding failed for {0} on {1}", new Object[]{prop, bindings}); diff -r cab175cc3358 -r 094cd25a16d9 javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/PageProcessor.java --- a/javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/PageProcessor.java Fri Apr 12 16:13:50 2013 +0200 +++ b/javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/PageProcessor.java Sat Apr 13 09:14:54 2013 +0200 @@ -193,7 +193,7 @@ w.append("import org.apidesign.bck2brwsr.htmlpage.api.*;\n"); w.append("import org.apidesign.bck2brwsr.htmlpage.KOList;\n"); w.append("import org.apidesign.bck2brwsr.core.JavaScriptOnly;\n"); - w.append("public final class ").append(className).append(" implements Cloneable {\n"); + w.append("final class ").append(className).append(" implements Cloneable {\n"); w.append(" private boolean locked;\n"); w.append(" private org.apidesign.bck2brwsr.htmlpage.Knockout ko;\n"); w.append(body.toString()); @@ -343,7 +343,7 @@ w.append("package " + pkg + ";\n"); w.append("import org.apidesign.bck2brwsr.htmlpage.api.*;\n"); w.append("import org.apidesign.bck2brwsr.htmlpage.KOList;\n"); - w.append("public final class ").append(className).append(" {\n"); + w.append("final class ").append(className).append(" {\n"); w.append(" private boolean locked;\n"); if (!initializeOnClick(className, (TypeElement) e, w, pp)) { ok = false;