# HG changeset patch # User lana # Date 1407776835 25200 # Node ID ff5b8d49be951d45305b4443e054b62b84abd9f7 # Parent 62406a5c83454b37dff2de10fa1daa56a11a9fb0# Parent 17acdbe290b253db1aeed5676a3764a7ca756512 Merge diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/.hgtags diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/make/build.xml --- a/nashorn/make/build.xml Sun Aug 10 19:39:07 2014 -0700 +++ b/nashorn/make/build.xml Mon Aug 11 10:07:15 2014 -0700 @@ -582,6 +582,8 @@ + + diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/make/project.properties --- a/nashorn/make/project.properties Sun Aug 10 19:39:07 2014 -0700 +++ b/nashorn/make/project.properties Mon Aug 11 10:07:15 2014 -0700 @@ -202,7 +202,7 @@ # list of test262 test dirs to be excluded test262-test-sys-prop.test.js.exclude.dir=\ ${test262.suite.dir}/intl402/ \ - ${test262.suite.dir}/bestPractice/ + ${test262.suite.dir}/bestPractice/ test262-test-sys-prop.test.failed.list.file=${build.dir}/test/failedTests @@ -217,7 +217,7 @@ ${test262.dir}/test/harness/sta.js # testmarkdown test root -testmarkdown-test-sys-prop.test.js.roots=${testmarkdown.dir} +testmarkdown-test-sys-prop.test.js.roots=${testmarkdown.dir} # execute testmarkdown tests in shared nashorn context or not? testmarkdown-test-sys-prop.test.js.shared.context=false @@ -227,7 +227,7 @@ ${test.script.dir}${file.separator}markdown.js # testjfx test root -testjfx-test-sys-prop.test.js.roots=${testjfx.dir} +testjfx-test-sys-prop.test.js.roots=${testjfx.dir} # execute testjfx tests in shared nashorn context or not? testjfx-test-sys-prop.test.js.shared.context=false diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/samples/zipfs.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/nashorn/samples/zipfs.js Mon Aug 11 10:07:15 2014 -0700 @@ -0,0 +1,48 @@ +/* + * Copyright (c) 2014, 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. + */ + +if (arguments.length == 0) { + print("Usage: jjs zipfs.js -- <.zip/.jar file>") + exit(1) +} + +var Files = Java.type("java.nio.file.Files") +var FileSystems = Java.type("java.nio.file.FileSystems") +var FileVisitOption = Java.type("java.nio.file.FileVisitOption") +var Paths = Java.type("java.nio.file.Paths") + +var zipfile = Paths.get(arguments[0]) +var fs = FileSystems.newFileSystem(zipfile, null) +var root = fs.rootDirectories[0] +Files.walk(root, FileVisitOption.FOLLOW_LINKS).forEach( + function(p) (print(p), print(Files.readAttributes(p, "zip:*"))) +) +fs.close() diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/samples/ziplist.js --- a/nashorn/samples/ziplist.js Sun Aug 10 19:39:07 2014 -0700 +++ b/nashorn/samples/ziplist.js Mon Aug 11 10:07:15 2014 -0700 @@ -30,7 +30,7 @@ */ if (arguments.length == 0) { - print("Usage: jjs ziplist "); + print("Usage: jjs ziplist -- "); exit(1); } diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java --- a/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java Sun Aug 10 19:39:07 2014 -0700 +++ b/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java Mon Aug 11 10:07:15 2014 -0700 @@ -715,6 +715,23 @@ return newArgs; } + /** + * Are the given objects mirrors to same underlying object? + * + * @param obj1 first object + * @param obj2 second object + * @return true if obj1 and obj2 are identical script objects or mirrors of it. + */ + public static boolean identical(final Object obj1, final Object obj2) { + final Object o1 = (obj1 instanceof ScriptObjectMirror)? + ((ScriptObjectMirror)obj1).sobj : obj1; + + final Object o2 = (obj2 instanceof ScriptObjectMirror)? + ((ScriptObjectMirror)obj2).sobj : obj2; + + return o1 == o2; + } + // package-privates below this. ScriptObjectMirror(final ScriptObject sobj, final Global global) { diff -r 62406a5c8345 -r ff5b8d49be95 nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java Sun Aug 10 19:39:07 2014 -0700 +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java Mon Aug 11 10:07:15 2014 -0700 @@ -250,8 +250,6 @@ private final Deque