From 06e15f698248e45b5afe50e507b3285c75cebadd Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Tue, 26 Sep 2017 20:29:13 +0530 Subject: [PATCH] 8187965: dynalink samples under $jdk10/src/sample/nashorn/dynalink are broken Reviewed-by: jlaskey, hannesw --- src/sample/nashorn/base64.js | 49 +++++++++++++++++++ src/sample/nashorn/dynalink/README | 6 --- .../nashorn/dynalink/array_stream_linker.js | 8 +-- .../dynalink/buffer_indexing_linker.js | 8 +-- src/sample/nashorn/dynalink/dom_linker.js | 6 ++- src/sample/nashorn/dynalink/jarutil.js | 45 +++++++++++++++++ .../nashorn/dynalink/missing_method_linker.js | 8 +-- .../nashorn/dynalink/underscore_linker.js | 8 +-- 8 files changed, 118 insertions(+), 20 deletions(-) create mode 100644 src/sample/nashorn/base64.js create mode 100644 src/sample/nashorn/dynalink/jarutil.js diff --git a/src/sample/nashorn/base64.js b/src/sample/nashorn/base64.js new file mode 100644 index 00000000000..c8d4d71b42d --- /dev/null +++ b/src/sample/nashorn/base64.js @@ -0,0 +1,49 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * - Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * - Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * - Neither the name of Oracle nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, + * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +// Usage: jjs --language=es6 base64.js + +const Base64 = Java.type("java.util.Base64"); +const ByteArray = Java.type("byte[]"); +const JString = Java.type("java.lang.String"); + +function toBase64(s) { + const ba = s instanceof ByteArray? s : String(s).bytes; + return Base64.encoder.encodeToString(ba); +} + +function fromBase64(s) { + const ba = s instanceof ByteArray? s : String(s).bytes; + return new JString(Base64.decoder.decode(ba)); +} + +print(toBase64`hello world`); +print(fromBase64(toBase64`hello world`)); diff --git a/src/sample/nashorn/dynalink/README b/src/sample/nashorn/dynalink/README index 6b53698846b..f0fee75143e 100644 --- a/src/sample/nashorn/dynalink/README +++ b/src/sample/nashorn/dynalink/README @@ -4,12 +4,6 @@ classpath of the jjs tool. Linker samples are named with the naming pattern "xyz_linker.js". These scripts build dynalink linker jar from java code and exec another jjs process with appropriate classpath set. -Note: you need to build jdk9 forest and put "images/jdk/bin" in your PATH to use -these scripts. This is because these scripts use javac to build dynalink jar and -exec another jjs with classpath set! Alternatively, you can also manually build -dynalink linker jars and invoke sample scripts by putting linker jar in jjs tool's -classpath as well. - Dynalink samples: * array_stream_linker.js diff --git a/src/sample/nashorn/dynalink/array_stream_linker.js b/src/sample/nashorn/dynalink/array_stream_linker.js index 91a5d6620ff..4e8ec194240 100644 --- a/src/sample/nashorn/dynalink/array_stream_linker.js +++ b/src/sample/nashorn/dynalink/array_stream_linker.js @@ -1,7 +1,7 @@ #! array stream linker example /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -37,10 +37,12 @@ $EXEC.throwOnError=true // compile ArrayStreamLinkerExporter -`javac -cp ../../dist/nashorn.jar ArrayStreamLinkerExporter.java` +`javac ArrayStreamLinkerExporter.java` + +load("jarutil.js"); // make a jar file out of pluggable linker -`jar cvf array_stream_linker.jar ArrayStreamLinkerExporter*.class META-INF/` +makeJar("array_stream_linker.jar"); // run a sample script that uses pluggable linker // but make sure classpath points to the pluggable linker jar! diff --git a/src/sample/nashorn/dynalink/buffer_indexing_linker.js b/src/sample/nashorn/dynalink/buffer_indexing_linker.js index 669cf9bf871..eaa63b59d2d 100644 --- a/src/sample/nashorn/dynalink/buffer_indexing_linker.js +++ b/src/sample/nashorn/dynalink/buffer_indexing_linker.js @@ -1,7 +1,7 @@ # buffer indexing linker example /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -37,10 +37,12 @@ $EXEC.throwOnError=true // compile BufferIndexingLinkerExporter -`javac -cp ../../dist/nashorn.jar BufferIndexingLinkerExporter.java` +`javac BufferIndexingLinkerExporter.java` + +load("jarutil.js"); // make a jar file out of pluggable linker -`jar cvf buffer_indexing_linker.jar BufferIndexingLinkerExporter*.class META-INF/` +makeJar("buffer_indexing_linker.jar"); // run a sample script that uses pluggable linker // but make sure classpath points to the pluggable linker jar! diff --git a/src/sample/nashorn/dynalink/dom_linker.js b/src/sample/nashorn/dynalink/dom_linker.js index 6bc0318982e..44bb5bda1d2 100644 --- a/src/sample/nashorn/dynalink/dom_linker.js +++ b/src/sample/nashorn/dynalink/dom_linker.js @@ -37,10 +37,12 @@ $EXEC.throwOnError=true // compile DOMLinkerExporter -`javac -cp ../../dist/nashorn.jar DOMLinkerExporter.java` +`javac DOMLinkerExporter.java` + +load("jarutil.js"); // make a jar file out of pluggable linker -`jar cvf dom_linker.jar DOMLinkerExporter*.class META-INF/` +makeJar("dom_linker.jar"); // run a sample script that uses pluggable linker // but make sure classpath points to the pluggable linker jar! diff --git a/src/sample/nashorn/dynalink/jarutil.js b/src/sample/nashorn/dynalink/jarutil.js new file mode 100644 index 00000000000..e8a35fe2b63 --- /dev/null +++ b/src/sample/nashorn/dynalink/jarutil.js @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * + * - Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * - Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * - Neither the name of Oracle nor the names of its + * contributors may be used to endorse or promote products derived + * from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS + * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, + * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING + * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +function classFiles() { + var arr = new java.io.File(".").listFiles( + new java.io.FilenameFilter() { + accept: function(dir, str) str.endsWith(".class") + }); + var str = ""; + for (var i in arr) str += " " + arr[i]; + return str; +} + +function makeJar(name) { + $EXEC("jar cvf " + name + " META-INF/ " + classFiles()); + print($ERR); +} diff --git a/src/sample/nashorn/dynalink/missing_method_linker.js b/src/sample/nashorn/dynalink/missing_method_linker.js index 81f6124d0f3..60126611b7b 100644 --- a/src/sample/nashorn/dynalink/missing_method_linker.js +++ b/src/sample/nashorn/dynalink/missing_method_linker.js @@ -1,7 +1,7 @@ #! missing method linker example /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -37,10 +37,12 @@ $EXEC.throwOnError=true // compile MissingMethodLinkerExporter -`javac -cp ../../dist/nashorn.jar MissingMethodLinkerExporter.java MissingMethodHandler.java MissingMethodExample.java` +`javac MissingMethodLinkerExporter.java MissingMethodHandler.java MissingMethodExample.java` + +load("jarutil.js"); // make a jar file out of pluggable linker -`jar cvf missing_method_linker.jar MissingMethod*.class META-INF/` +makeJar("missing_method_linker.jar"); // run a sample script that uses pluggable linker // but make sure classpath points to the pluggable linker jar! diff --git a/src/sample/nashorn/dynalink/underscore_linker.js b/src/sample/nashorn/dynalink/underscore_linker.js index 82ad554de73..d9c46dd7e27 100644 --- a/src/sample/nashorn/dynalink/underscore_linker.js +++ b/src/sample/nashorn/dynalink/underscore_linker.js @@ -1,7 +1,7 @@ # underscore name translator dynalink linker example /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -37,10 +37,12 @@ $EXEC.throwOnError=true // compile UnderscoreNameLinkerExporter -`javac -cp ../../dist/nashorn.jar UnderscoreNameLinkerExporter.java` +`javac UnderscoreNameLinkerExporter.java` + +load('jarutil.js'); // make a jar file out of pluggable linker -`jar cvf underscore_linker.jar UnderscoreNameLinkerExporter*.class META-INF/` +makeJar("underscore_linker.jar"); // run a sample script that uses pluggable linker // but make sure classpath points to the pluggable linker jar!