X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2Fplat%2FJava2.java;h=f1a2acd81dc5530d78724a068d6cc36075f794bb;hb=ac45417ed6e9e7b49c4cc187f25dcc756df95b53;hp=629858cbaf096f21b882ad4c8ab85a1d9a607009;hpb=85b1ed8a659af79fb374a5e2c82516b094667ac1;p=org.ibex.core.git diff --git a/src/org/xwt/plat/Java2.java b/src/org/xwt/plat/Java2.java index 629858c..f1a2acd 100644 --- a/src/org/xwt/plat/Java2.java +++ b/src/org/xwt/plat/Java2.java @@ -104,7 +104,21 @@ public class Java2 extends AWT { protected DoubleBuffer _createDoubleBuffer(int w, int h, Surface owner) { return new Java2DoubleBuffer(w, h); } protected Surface _createSurface(final Box root, final boolean framed) { return (Surface)java.security.AccessController.doPrivileged(new java.security.PrivilegedAction() { - public Object run() { return isJava14 ? new Java14Surface(root, framed) : new Java2Surface(root, framed); } + public Object run() { + if (isJava14) { + try { + // weaken the binding here to avoid link errors on 1.3.x + Class java14SurfaceClass = Class.forName(Java2.class.getName() + "$Java14Surface"); + Constructor ctor = java14SurfaceClass.getConstructor(new Class[] { Box.class, Boolean.TYPE }); + return (Surface)ctor.newInstance(new Object[] { root, new Boolean(framed) }); + } catch (Exception e) { + Log.log(this, e); + throw new LinkageError("error: " + e); + } + } else { + return new Java2Surface(root, framed); + } + } }); } @@ -263,7 +277,7 @@ public class Java2 extends AWT { }); } - protected String getDescriptiveName() { return "Java 1.2+ JVM"; } + protected String getDescriptiveName() { return isJava14 ? "Java 1.4+ JVM" : "Java 1.2+ JVM"; } protected void _newBrowserWindow(String url) { if (Main.applet == null) {