X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FBox.java;h=c3fec81e46597219f3743578d608f3d8144aa983;hb=c40cc244dc85706fb2227db695dfed84f08e5faf;hp=c50ff7b986cffe05a51820995fc92f37b0fa7834;hpb=77f51cd3e157cf6fd2ae85ce774444bb85ea7b81;p=org.ibex.core.git diff --git a/src/org/xwt/Box.java b/src/org/xwt/Box.java index c50ff7b..c3fec81 100644 --- a/src/org/xwt/Box.java +++ b/src/org/xwt/Box.java @@ -1504,4 +1504,31 @@ public final class Box extends JS.Scope { } - +/** this is in Box.java solely to work around a GCJ bug */ +class Apply extends JS.Callable { + Box b; + public Apply(Box b) { this.b = b; } + public Object call(JS.Array args) throws JS.Exn { + if (args.elementAt(0) instanceof String) { + String templatename = (String)args.elementAt(0); + Template t = Template.getTemplate(templatename, null); + if (t == null) { + if (Log.on) Log.logJS(this, "template " + templatename + " not found"); + } else { + if (ThreadMessage.suspendThread()) try { + JS.Callable callback = args.length() < 2 ? null : (Callable)args.elementAt(1); + t.apply(b, null, null, callback, 0, t.numUnits()); + } finally { + ThreadMessage.resumeThread(); + } + } + + } else if (args.elementAt(0) instanceof JS && !(args.elementAt(0) instanceof Box)) { + JS s = (JS)args.elementAt(0); + Object[] keys = s.keys(); + for(int j=0; j