aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--gwtquery-core/pom.xml7
-rw-r--r--gwtquery-core/src/main/java/com/google/gwt/query/client/GQ.java73
2 files changed, 61 insertions, 19 deletions
diff --git a/gwtquery-core/pom.xml b/gwtquery-core/pom.xml
index 62ad370c..04286df6 100644
--- a/gwtquery-core/pom.xml
+++ b/gwtquery-core/pom.xml
@@ -42,6 +42,13 @@
<classifier>sources</classifier>
<scope>provided</scope>
</dependency>
+ <!-- needed in server side if we don't include gwt-servlet
+ we will remove this when using elemental.json or android.json -->
+ <dependency>
+ <groupId>org.json</groupId>
+ <artifactId>json</artifactId>
+ <version>20140107</version>
+ </dependency>
</dependencies>
<build>
<resources>
diff --git a/gwtquery-core/src/main/java/com/google/gwt/query/client/GQ.java b/gwtquery-core/src/main/java/com/google/gwt/query/client/GQ.java
index a780602c..380c57ef 100644
--- a/gwtquery-core/src/main/java/com/google/gwt/query/client/GQ.java
+++ b/gwtquery-core/src/main/java/com/google/gwt/query/client/GQ.java
@@ -15,7 +15,11 @@
*/
package com.google.gwt.query.client;
-import com.google.gwt.core.client.GWT;
+import java.lang.reflect.InvocationTargetException;
+import java.lang.reflect.Method;
+
+import org.apache.http.MethodNotSupportedException;
+
import com.google.gwt.query.client.builders.JsonBuilder;
import com.google.gwt.query.client.builders.JsonFactory;
import com.google.gwt.query.client.plugins.ajax.Ajax.AjaxTransport;
@@ -27,11 +31,13 @@ import com.google.gwt.query.vm.JsonFactoryJre;
* A set of useful methods for gQuery which can be run in browser or JVM.
*/
public abstract class GQ {
-
+
private static AjaxTransport ajaxTransport;
-
+
private static JsonFactory jsonFactory;
+ private static Boolean isClient;
+
public static IsProperties create() {
return getFactory().create();
}
@@ -62,7 +68,7 @@ public abstract class GQ {
ret.load(payload);
return ret;
}
-
+
/**
* Create an instance of IsProperties, a Properties JavaScriptObject in the client
* side and a proxy object in the JVM.
@@ -76,7 +82,7 @@ public abstract class GQ {
* side and a proxy object in the JVM.
*
* If fixJson is set, we correct certain errors in the Json string. It is useful
- * for generating Properties using java strings, so as we can use a more relaxed
+ * for generating Properties using java strings, so as we can use a more relaxed
* syntax.
*/
public static IsProperties create(String s, boolean fixJson) {
@@ -85,32 +91,61 @@ public abstract class GQ {
/**
* Return the appropriate transport implementation depending on the runtime
- * environment: browser or JVM
+ * environment: browser or JVM
*/
public static AjaxTransport getAjaxTransport() {
- if (ajaxTransport == null) {
- ajaxTransport = GWT.isClient() ?
- new AjaxTransportJs() :
- new AjaxTransportJre();
- }
+ initFactory();
return ajaxTransport;
}
private static JsonFactory getFactory() {
- if (jsonFactory == null) {
- jsonFactory = GWT.isClient() ?
- GWT.<JsonFactory>create(JsonFactory.class) :
- new JsonFactoryJre();
- }
+ initFactory();
return jsonFactory;
}
-
+
/**
- * Change the default Ajax transport by a customized one, useful for
+ * Change the default Ajax transport by a customized one, useful for
* testing purposes.
*/
public static void setAjaxTransport(AjaxTransport transport) {
ajaxTransport = transport;
}
-
+
+ /*
+ * Create the appropriate version of factories depending
+ * if whether we are running dev-mode
+ */
+ private static void initFactory() {
+ if (jsonFactory == null) {
+ try {
+ // We use reflection because the server side should not
+ // depend on gwt-servlet nor gwt-dev. Hence if GWT is not
+ // in our classpath means that we are in server side, otherwise
+ // we use GWT to figure out if we are running devmode.
+ // This is run once, so no performance issues to worry about.
+ Class.forName("com.google.gwt.core.shared.GWTBridge");
+ Class<?> gwt = Class.forName("com.google.gwt.core.shared.GWT");
+ Method method = gwt.getMethod("isClient");
+ Object ret = method.invoke(null);
+ if (ret instanceof Boolean && ((Boolean) ret)) {
+ // We are running DevMode, so create Js versions of the factories
+ method = gwt.getMethod("create", Class.class);
+ ret = method.invoke(null,
+ new Object[] {JsonFactory.class});
+ jsonFactory = (JsonFactory) ret;
+ ajaxTransport = new AjaxTransportJs();
+ return;
+ }
+ } catch (ClassNotFoundException ignore) {
+ } catch (NoSuchMethodException ignore) {
+ } catch (SecurityException ignore) {
+ } catch (IllegalAccessException ignore) {
+ } catch (IllegalArgumentException ignore) {
+ } catch (InvocationTargetException ignore) {
+ }
+ // We are running in the JVM, so create Jre versions.
+ jsonFactory = new JsonFactoryJre();
+ ajaxTransport = new AjaxTransportJre();
+ }
+ }
}