WebSocketTest passes OK against modified version of 0.5 net.java.html APIs - rev. b04268c0ded9
authorJaroslav Tulach <jaroslav.tulach@apidesign.org>
Thu, 29 Aug 2013 14:35:01 +0000
changeset 1253a936dd8280dc
parent 1252 e414f379f378
child 1254 2e0da2375ef5
WebSocketTest passes OK against modified version of 0.5 net.java.html APIs - rev. b04268c0ded9
ko/bck2brwsr/pom.xml
ko/bck2brwsr/src/main/java/org/apidesign/bck2brwsr/ko2brwsr/BrwsrCtxImpl.java
ko/bck2brwsr/src/main/java/org/apidesign/bck2brwsr/ko2brwsr/LoadWS.java
ko/bck2brwsr/src/test/java/org/apidesign/bck2brwsr/ko2brwsr/Bck2BrwsrKnockoutTest.java
launcher/fx/src/main/java/org/apidesign/bck2brwsr/launcher/BaseHTTPLauncher.java
launcher/pom.xml
     1.1 --- a/ko/bck2brwsr/pom.xml	Thu Aug 29 08:00:42 2013 +0000
     1.2 +++ b/ko/bck2brwsr/pom.xml	Thu Aug 29 14:35:01 2013 +0000
     1.3 @@ -92,5 +92,11 @@
     1.4        <version>${project.version}</version>
     1.5        <type>jar</type>
     1.6      </dependency>
     1.7 +    <dependency>
     1.8 +      <groupId>org.apidesign.html</groupId>
     1.9 +      <artifactId>net.java.html.boot</artifactId>
    1.10 +      <version>0.5</version>
    1.11 +      <type>jar</type>
    1.12 +    </dependency>
    1.13    </dependencies>
    1.14  </project>
     2.1 --- a/ko/bck2brwsr/src/main/java/org/apidesign/bck2brwsr/ko2brwsr/BrwsrCtxImpl.java	Thu Aug 29 08:00:42 2013 +0000
     2.2 +++ b/ko/bck2brwsr/src/main/java/org/apidesign/bck2brwsr/ko2brwsr/BrwsrCtxImpl.java	Thu Aug 29 14:35:01 2013 +0000
     2.3 @@ -26,12 +26,13 @@
     2.4  import org.apidesign.html.json.spi.PropertyBinding;
     2.5  import org.apidesign.html.json.spi.Technology;
     2.6  import org.apidesign.html.json.spi.Transfer;
     2.7 +import org.apidesign.html.json.spi.WSTransfer;
     2.8  
     2.9  /**
    2.10   *
    2.11   * @author Jaroslav Tulach <jtulach@netbeans.org>
    2.12   */
    2.13 -final class BrwsrCtxImpl implements Technology<Object>, Transfer {
    2.14 +final class BrwsrCtxImpl implements Technology<Object>, Transfer, WSTransfer<LoadWS> {
    2.15      private BrwsrCtxImpl() {}
    2.16      
    2.17      public static final BrwsrCtxImpl DEFAULT = new BrwsrCtxImpl();
    2.18 @@ -126,4 +127,19 @@
    2.19      public void runSafe(Runnable r) {
    2.20          r.run();
    2.21      }
    2.22 +
    2.23 +    @Override
    2.24 +    public LoadWS open(String url, JSONCall callback) {
    2.25 +        return new LoadWS(callback, url);
    2.26 +    }
    2.27 +
    2.28 +    @Override
    2.29 +    public void send(LoadWS socket, JSONCall data) {
    2.30 +        socket.send(data);
    2.31 +    }
    2.32 +
    2.33 +    @Override
    2.34 +    public void close(LoadWS socket) {
    2.35 +        socket.close();
    2.36 +    }
    2.37  }
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/ko/bck2brwsr/src/main/java/org/apidesign/bck2brwsr/ko2brwsr/LoadWS.java	Thu Aug 29 14:35:01 2013 +0000
     3.3 @@ -0,0 +1,126 @@
     3.4 +/**
     3.5 + * Back 2 Browser Bytecode Translator
     3.6 + * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
     3.7 + *
     3.8 + * This program is free software: you can redistribute it and/or modify
     3.9 + * it under the terms of the GNU General Public License as published by
    3.10 + * the Free Software Foundation, version 2 of the License.
    3.11 + *
    3.12 + * This program is distributed in the hope that it will be useful,
    3.13 + * but WITHOUT ANY WARRANTY; without even the implied warranty of
    3.14 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    3.15 + * GNU General Public License for more details.
    3.16 + *
    3.17 + * You should have received a copy of the GNU General Public License
    3.18 + * along with this program. Look for COPYING file in the top folder.
    3.19 + * If not, see http://opensource.org/licenses/GPL-2.0.
    3.20 + */
    3.21 +package org.apidesign.bck2brwsr.ko2brwsr;
    3.22 +
    3.23 +import net.java.html.js.JavaScriptBody;
    3.24 +import org.apidesign.html.json.spi.JSONCall;
    3.25 +
    3.26 +/** Communication with WebSockets for WebView 1.8.
    3.27 + *
    3.28 + * @author Jaroslav Tulach <jtulach@netbeans.org>
    3.29 + */
    3.30 +final class LoadWS {
    3.31 +    private static final boolean SUPPORTED = isWebSocket();
    3.32 +    private final Object ws;
    3.33 +    private final JSONCall call;
    3.34 +    LoadWS(JSONCall first, String url) {
    3.35 +        call = first;
    3.36 +        ws = initWebSocket(this, url);
    3.37 +        if (ws == null) {
    3.38 +            first.notifyError(new IllegalArgumentException("Wrong URL: " + url));
    3.39 +        }
    3.40 +    }
    3.41 +    
    3.42 +    static boolean isSupported() {
    3.43 +        return SUPPORTED;
    3.44 +    }
    3.45 +    
    3.46 +    void send(JSONCall call) {
    3.47 +        push(call);
    3.48 +    }
    3.49 +    
    3.50 +    private synchronized void push(JSONCall call) {
    3.51 +        send(ws, call.getMessage());
    3.52 +    }
    3.53 +
    3.54 +    void onOpen(Object ev) {
    3.55 +        if (!call.isDoOutput()) {
    3.56 +            call.notifySuccess(null);
    3.57 +        }
    3.58 +    }
    3.59 +    
    3.60 +    
    3.61 +    @JavaScriptBody(args = { "data" }, body = "try {\n"
    3.62 +        + "    return eval('(' + data + ')');\n"
    3.63 +        + "  } catch (error) {;\n"
    3.64 +        + "    return data;\n"
    3.65 +        + "  }\n"
    3.66 +    )
    3.67 +    private static native Object toJSON(String data);
    3.68 +    
    3.69 +    void onMessage(Object ev, String data) {
    3.70 +        Object json = toJSON(data);
    3.71 +        call.notifySuccess(json);
    3.72 +    }
    3.73 +    
    3.74 +    void onError(Object ev) {
    3.75 +        call.notifyError(new Exception(ev.toString()));
    3.76 +    }
    3.77 +
    3.78 +    void onClose(boolean wasClean, int code, String reason) {
    3.79 +        call.notifyError(null);
    3.80 +    }
    3.81 +    
    3.82 +    @JavaScriptBody(args = {}, body = "if (window.WebSocket) return true; else return false;")
    3.83 +    private static boolean isWebSocket() {
    3.84 +        return false;
    3.85 +    }
    3.86 +
    3.87 +    @JavaScriptBody(args = { "back", "url" }, javacall = true, body = ""
    3.88 +        + "if (window.WebSocket) {\n"
    3.89 +        + "  try {\n"
    3.90 +        + "    var ws = new window.WebSocket(url);\n"
    3.91 +        + "    ws.onopen = function(ev) {\n"
    3.92 +        + "      back.@org.apidesign.bck2brwsr.ko2brwsr.LoadWS::onOpen(Ljava/lang/Object;)(ev);\n"
    3.93 +        + "    };\n"
    3.94 +        + "    ws.onmessage = function(ev) {\n"
    3.95 +        + "      back.@org.apidesign.bck2brwsr.ko2brwsr.LoadWS::onMessage(Ljava/lang/Object;Ljava/lang/String;)(ev, ev.data);\n"
    3.96 +        + "    };\n"
    3.97 +        + "    ws.onerror = function(ev) {\n"
    3.98 +        + "      back.@org.apidesign.bck2brwsr.ko2brwsr.LoadWS::onError(Ljava/lang/Object;)(ev);\n"
    3.99 +        + "    };\n"
   3.100 +        + "    ws.onclose = function(ev) {\n"
   3.101 +        + "      back.@org.apidesign.bck2brwsr.ko2brwsr.LoadWS::onClose(ZILjava/lang/String;)(ev.wasClean, ev.code, ev.reason);\n"
   3.102 +        + "    };\n"
   3.103 +        + "    return ws;\n"
   3.104 +        + "  } catch (ex) {\n"
   3.105 +        + "    return null;\n"
   3.106 +        + "  }\n"
   3.107 +        + "} else {\n"
   3.108 +        + "  return null;\n"
   3.109 +        + "}\n"
   3.110 +    )
   3.111 +    private static Object initWebSocket(Object back, String url) {
   3.112 +        return null;
   3.113 +    }
   3.114 +    
   3.115 +
   3.116 +    @JavaScriptBody(args = { "ws", "msg" }, body = ""
   3.117 +        + "ws.send(msg);"
   3.118 +    )
   3.119 +    private void send(Object ws, String msg) {
   3.120 +    }
   3.121 +
   3.122 +    @JavaScriptBody(args = { "ws" }, body = "ws.close();")
   3.123 +    private static void close(Object ws) {
   3.124 +    }
   3.125 +
   3.126 +    void close() {
   3.127 +        close(ws);
   3.128 +    }
   3.129 +}
     4.1 --- a/ko/bck2brwsr/src/test/java/org/apidesign/bck2brwsr/ko2brwsr/Bck2BrwsrKnockoutTest.java	Thu Aug 29 08:00:42 2013 +0000
     4.2 +++ b/ko/bck2brwsr/src/test/java/org/apidesign/bck2brwsr/ko2brwsr/Bck2BrwsrKnockoutTest.java	Thu Aug 29 14:35:01 2013 +0000
     4.3 @@ -28,6 +28,7 @@
     4.4  import org.apidesign.html.context.spi.Contexts;
     4.5  import org.apidesign.html.json.spi.Technology;
     4.6  import org.apidesign.html.json.spi.Transfer;
     4.7 +import org.apidesign.html.json.spi.WSTransfer;
     4.8  import org.apidesign.html.json.tck.KOTest;
     4.9  import org.apidesign.html.json.tck.KnockoutTCK;
    4.10  import org.openide.util.lookup.ServiceProvider;
    4.11 @@ -51,6 +52,7 @@
    4.12      public BrwsrCtx createContext() {
    4.13          return Contexts.newBuilder().
    4.14              register(Transfer.class, BrwsrCtxImpl.DEFAULT, 9).
    4.15 +            register(WSTransfer.class, BrwsrCtxImpl.DEFAULT, 9).
    4.16              register(Technology.class, BrwsrCtxImpl.DEFAULT, 9).build();
    4.17      }
    4.18  
     5.1 --- a/launcher/fx/src/main/java/org/apidesign/bck2brwsr/launcher/BaseHTTPLauncher.java	Thu Aug 29 08:00:42 2013 +0000
     5.2 +++ b/launcher/fx/src/main/java/org/apidesign/bck2brwsr/launcher/BaseHTTPLauncher.java	Thu Aug 29 14:35:01 2013 +0000
     5.3 @@ -157,29 +157,29 @@
     5.4      
     5.5      private HttpServer initServer(String path, boolean addClasses) throws IOException {
     5.6          HttpServer s = HttpServer.createSimpleServer(path, new PortRange(8080, 65535));
     5.7 -        final WebSocketAddOn addon = new WebSocketAddOn();
     5.8 -        for (NetworkListener listener : s.getListeners()) {
     5.9 -            listener.registerAddOn(addon);
    5.10 -        }
    5.11 -        
    5.12 +        /*
    5.13          ThreadPoolConfig fewThreads = ThreadPoolConfig.defaultConfig().copy().
    5.14              setPoolName("Fx/Bck2 Brwsr").
    5.15 -            setCorePoolSize(1).
    5.16 +            setCorePoolSize(3).
    5.17              setMaxPoolSize(5);
    5.18          ThreadPoolConfig oneKernel = ThreadPoolConfig.defaultConfig().copy().
    5.19              setPoolName("Kernel Fx/Bck2").
    5.20 -            setCorePoolSize(1).
    5.21 +            setCorePoolSize(3).
    5.22              setMaxPoolSize(3);
    5.23          for (NetworkListener nl : s.getListeners()) {
    5.24              nl.getTransport().setWorkerThreadPoolConfig(fewThreads);
    5.25              nl.getTransport().setKernelThreadPoolConfig(oneKernel);
    5.26          }
    5.27 -        
    5.28 +        */
    5.29          final ServerConfiguration conf = s.getServerConfiguration();
    5.30          if (addClasses) {
    5.31              conf.addHttpHandler(new VM(), "/bck2brwsr.js");
    5.32              conf.addHttpHandler(new Classes(resources), "/classes/");
    5.33          }
    5.34 +        final WebSocketAddOn addon = new WebSocketAddOn();
    5.35 +        for (NetworkListener listener : s.getListeners()) {
    5.36 +            listener.registerAddOn(addon);
    5.37 +        }
    5.38          return s;
    5.39      }
    5.40      
     6.1 --- a/launcher/pom.xml	Thu Aug 29 08:00:42 2013 +0000
     6.2 +++ b/launcher/pom.xml	Thu Aug 29 14:35:01 2013 +0000
     6.3 @@ -12,7 +12,7 @@
     6.4    <packaging>pom</packaging>
     6.5    <name>Launchers</name>
     6.6    <properties>
     6.7 -      <grizzly.version>2.3.2</grizzly.version>
     6.8 +      <grizzly.version>2.3.3</grizzly.version>
     6.9    </properties>
    6.10    <modules>
    6.11      <module>api</module>