nashorn/test/src/jdk/nashorn/internal/codegen/CompilerTest.java
author lagergren
Mon, 03 Nov 2014 11:47:41 +0100
changeset 27361 86c4ddb4797b
parent 27106 d2d7e511c05c
child 29407 3fd4ede1581e
permissions -rw-r--r--
8060204: Fix warnings in Joni and tests Reviewed-by: hannesw, sundar, attila
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     1
/*
16151
97c1e756ae1e 8005663: Update copyright year to 2013
jlaskey
parents: 16147
diff changeset
     2
 * Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved.
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     4
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    10
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    15
 * accompanied this code).
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    16
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    20
 *
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    23
 * questions.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    24
 */
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    25
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    26
package jdk.nashorn.internal.codegen;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    27
24769
attila
parents: 24727 24279
diff changeset
    28
import static jdk.nashorn.internal.runtime.Source.readFully;
24206
40c6d45af73f 8040078: Avoid repeated reading of source for cached loads
hannesw
parents: 23375
diff changeset
    29
import static jdk.nashorn.internal.runtime.Source.sourceFor;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    30
import java.io.File;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    31
import java.io.PrintWriter;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    32
import java.io.StringWriter;
23375
a1110f2cbe75 8037400: Remove getInitialMap getters and GlobalObject interface
sundar
parents: 19456
diff changeset
    33
import jdk.nashorn.internal.objects.Global;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    34
import jdk.nashorn.internal.runtime.Context;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    35
import jdk.nashorn.internal.runtime.ErrorManager;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    36
import jdk.nashorn.internal.runtime.ScriptFunction;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    37
import jdk.nashorn.internal.runtime.Source;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    38
import jdk.nashorn.internal.runtime.options.Options;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    39
import org.testng.Assert;
19456
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    40
import org.testng.annotations.AfterClass;
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    41
import org.testng.annotations.BeforeClass;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    42
import org.testng.annotations.Test;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    43
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    44
/**
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    45
 * Tests to check Nashorn JS compiler - just compiler and not execution of scripts.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    46
 */
27361
86c4ddb4797b 8060204: Fix warnings in Joni and tests
lagergren
parents: 27106
diff changeset
    47
@SuppressWarnings("javadoc")
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    48
public class CompilerTest {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    49
    private static final boolean VERBOSE  = Boolean.valueOf(System.getProperty("compilertest.verbose"));
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    50
    private static final boolean TEST262  = Boolean.valueOf(System.getProperty("compilertest.test262"));
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    51
    private static final String TEST_BASIC_DIR  = System.getProperty("test.basic.dir");
16530
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
    52
    private static final String TEST_NODE_DIR  = System.getProperty("test.node.dir");
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    53
    private static final String TEST262_SUITE_DIR = System.getProperty("test262.suite.dir");
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    54
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    55
    interface TestFilter {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    56
        public boolean exclude(File file, String content);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    57
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    58
27361
86c4ddb4797b 8060204: Fix warnings in Joni and tests
lagergren
parents: 27106
diff changeset
    59
    private static void log(final String msg) {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    60
        org.testng.Reporter.log(msg, true);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    61
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    62
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    63
    private Context context;
23375
a1110f2cbe75 8037400: Remove getInitialMap getters and GlobalObject interface
sundar
parents: 19456
diff changeset
    64
    private Global  global;
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    65
19456
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    66
    @BeforeClass
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    67
    public void setupTest() {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    68
        final Options options = new Options("nashorn");
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    69
        options.set("anon.functions", true);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    70
        options.set("compile.only", true);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    71
        options.set("print.ast", true);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    72
        options.set("print.parse", true);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    73
        options.set("scripting", true);
24279
33b0fbd03872 8027933: Add --const-as-var option
sundar
parents: 24206
diff changeset
    74
        options.set("const.as.var", true);
27106
d2d7e511c05c 8060688: Nashorn: Generated script class name fails --verify-code for names with special chars
sundar
parents: 26377
diff changeset
    75
        options.set("verify.code", true);
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    76
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    77
        final ErrorManager errors = new ErrorManager() {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    78
            @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    79
            public void error(final String msg) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    80
                log(msg);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    81
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    82
        };
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    83
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    84
        final StringWriter sw = new StringWriter();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    85
        final PrintWriter pw = new PrintWriter(sw);
16185
893aabe8c800 8006635: Reduce access levels as much as possible
sundar
parents: 16163
diff changeset
    86
        this.context = new Context(options, errors, pw, pw, Thread.currentThread().getContextClassLoader());
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    87
        this.global = context.createGlobal();
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    88
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    89
19456
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    90
    @AfterClass
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    91
    public void tearDownTest() {
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    92
        this.context = null;
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    93
        this.global = null;
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    94
    }
8cc345d620c8 8022524: Memory leaks in nashorn sources and tests found by jhat analysis
sundar
parents: 16530
diff changeset
    95
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    96
    @Test
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    97
    public void compileAllTests() {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
    98
        if (TEST262) {
16530
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
    99
            compileTestSet(new File(TEST262_SUITE_DIR), new TestFilter() {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   100
                @Override
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   101
                public boolean exclude(final File file, final String content) {
26377
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   102
                    return content != null && content.contains("@negative");
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   103
                }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   104
            });
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   105
        }
26377
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   106
        compileTestSet(new File(TEST_BASIC_DIR), new TestFilter() {
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   107
            @Override
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   108
            public boolean exclude(final File file, final String content) {
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   109
                return file.getName().equals("es6");
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   110
            }
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   111
        });
16530
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
   112
        compileTestSet(new File(TEST_NODE_DIR, "node"), null);
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
   113
        compileTestSet(new File(TEST_NODE_DIR, "src"), null);
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   114
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   115
16530
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
   116
    private void compileTestSet(final File testSetDir, final TestFilter filter) {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   117
        passed = 0;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   118
        failed = 0;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   119
        skipped = 0;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   120
        if (! testSetDir.isDirectory()) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   121
            log("WARNING: " + testSetDir + " not found or not a directory");
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   122
            return;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   123
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   124
        log(testSetDir.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   125
        compileJSDirectory(testSetDir, filter);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   126
16530
201d682e75f4 8010652: Eliminate non-child references in Block/FunctionNode, and make few node types immutable
attila
parents: 16230
diff changeset
   127
        log(testSetDir + " compile done!");
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   128
        log("compile ok: " + passed);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   129
        log("compile failed: " + failed);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   130
        log("compile skipped: " + skipped);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   131
        if (failed != 0) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   132
            Assert.fail(failed + " tests failed to compile in " + testSetDir.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   133
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   134
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   135
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   136
    // number of scripts that compiled fine
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   137
    private int passed;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   138
    // number of scripts resulting in compile failure
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   139
    private int failed;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   140
    // scripts that were skipped - all tests with @negative are
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   141
    // skipped for now.
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   142
    private int skipped;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   143
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   144
    private void compileJSDirectory(final File dir, final TestFilter filter) {
26377
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   145
        if (filter != null && filter.exclude(dir, null)) {
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   146
            return;
028dad61662f 8051889: Implement block scoping in symbol assignment and scope computation
hannesw
parents: 24778
diff changeset
   147
        }
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   148
        for (final File f : dir.listFiles()) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   149
            if (f.isDirectory()) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   150
                compileJSDirectory(f, filter);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   151
            } else if (f.getName().endsWith(".js")) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   152
                compileJSFile(f, filter);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   153
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   154
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   155
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   156
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   157
    private void compileJSFile(final File file, final TestFilter filter) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   158
        if (VERBOSE) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   159
            log("Begin compiling " + file.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   160
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   161
23375
a1110f2cbe75 8037400: Remove getInitialMap getters and GlobalObject interface
sundar
parents: 19456
diff changeset
   162
        final Global oldGlobal = Context.getGlobal();
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   163
        final boolean globalChanged = (oldGlobal != global);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   164
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   165
        try {
24206
40c6d45af73f 8040078: Avoid repeated reading of source for cached loads
hannesw
parents: 23375
diff changeset
   166
            final char[] buffer = readFully(file);
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   167
            boolean excluded = false;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   168
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   169
            if (filter != null) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   170
                final String content = new String(buffer);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   171
                excluded = filter.exclude(file, content);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   172
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   173
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   174
            if (excluded) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   175
                if (VERBOSE) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   176
                    log("Skipping " + file.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   177
                }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   178
                skipped++;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   179
                return;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   180
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   181
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   182
            if (globalChanged) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   183
                Context.setGlobal(global);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   184
            }
24206
40c6d45af73f 8040078: Avoid repeated reading of source for cached loads
hannesw
parents: 23375
diff changeset
   185
            final Source source = sourceFor(file.getAbsolutePath(), buffer);
16230
c38c724d82e7 8008103: Source object should maintain URL of the script source as a private field
sundar
parents: 16185
diff changeset
   186
            final ScriptFunction script = context.compileScript(source, global);
16185
893aabe8c800 8006635: Reduce access levels as much as possible
sundar
parents: 16163
diff changeset
   187
            if (script == null || context.getErrorManager().getNumberOfErrors() > 0) {
16147
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   188
                log("Compile failed: " + file.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   189
                failed++;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   190
            } else {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   191
                passed++;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   192
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   193
        } catch (final Throwable t) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   194
            log("Compile failed: " + file.getAbsolutePath() + " : " + t);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   195
            if (VERBOSE) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   196
                t.printStackTrace(System.out);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   197
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   198
            failed++;
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   199
        } finally {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   200
            if (globalChanged) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   201
                Context.setGlobal(oldGlobal);
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   202
            }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   203
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   204
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   205
        if (VERBOSE) {
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   206
            log("Done compiling " + file.getAbsolutePath());
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   207
        }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   208
    }
e63b63819133 8005403: Open-source Nashorn
jlaskey
parents:
diff changeset
   209
}