langtools/src/share/classes/com/sun/tools/javac/main/JavaCompiler.java
author jjg
Fri, 26 Jun 2009 19:47:12 -0700
changeset 3151 41800a86aad3
parent 2984 e15ff3a34054
child 3557 a803afefa115
permissions -rw-r--r--
6854796: update JSR308 impl with latest code from type-annotations repo Reviewed-by: jjg, mcimadamore, darcy Contributed-by: mernst@cs.washington.edu, mali@csail.mit.edu, mpapi@csail.mit.edu
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
2212
1d3dc0e0ba0c 6814575: Update copyright year
xdono
parents: 1996
diff changeset
     2
 * Copyright 1999-2009 Sun Microsystems, Inc.  All Rights Reserved.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
06bc494ca11e Initial load
duke
parents:
diff changeset
     4
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
06bc494ca11e Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
06bc494ca11e Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Sun designates this
06bc494ca11e Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
06bc494ca11e Initial load
duke
parents:
diff changeset
     9
 * by Sun in the LICENSE file that accompanied this code.
06bc494ca11e Initial load
duke
parents:
diff changeset
    10
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
06bc494ca11e Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
06bc494ca11e Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
06bc494ca11e Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
06bc494ca11e Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
06bc494ca11e Initial load
duke
parents:
diff changeset
    16
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
06bc494ca11e Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
06bc494ca11e Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
06bc494ca11e Initial load
duke
parents:
diff changeset
    20
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    21
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
06bc494ca11e Initial load
duke
parents:
diff changeset
    22
 * CA 95054 USA or visit www.sun.com if you need additional information or
06bc494ca11e Initial load
duke
parents:
diff changeset
    23
 * have any questions.
06bc494ca11e Initial load
duke
parents:
diff changeset
    24
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    25
06bc494ca11e Initial load
duke
parents:
diff changeset
    26
package com.sun.tools.javac.main;
06bc494ca11e Initial load
duke
parents:
diff changeset
    27
06bc494ca11e Initial load
duke
parents:
diff changeset
    28
import java.io.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    29
import java.util.HashSet;
1046
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
    30
import java.util.LinkedHashSet;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    31
import java.util.LinkedHashMap;
06bc494ca11e Initial load
duke
parents:
diff changeset
    32
import java.util.Map;
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
import java.util.MissingResourceException;
06bc494ca11e Initial load
duke
parents:
diff changeset
    34
import java.util.ResourceBundle;
06bc494ca11e Initial load
duke
parents:
diff changeset
    35
import java.util.Set;
06bc494ca11e Initial load
duke
parents:
diff changeset
    36
import java.util.logging.Handler;
06bc494ca11e Initial load
duke
parents:
diff changeset
    37
import java.util.logging.Level;
06bc494ca11e Initial load
duke
parents:
diff changeset
    38
import java.util.logging.Logger;
06bc494ca11e Initial load
duke
parents:
diff changeset
    39
06bc494ca11e Initial load
duke
parents:
diff changeset
    40
import javax.tools.JavaFileManager;
06bc494ca11e Initial load
duke
parents:
diff changeset
    41
import javax.tools.JavaFileObject;
06bc494ca11e Initial load
duke
parents:
diff changeset
    42
import javax.tools.DiagnosticListener;
06bc494ca11e Initial load
duke
parents:
diff changeset
    43
731
1dd22bdb9ca5 6714364: refactor javac File handling code into new javac.file package
jjg
parents: 169
diff changeset
    44
import com.sun.tools.javac.file.JavacFileManager;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    45
import com.sun.source.util.TaskEvent;
06bc494ca11e Initial load
duke
parents:
diff changeset
    46
import com.sun.source.util.TaskListener;
06bc494ca11e Initial load
duke
parents:
diff changeset
    47
06bc494ca11e Initial load
duke
parents:
diff changeset
    48
import com.sun.tools.javac.util.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
import com.sun.tools.javac.code.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    50
import com.sun.tools.javac.tree.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    51
import com.sun.tools.javac.parser.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    52
import com.sun.tools.javac.comp.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
import com.sun.tools.javac.jvm.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
import com.sun.tools.javac.code.Symbol.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
import com.sun.tools.javac.tree.JCTree.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
06bc494ca11e Initial load
duke
parents:
diff changeset
    58
import com.sun.tools.javac.processing.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    59
import javax.annotation.processing.Processor;
06bc494ca11e Initial load
duke
parents:
diff changeset
    60
06bc494ca11e Initial load
duke
parents:
diff changeset
    61
import static javax.tools.StandardLocation.CLASS_OUTPUT;
06bc494ca11e Initial load
duke
parents:
diff changeset
    62
import static com.sun.tools.javac.util.ListBuffer.lb;
06bc494ca11e Initial load
duke
parents:
diff changeset
    63
06bc494ca11e Initial load
duke
parents:
diff changeset
    64
// TEMP, until we have a more efficient way to save doc comment info
06bc494ca11e Initial load
duke
parents:
diff changeset
    65
import com.sun.tools.javac.parser.DocCommentScanner;
06bc494ca11e Initial load
duke
parents:
diff changeset
    66
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
    67
import java.util.HashMap;
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
    68
import java.util.Queue;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    69
import javax.lang.model.SourceVersion;
06bc494ca11e Initial load
duke
parents:
diff changeset
    70
06bc494ca11e Initial load
duke
parents:
diff changeset
    71
/** This class could be the main entry point for GJC when GJC is used as a
06bc494ca11e Initial load
duke
parents:
diff changeset
    72
 *  component in a larger software system. It provides operations to
06bc494ca11e Initial load
duke
parents:
diff changeset
    73
 *  construct a new compiler, and to run a new compiler on a set of source
06bc494ca11e Initial load
duke
parents:
diff changeset
    74
 *  files.
06bc494ca11e Initial load
duke
parents:
diff changeset
    75
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    76
 *  <p><b>This is NOT part of any API supported by Sun Microsystems.  If
06bc494ca11e Initial load
duke
parents:
diff changeset
    77
 *  you write code that depends on this, you do so at your own risk.
06bc494ca11e Initial load
duke
parents:
diff changeset
    78
 *  This code and its internal interfaces are subject to change or
06bc494ca11e Initial load
duke
parents:
diff changeset
    79
 *  deletion without notice.</b>
06bc494ca11e Initial load
duke
parents:
diff changeset
    80
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    81
public class JavaCompiler implements ClassReader.SourceCompleter {
06bc494ca11e Initial load
duke
parents:
diff changeset
    82
    /** The context key for the compiler. */
06bc494ca11e Initial load
duke
parents:
diff changeset
    83
    protected static final Context.Key<JavaCompiler> compilerKey =
06bc494ca11e Initial load
duke
parents:
diff changeset
    84
        new Context.Key<JavaCompiler>();
06bc494ca11e Initial load
duke
parents:
diff changeset
    85
06bc494ca11e Initial load
duke
parents:
diff changeset
    86
    /** Get the JavaCompiler instance for this context. */
06bc494ca11e Initial load
duke
parents:
diff changeset
    87
    public static JavaCompiler instance(Context context) {
06bc494ca11e Initial load
duke
parents:
diff changeset
    88
        JavaCompiler instance = context.get(compilerKey);
06bc494ca11e Initial load
duke
parents:
diff changeset
    89
        if (instance == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
    90
            instance = new JavaCompiler(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
    91
        return instance;
06bc494ca11e Initial load
duke
parents:
diff changeset
    92
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
    93
06bc494ca11e Initial load
duke
parents:
diff changeset
    94
    /** The current version number as a string.
06bc494ca11e Initial load
duke
parents:
diff changeset
    95
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    96
    public static String version() {
06bc494ca11e Initial load
duke
parents:
diff changeset
    97
        return version("release");  // mm.nn.oo[-milestone]
06bc494ca11e Initial load
duke
parents:
diff changeset
    98
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
    99
06bc494ca11e Initial load
duke
parents:
diff changeset
   100
    /** The current full version number as a string.
06bc494ca11e Initial load
duke
parents:
diff changeset
   101
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   102
    public static String fullVersion() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   103
        return version("full"); // mm.mm.oo[-milestone]-build
06bc494ca11e Initial load
duke
parents:
diff changeset
   104
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
06bc494ca11e Initial load
duke
parents:
diff changeset
   106
    private static final String versionRBName = "com.sun.tools.javac.resources.version";
06bc494ca11e Initial load
duke
parents:
diff changeset
   107
    private static ResourceBundle versionRB;
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
06bc494ca11e Initial load
duke
parents:
diff changeset
   109
    private static String version(String key) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   110
        if (versionRB == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   111
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   112
                versionRB = ResourceBundle.getBundle(versionRBName);
06bc494ca11e Initial load
duke
parents:
diff changeset
   113
            } catch (MissingResourceException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   114
                return Log.getLocalizedString("version.resource.missing", System.getProperty("java.version"));
06bc494ca11e Initial load
duke
parents:
diff changeset
   115
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   116
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   117
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   118
            return versionRB.getString(key);
06bc494ca11e Initial load
duke
parents:
diff changeset
   119
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   120
        catch (MissingResourceException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   121
            return Log.getLocalizedString("version.unknown", System.getProperty("java.version"));
06bc494ca11e Initial load
duke
parents:
diff changeset
   122
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   123
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   124
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   125
    /**
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   126
     * Control how the compiler's latter phases (attr, flow, desugar, generate)
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   127
     * are connected. Each individual file is processed by each phase in turn,
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   128
     * but with different compile policies, you can control the order in which
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   129
     * each class is processed through its next phase.
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   130
     *
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   131
     * <p>Generally speaking, the compiler will "fail fast" in the face of
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   132
     * errors, although not aggressively so. flow, desugar, etc become no-ops
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   133
     * once any errors have occurred. No attempt is currently made to determine
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   134
     * if it might be safe to process a class through its next phase because
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   135
     * it does not depend on any unrelated errors that might have occurred.
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   136
     */
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   137
    protected static enum CompilePolicy {
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   138
        /**
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   139
         * Just attribute the parse trees.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   140
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   141
        ATTR_ONLY,
06bc494ca11e Initial load
duke
parents:
diff changeset
   142
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   143
        /**
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   144
         * Just attribute and do flow analysis on the parse trees.
06bc494ca11e Initial load
duke
parents:
diff changeset
   145
         * This should catch most user errors.
06bc494ca11e Initial load
duke
parents:
diff changeset
   146
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   147
        CHECK_ONLY,
06bc494ca11e Initial load
duke
parents:
diff changeset
   148
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   149
        /**
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   150
         * Attribute everything, then do flow analysis for everything,
06bc494ca11e Initial load
duke
parents:
diff changeset
   151
         * then desugar everything, and only then generate output.
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   152
         * This means no output will be generated if there are any
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   153
         * errors in any classes.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   154
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   155
        SIMPLE,
06bc494ca11e Initial load
duke
parents:
diff changeset
   156
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   157
        /**
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   158
         * Groups the classes for each source file together, then process
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   159
         * each group in a manner equivalent to the {@code SIMPLE} policy.
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   160
         * This means no output will be generated if there are any
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   161
         * errors in any of the classes in a source file.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   162
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   163
        BY_FILE,
06bc494ca11e Initial load
duke
parents:
diff changeset
   164
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   165
        /**
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   166
         * Completely process each entry on the todo list in turn.
06bc494ca11e Initial load
duke
parents:
diff changeset
   167
         * -- this is the same for 1.5.
06bc494ca11e Initial load
duke
parents:
diff changeset
   168
         * Means output might be generated for some classes in a compilation unit
06bc494ca11e Initial load
duke
parents:
diff changeset
   169
         * and not others.
06bc494ca11e Initial load
duke
parents:
diff changeset
   170
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   171
        BY_TODO;
06bc494ca11e Initial load
duke
parents:
diff changeset
   172
06bc494ca11e Initial load
duke
parents:
diff changeset
   173
        static CompilePolicy decode(String option) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   174
            if (option == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   175
                return DEFAULT_COMPILE_POLICY;
06bc494ca11e Initial load
duke
parents:
diff changeset
   176
            else if (option.equals("attr"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   177
                return ATTR_ONLY;
06bc494ca11e Initial load
duke
parents:
diff changeset
   178
            else if (option.equals("check"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   179
                return CHECK_ONLY;
06bc494ca11e Initial load
duke
parents:
diff changeset
   180
            else if (option.equals("simple"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   181
                return SIMPLE;
06bc494ca11e Initial load
duke
parents:
diff changeset
   182
            else if (option.equals("byfile"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   183
                return BY_FILE;
06bc494ca11e Initial load
duke
parents:
diff changeset
   184
            else if (option.equals("bytodo"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   185
                return BY_TODO;
06bc494ca11e Initial load
duke
parents:
diff changeset
   186
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
   187
                return DEFAULT_COMPILE_POLICY;
06bc494ca11e Initial load
duke
parents:
diff changeset
   188
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   189
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   190
06bc494ca11e Initial load
duke
parents:
diff changeset
   191
    private static CompilePolicy DEFAULT_COMPILE_POLICY = CompilePolicy.BY_TODO;
06bc494ca11e Initial load
duke
parents:
diff changeset
   192
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   193
    protected static enum ImplicitSourcePolicy {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   194
        /** Don't generate or process implicitly read source files. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   195
        NONE,
06bc494ca11e Initial load
duke
parents:
diff changeset
   196
        /** Generate classes for implicitly read source files. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   197
        CLASS,
06bc494ca11e Initial load
duke
parents:
diff changeset
   198
        /** Like CLASS, but generate warnings if annotation processing occurs */
06bc494ca11e Initial load
duke
parents:
diff changeset
   199
        UNSET;
06bc494ca11e Initial load
duke
parents:
diff changeset
   200
06bc494ca11e Initial load
duke
parents:
diff changeset
   201
        static ImplicitSourcePolicy decode(String option) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   202
            if (option == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   203
                return UNSET;
06bc494ca11e Initial load
duke
parents:
diff changeset
   204
            else if (option.equals("none"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   205
                return NONE;
06bc494ca11e Initial load
duke
parents:
diff changeset
   206
            else if (option.equals("class"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   207
                return CLASS;
06bc494ca11e Initial load
duke
parents:
diff changeset
   208
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
   209
                return UNSET;
06bc494ca11e Initial load
duke
parents:
diff changeset
   210
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   211
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   212
06bc494ca11e Initial load
duke
parents:
diff changeset
   213
    /** The log to be used for error reporting.
06bc494ca11e Initial load
duke
parents:
diff changeset
   214
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   215
    public Log log;
06bc494ca11e Initial load
duke
parents:
diff changeset
   216
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   217
    /** Factory for creating diagnostic objects
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   218
     */
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   219
    JCDiagnostic.Factory diagFactory;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   220
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   221
    /** The tree factory module.
06bc494ca11e Initial load
duke
parents:
diff changeset
   222
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   223
    protected TreeMaker make;
06bc494ca11e Initial load
duke
parents:
diff changeset
   224
06bc494ca11e Initial load
duke
parents:
diff changeset
   225
    /** The class reader.
06bc494ca11e Initial load
duke
parents:
diff changeset
   226
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   227
    protected ClassReader reader;
06bc494ca11e Initial load
duke
parents:
diff changeset
   228
06bc494ca11e Initial load
duke
parents:
diff changeset
   229
    /** The class writer.
06bc494ca11e Initial load
duke
parents:
diff changeset
   230
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   231
    protected ClassWriter writer;
06bc494ca11e Initial load
duke
parents:
diff changeset
   232
06bc494ca11e Initial load
duke
parents:
diff changeset
   233
    /** The module for the symbol table entry phases.
06bc494ca11e Initial load
duke
parents:
diff changeset
   234
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   235
    protected Enter enter;
06bc494ca11e Initial load
duke
parents:
diff changeset
   236
06bc494ca11e Initial load
duke
parents:
diff changeset
   237
    /** The symbol table.
06bc494ca11e Initial load
duke
parents:
diff changeset
   238
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   239
    protected Symtab syms;
06bc494ca11e Initial load
duke
parents:
diff changeset
   240
06bc494ca11e Initial load
duke
parents:
diff changeset
   241
    /** The language version.
06bc494ca11e Initial load
duke
parents:
diff changeset
   242
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   243
    protected Source source;
06bc494ca11e Initial load
duke
parents:
diff changeset
   244
06bc494ca11e Initial load
duke
parents:
diff changeset
   245
    /** The module for code generation.
06bc494ca11e Initial load
duke
parents:
diff changeset
   246
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   247
    protected Gen gen;
06bc494ca11e Initial load
duke
parents:
diff changeset
   248
06bc494ca11e Initial load
duke
parents:
diff changeset
   249
    /** The name table.
06bc494ca11e Initial load
duke
parents:
diff changeset
   250
     */
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1258
diff changeset
   251
    protected Names names;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   252
06bc494ca11e Initial load
duke
parents:
diff changeset
   253
    /** The attributor.
06bc494ca11e Initial load
duke
parents:
diff changeset
   254
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   255
    protected Attr attr;
06bc494ca11e Initial load
duke
parents:
diff changeset
   256
06bc494ca11e Initial load
duke
parents:
diff changeset
   257
    /** The attributor.
06bc494ca11e Initial load
duke
parents:
diff changeset
   258
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   259
    protected Check chk;
06bc494ca11e Initial load
duke
parents:
diff changeset
   260
06bc494ca11e Initial load
duke
parents:
diff changeset
   261
    /** The flow analyzer.
06bc494ca11e Initial load
duke
parents:
diff changeset
   262
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   263
    protected Flow flow;
06bc494ca11e Initial load
duke
parents:
diff changeset
   264
06bc494ca11e Initial load
duke
parents:
diff changeset
   265
    /** The type eraser.
06bc494ca11e Initial load
duke
parents:
diff changeset
   266
     */
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   267
    protected TransTypes transTypes;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   268
06bc494ca11e Initial load
duke
parents:
diff changeset
   269
    /** The syntactic sugar desweetener.
06bc494ca11e Initial load
duke
parents:
diff changeset
   270
     */
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   271
    protected Lower lower;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   272
06bc494ca11e Initial load
duke
parents:
diff changeset
   273
    /** The annotation annotator.
06bc494ca11e Initial load
duke
parents:
diff changeset
   274
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   275
    protected Annotate annotate;
06bc494ca11e Initial load
duke
parents:
diff changeset
   276
06bc494ca11e Initial load
duke
parents:
diff changeset
   277
    /** Force a completion failure on this name
06bc494ca11e Initial load
duke
parents:
diff changeset
   278
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   279
    protected final Name completionFailureName;
06bc494ca11e Initial load
duke
parents:
diff changeset
   280
06bc494ca11e Initial load
duke
parents:
diff changeset
   281
    /** Type utilities.
06bc494ca11e Initial load
duke
parents:
diff changeset
   282
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   283
    protected Types types;
06bc494ca11e Initial load
duke
parents:
diff changeset
   284
06bc494ca11e Initial load
duke
parents:
diff changeset
   285
    /** Access to file objects.
06bc494ca11e Initial load
duke
parents:
diff changeset
   286
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   287
    protected JavaFileManager fileManager;
06bc494ca11e Initial load
duke
parents:
diff changeset
   288
06bc494ca11e Initial load
duke
parents:
diff changeset
   289
    /** Factory for parsers.
06bc494ca11e Initial load
duke
parents:
diff changeset
   290
     */
1258
1cf37d8837d1 6724118: change JavaCompiler to not use Scanner directly
jjg
parents: 1046
diff changeset
   291
    protected ParserFactory parserFactory;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   292
06bc494ca11e Initial load
duke
parents:
diff changeset
   293
    /** Optional listener for progress events
06bc494ca11e Initial load
duke
parents:
diff changeset
   294
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   295
    protected TaskListener taskListener;
06bc494ca11e Initial load
duke
parents:
diff changeset
   296
06bc494ca11e Initial load
duke
parents:
diff changeset
   297
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   298
     * Annotation processing may require and provide a new instance
06bc494ca11e Initial load
duke
parents:
diff changeset
   299
     * of the compiler to be used for the analyze and generate phases.
06bc494ca11e Initial load
duke
parents:
diff changeset
   300
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   301
    protected JavaCompiler delegateCompiler;
06bc494ca11e Initial load
duke
parents:
diff changeset
   302
06bc494ca11e Initial load
duke
parents:
diff changeset
   303
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   304
     * Flag set if any annotation processing occurred.
06bc494ca11e Initial load
duke
parents:
diff changeset
   305
     **/
06bc494ca11e Initial load
duke
parents:
diff changeset
   306
    protected boolean annotationProcessingOccurred;
06bc494ca11e Initial load
duke
parents:
diff changeset
   307
06bc494ca11e Initial load
duke
parents:
diff changeset
   308
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   309
     * Flag set if any implicit source files read.
06bc494ca11e Initial load
duke
parents:
diff changeset
   310
     **/
06bc494ca11e Initial load
duke
parents:
diff changeset
   311
    protected boolean implicitSourceFilesRead;
06bc494ca11e Initial load
duke
parents:
diff changeset
   312
06bc494ca11e Initial load
duke
parents:
diff changeset
   313
    protected Context context;
06bc494ca11e Initial load
duke
parents:
diff changeset
   314
06bc494ca11e Initial load
duke
parents:
diff changeset
   315
    /** Construct a new compiler using a shared context.
06bc494ca11e Initial load
duke
parents:
diff changeset
   316
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   317
    public JavaCompiler(final Context context) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   318
        this.context = context;
06bc494ca11e Initial load
duke
parents:
diff changeset
   319
        context.put(compilerKey, this);
06bc494ca11e Initial load
duke
parents:
diff changeset
   320
06bc494ca11e Initial load
duke
parents:
diff changeset
   321
        // if fileManager not already set, register the JavacFileManager to be used
06bc494ca11e Initial load
duke
parents:
diff changeset
   322
        if (context.get(JavaFileManager.class) == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   323
            JavacFileManager.preRegister(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   324
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1258
diff changeset
   325
        names = Names.instance(context);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   326
        log = Log.instance(context);
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   327
        diagFactory = JCDiagnostic.Factory.instance(context);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   328
        reader = ClassReader.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   329
        make = TreeMaker.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   330
        writer = ClassWriter.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   331
        enter = Enter.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   332
        todo = Todo.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   333
06bc494ca11e Initial load
duke
parents:
diff changeset
   334
        fileManager = context.get(JavaFileManager.class);
1258
1cf37d8837d1 6724118: change JavaCompiler to not use Scanner directly
jjg
parents: 1046
diff changeset
   335
        parserFactory = ParserFactory.instance(context);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   336
06bc494ca11e Initial load
duke
parents:
diff changeset
   337
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   338
            // catch completion problems with predefineds
06bc494ca11e Initial load
duke
parents:
diff changeset
   339
            syms = Symtab.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   340
        } catch (CompletionFailure ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   341
            // inlined Check.completionError as it is not initialized yet
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   342
            log.error("cant.access", ex.sym, ex.getDetailValue());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   343
            if (ex instanceof ClassReader.BadClassFile)
06bc494ca11e Initial load
duke
parents:
diff changeset
   344
                throw new Abort();
06bc494ca11e Initial load
duke
parents:
diff changeset
   345
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   346
        source = Source.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   347
        attr = Attr.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   348
        chk = Check.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   349
        gen = Gen.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   350
        flow = Flow.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   351
        transTypes = TransTypes.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   352
        lower = Lower.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   353
        annotate = Annotate.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   354
        types = Types.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   355
        taskListener = context.get(TaskListener.class);
06bc494ca11e Initial load
duke
parents:
diff changeset
   356
06bc494ca11e Initial load
duke
parents:
diff changeset
   357
        reader.sourceCompleter = this;
06bc494ca11e Initial load
duke
parents:
diff changeset
   358
06bc494ca11e Initial load
duke
parents:
diff changeset
   359
        Options options = Options.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   360
06bc494ca11e Initial load
duke
parents:
diff changeset
   361
        verbose       = options.get("-verbose")       != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   362
        sourceOutput  = options.get("-printsource")   != null; // used to be -s
06bc494ca11e Initial load
duke
parents:
diff changeset
   363
        stubOutput    = options.get("-stubs")         != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   364
        relax         = options.get("-relax")         != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   365
        printFlat     = options.get("-printflat")     != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   366
        attrParseOnly = options.get("-attrparseonly") != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   367
        encoding      = options.get("-encoding");
06bc494ca11e Initial load
duke
parents:
diff changeset
   368
        lineDebugInfo = options.get("-g:")            == null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
   369
                        options.get("-g:lines")       != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   370
        genEndPos     = options.get("-Xjcov")         != null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
   371
                        context.get(DiagnosticListener.class) != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   372
        devVerbose    = options.get("dev") != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   373
        processPcks   = options.get("process.packages") != null;
1996
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   374
        werror        = options.get("-Werror")        != null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   375
06bc494ca11e Initial load
duke
parents:
diff changeset
   376
        verboseCompilePolicy = options.get("verboseCompilePolicy") != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   377
06bc494ca11e Initial load
duke
parents:
diff changeset
   378
        if (attrParseOnly)
06bc494ca11e Initial load
duke
parents:
diff changeset
   379
            compilePolicy = CompilePolicy.ATTR_ONLY;
06bc494ca11e Initial load
duke
parents:
diff changeset
   380
        else
06bc494ca11e Initial load
duke
parents:
diff changeset
   381
            compilePolicy = CompilePolicy.decode(options.get("compilePolicy"));
06bc494ca11e Initial load
duke
parents:
diff changeset
   382
06bc494ca11e Initial load
duke
parents:
diff changeset
   383
        implicitSourcePolicy = ImplicitSourcePolicy.decode(options.get("-implicit"));
06bc494ca11e Initial load
duke
parents:
diff changeset
   384
06bc494ca11e Initial load
duke
parents:
diff changeset
   385
        completionFailureName =
06bc494ca11e Initial load
duke
parents:
diff changeset
   386
            (options.get("failcomplete") != null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   387
            ? names.fromString(options.get("failcomplete"))
06bc494ca11e Initial load
duke
parents:
diff changeset
   388
            : null;
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   389
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   390
        shouldStopPolicy =
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   391
            (options.get("shouldStopPolicy") != null)
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   392
            ? CompileState.valueOf(options.get("shouldStopPolicy"))
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   393
            : null;
2984
e15ff3a34054 6722234: javac diagnostics need better integration with the type-system
mcimadamore
parents: 2514
diff changeset
   394
        if (options.get("oldDiags") == null)
e15ff3a34054 6722234: javac diagnostics need better integration with the type-system
mcimadamore
parents: 2514
diff changeset
   395
            log.setDiagnosticFormatter(RichDiagnosticFormatter.instance(context));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   396
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   397
06bc494ca11e Initial load
duke
parents:
diff changeset
   398
    /* Switches:
06bc494ca11e Initial load
duke
parents:
diff changeset
   399
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   400
06bc494ca11e Initial load
duke
parents:
diff changeset
   401
    /** Verbose output.
06bc494ca11e Initial load
duke
parents:
diff changeset
   402
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   403
    public boolean verbose;
06bc494ca11e Initial load
duke
parents:
diff changeset
   404
06bc494ca11e Initial load
duke
parents:
diff changeset
   405
    /** Emit plain Java source files rather than class files.
06bc494ca11e Initial load
duke
parents:
diff changeset
   406
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   407
    public boolean sourceOutput;
06bc494ca11e Initial load
duke
parents:
diff changeset
   408
06bc494ca11e Initial load
duke
parents:
diff changeset
   409
    /** Emit stub source files rather than class files.
06bc494ca11e Initial load
duke
parents:
diff changeset
   410
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   411
    public boolean stubOutput;
06bc494ca11e Initial load
duke
parents:
diff changeset
   412
06bc494ca11e Initial load
duke
parents:
diff changeset
   413
    /** Generate attributed parse tree only.
06bc494ca11e Initial load
duke
parents:
diff changeset
   414
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   415
    public boolean attrParseOnly;
06bc494ca11e Initial load
duke
parents:
diff changeset
   416
06bc494ca11e Initial load
duke
parents:
diff changeset
   417
    /** Switch: relax some constraints for producing the jsr14 prototype.
06bc494ca11e Initial load
duke
parents:
diff changeset
   418
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   419
    boolean relax;
06bc494ca11e Initial load
duke
parents:
diff changeset
   420
06bc494ca11e Initial load
duke
parents:
diff changeset
   421
    /** Debug switch: Emit Java sources after inner class flattening.
06bc494ca11e Initial load
duke
parents:
diff changeset
   422
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   423
    public boolean printFlat;
06bc494ca11e Initial load
duke
parents:
diff changeset
   424
06bc494ca11e Initial load
duke
parents:
diff changeset
   425
    /** The encoding to be used for source input.
06bc494ca11e Initial load
duke
parents:
diff changeset
   426
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   427
    public String encoding;
06bc494ca11e Initial load
duke
parents:
diff changeset
   428
06bc494ca11e Initial load
duke
parents:
diff changeset
   429
    /** Generate code with the LineNumberTable attribute for debugging
06bc494ca11e Initial load
duke
parents:
diff changeset
   430
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   431
    public boolean lineDebugInfo;
06bc494ca11e Initial load
duke
parents:
diff changeset
   432
06bc494ca11e Initial load
duke
parents:
diff changeset
   433
    /** Switch: should we store the ending positions?
06bc494ca11e Initial load
duke
parents:
diff changeset
   434
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   435
    public boolean genEndPos;
06bc494ca11e Initial load
duke
parents:
diff changeset
   436
06bc494ca11e Initial load
duke
parents:
diff changeset
   437
    /** Switch: should we debug ignored exceptions
06bc494ca11e Initial load
duke
parents:
diff changeset
   438
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   439
    protected boolean devVerbose;
06bc494ca11e Initial load
duke
parents:
diff changeset
   440
06bc494ca11e Initial load
duke
parents:
diff changeset
   441
    /** Switch: should we (annotation) process packages as well
06bc494ca11e Initial load
duke
parents:
diff changeset
   442
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   443
    protected boolean processPcks;
06bc494ca11e Initial load
duke
parents:
diff changeset
   444
1996
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   445
    /** Switch: treat warnings as errors
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   446
     */
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   447
    protected boolean werror;
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   448
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   449
    /** Switch: is annotation processing requested explitly via
06bc494ca11e Initial load
duke
parents:
diff changeset
   450
     * CompilationTask.setProcessors?
06bc494ca11e Initial load
duke
parents:
diff changeset
   451
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   452
    protected boolean explicitAnnotationProcessingRequested = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   453
06bc494ca11e Initial load
duke
parents:
diff changeset
   454
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   455
     * The policy for the order in which to perform the compilation
06bc494ca11e Initial load
duke
parents:
diff changeset
   456
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   457
    protected CompilePolicy compilePolicy;
06bc494ca11e Initial load
duke
parents:
diff changeset
   458
06bc494ca11e Initial load
duke
parents:
diff changeset
   459
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   460
     * The policy for what to do with implicitly read source files
06bc494ca11e Initial load
duke
parents:
diff changeset
   461
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   462
    protected ImplicitSourcePolicy implicitSourcePolicy;
06bc494ca11e Initial load
duke
parents:
diff changeset
   463
06bc494ca11e Initial load
duke
parents:
diff changeset
   464
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   465
     * Report activity related to compilePolicy
06bc494ca11e Initial load
duke
parents:
diff changeset
   466
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   467
    public boolean verboseCompilePolicy;
06bc494ca11e Initial load
duke
parents:
diff changeset
   468
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   469
    /**
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   470
     * Policy of how far to continue processing. null means until first
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   471
     * error.
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   472
     */
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   473
    public CompileState shouldStopPolicy;
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   474
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   475
    /** A queue of all as yet unattributed classes.
06bc494ca11e Initial load
duke
parents:
diff changeset
   476
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   477
    public Todo todo;
06bc494ca11e Initial load
duke
parents:
diff changeset
   478
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   479
    /** Ordered list of compiler phases for each compilation unit. */
3151
41800a86aad3 6854796: update JSR308 impl with latest code from type-annotations repo
jjg
parents: 2984
diff changeset
   480
    public enum CompileState {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   481
        PARSE(1),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   482
        ENTER(2),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   483
        PROCESS(3),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   484
        ATTR(4),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   485
        FLOW(5),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   486
        TRANSTYPES(6),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   487
        LOWER(7),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   488
        GENERATE(8);
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   489
        CompileState(int value) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   490
            this.value = value;
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   491
        }
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   492
        boolean isDone(CompileState other) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   493
            return value >= other.value;
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   494
        }
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   495
        private int value;
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   496
    };
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   497
    /** Partial map to record which compiler phases have been executed
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   498
     * for each compilation unit. Used for ATTR and FLOW phases.
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   499
     */
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   500
    protected class CompileStates extends HashMap<Env<AttrContext>,CompileState> {
1870
57a1138dffc8 6795903: fix latent build warnings in langtools repository
jjg
parents: 1355
diff changeset
   501
        private static final long serialVersionUID = 1812267524140424433L;
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   502
        boolean isDone(Env<AttrContext> env, CompileState cs) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   503
            CompileState ecs = get(env);
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   504
            return ecs != null && ecs.isDone(cs);
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   505
        }
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   506
    }
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
   507
    private CompileStates compileStates = new CompileStates();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   508
06bc494ca11e Initial load
duke
parents:
diff changeset
   509
    /** The set of currently compiled inputfiles, needed to ensure
06bc494ca11e Initial load
duke
parents:
diff changeset
   510
     *  we don't accidentally overwrite an input file when -s is set.
06bc494ca11e Initial load
duke
parents:
diff changeset
   511
     *  initialized by `compile'.
06bc494ca11e Initial load
duke
parents:
diff changeset
   512
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   513
    protected Set<JavaFileObject> inputFiles = new HashSet<JavaFileObject>();
06bc494ca11e Initial load
duke
parents:
diff changeset
   514
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   515
    protected boolean shouldStop(CompileState cs) {
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   516
        if (shouldStopPolicy == null)
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   517
            return (errorCount() > 0);
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   518
        else
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   519
            return cs.ordinal() > shouldStopPolicy.ordinal();
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   520
    }
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   521
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   522
    /** The number of errors reported so far.
06bc494ca11e Initial load
duke
parents:
diff changeset
   523
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   524
    public int errorCount() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   525
        if (delegateCompiler != null && delegateCompiler != this)
06bc494ca11e Initial load
duke
parents:
diff changeset
   526
            return delegateCompiler.errorCount();
1996
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   527
        else {
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   528
            if (werror && log.nerrors == 0 && log.nwarnings > 0) {
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   529
                log.error("warnings.and.werror");
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   530
            }
c855318a4b03 6595666: fix -Werror
jjg
parents: 1870
diff changeset
   531
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   532
            return log.nerrors;
06bc494ca11e Initial load
duke
parents:
diff changeset
   533
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   534
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   535
    protected final <T> Queue<T> stopIfError(CompileState cs, Queue<T> queue) {
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   536
        return shouldStop(cs) ? ListBuffer.<T>lb() : queue;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   537
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   538
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   539
    protected final <T> List<T> stopIfError(CompileState cs, List<T> list) {
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   540
        return shouldStop(cs) ? List.<T>nil() : list;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   541
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   542
06bc494ca11e Initial load
duke
parents:
diff changeset
   543
    /** The number of warnings reported so far.
06bc494ca11e Initial load
duke
parents:
diff changeset
   544
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   545
    public int warningCount() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   546
        if (delegateCompiler != null && delegateCompiler != this)
06bc494ca11e Initial load
duke
parents:
diff changeset
   547
            return delegateCompiler.warningCount();
06bc494ca11e Initial load
duke
parents:
diff changeset
   548
        else
06bc494ca11e Initial load
duke
parents:
diff changeset
   549
            return log.nwarnings;
06bc494ca11e Initial load
duke
parents:
diff changeset
   550
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   551
06bc494ca11e Initial load
duke
parents:
diff changeset
   552
    /** Whether or not any parse errors have occurred.
06bc494ca11e Initial load
duke
parents:
diff changeset
   553
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   554
    public boolean parseErrors() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   555
        return parseErrors;
06bc494ca11e Initial load
duke
parents:
diff changeset
   556
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   557
06bc494ca11e Initial load
duke
parents:
diff changeset
   558
    /** Try to open input stream with given name.
06bc494ca11e Initial load
duke
parents:
diff changeset
   559
     *  Report an error if this fails.
06bc494ca11e Initial load
duke
parents:
diff changeset
   560
     *  @param filename   The file name of the input stream to be opened.
06bc494ca11e Initial load
duke
parents:
diff changeset
   561
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   562
    public CharSequence readSource(JavaFileObject filename) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   563
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   564
            inputFiles.add(filename);
06bc494ca11e Initial load
duke
parents:
diff changeset
   565
            return filename.getCharContent(false);
06bc494ca11e Initial load
duke
parents:
diff changeset
   566
        } catch (IOException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   567
            log.error("error.reading.file", filename, e.getLocalizedMessage());
06bc494ca11e Initial load
duke
parents:
diff changeset
   568
            return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   569
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   570
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   571
06bc494ca11e Initial load
duke
parents:
diff changeset
   572
    /** Parse contents of input stream.
06bc494ca11e Initial load
duke
parents:
diff changeset
   573
     *  @param filename     The name of the file from which input stream comes.
06bc494ca11e Initial load
duke
parents:
diff changeset
   574
     *  @param input        The input stream to be parsed.
06bc494ca11e Initial load
duke
parents:
diff changeset
   575
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   576
    protected JCCompilationUnit parse(JavaFileObject filename, CharSequence content) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   577
        long msec = now();
06bc494ca11e Initial load
duke
parents:
diff changeset
   578
        JCCompilationUnit tree = make.TopLevel(List.<JCTree.JCAnnotation>nil(),
06bc494ca11e Initial load
duke
parents:
diff changeset
   579
                                      null, List.<JCTree>nil());
06bc494ca11e Initial load
duke
parents:
diff changeset
   580
        if (content != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   581
            if (verbose) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   582
                printVerbose("parsing.started", filename);
06bc494ca11e Initial load
duke
parents:
diff changeset
   583
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   584
            if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   585
                TaskEvent e = new TaskEvent(TaskEvent.Kind.PARSE, filename);
06bc494ca11e Initial load
duke
parents:
diff changeset
   586
                taskListener.started(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   587
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   588
            int initialErrorCount = log.nerrors;
1258
1cf37d8837d1 6724118: change JavaCompiler to not use Scanner directly
jjg
parents: 1046
diff changeset
   589
            Parser parser = parserFactory.newParser(content, keepComments(), genEndPos, lineDebugInfo);
1cf37d8837d1 6724118: change JavaCompiler to not use Scanner directly
jjg
parents: 1046
diff changeset
   590
            tree = parser.parseCompilationUnit();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   591
            parseErrors |= (log.nerrors > initialErrorCount);
06bc494ca11e Initial load
duke
parents:
diff changeset
   592
            if (verbose) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   593
                printVerbose("parsing.done", Long.toString(elapsed(msec)));
06bc494ca11e Initial load
duke
parents:
diff changeset
   594
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   595
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   596
06bc494ca11e Initial load
duke
parents:
diff changeset
   597
        tree.sourcefile = filename;
06bc494ca11e Initial load
duke
parents:
diff changeset
   598
06bc494ca11e Initial load
duke
parents:
diff changeset
   599
        if (content != null && taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   600
            TaskEvent e = new TaskEvent(TaskEvent.Kind.PARSE, tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
   601
            taskListener.finished(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   602
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   603
06bc494ca11e Initial load
duke
parents:
diff changeset
   604
        return tree;
06bc494ca11e Initial load
duke
parents:
diff changeset
   605
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   606
    // where
06bc494ca11e Initial load
duke
parents:
diff changeset
   607
        public boolean keepComments = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   608
        protected boolean keepComments() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   609
            return keepComments || sourceOutput || stubOutput;
06bc494ca11e Initial load
duke
parents:
diff changeset
   610
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   611
06bc494ca11e Initial load
duke
parents:
diff changeset
   612
06bc494ca11e Initial load
duke
parents:
diff changeset
   613
    /** Parse contents of file.
06bc494ca11e Initial load
duke
parents:
diff changeset
   614
     *  @param filename     The name of the file to be parsed.
06bc494ca11e Initial load
duke
parents:
diff changeset
   615
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   616
    @Deprecated
06bc494ca11e Initial load
duke
parents:
diff changeset
   617
    public JCTree.JCCompilationUnit parse(String filename) throws IOException {
06bc494ca11e Initial load
duke
parents:
diff changeset
   618
        JavacFileManager fm = (JavacFileManager)fileManager;
06bc494ca11e Initial load
duke
parents:
diff changeset
   619
        return parse(fm.getJavaFileObjectsFromStrings(List.of(filename)).iterator().next());
06bc494ca11e Initial load
duke
parents:
diff changeset
   620
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   621
06bc494ca11e Initial load
duke
parents:
diff changeset
   622
    /** Parse contents of file.
06bc494ca11e Initial load
duke
parents:
diff changeset
   623
     *  @param filename     The name of the file to be parsed.
06bc494ca11e Initial load
duke
parents:
diff changeset
   624
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   625
    public JCTree.JCCompilationUnit parse(JavaFileObject filename) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   626
        JavaFileObject prev = log.useSource(filename);
06bc494ca11e Initial load
duke
parents:
diff changeset
   627
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   628
            JCTree.JCCompilationUnit t = parse(filename, readSource(filename));
06bc494ca11e Initial load
duke
parents:
diff changeset
   629
            if (t.endPositions != null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   630
                log.setEndPosTable(filename, t.endPositions);
06bc494ca11e Initial load
duke
parents:
diff changeset
   631
            return t;
06bc494ca11e Initial load
duke
parents:
diff changeset
   632
        } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
   633
            log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
   634
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   635
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   636
06bc494ca11e Initial load
duke
parents:
diff changeset
   637
    /** Resolve an identifier.
06bc494ca11e Initial load
duke
parents:
diff changeset
   638
     * @param name      The identifier to resolve
06bc494ca11e Initial load
duke
parents:
diff changeset
   639
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   640
    public Symbol resolveIdent(String name) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   641
        if (name.equals(""))
06bc494ca11e Initial load
duke
parents:
diff changeset
   642
            return syms.errSymbol;
06bc494ca11e Initial load
duke
parents:
diff changeset
   643
        JavaFileObject prev = log.useSource(null);
06bc494ca11e Initial load
duke
parents:
diff changeset
   644
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   645
            JCExpression tree = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   646
            for (String s : name.split("\\.", -1)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   647
                if (!SourceVersion.isIdentifier(s)) // TODO: check for keywords
06bc494ca11e Initial load
duke
parents:
diff changeset
   648
                    return syms.errSymbol;
06bc494ca11e Initial load
duke
parents:
diff changeset
   649
                tree = (tree == null) ? make.Ident(names.fromString(s))
06bc494ca11e Initial load
duke
parents:
diff changeset
   650
                                      : make.Select(tree, names.fromString(s));
06bc494ca11e Initial load
duke
parents:
diff changeset
   651
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   652
            JCCompilationUnit toplevel =
06bc494ca11e Initial load
duke
parents:
diff changeset
   653
                make.TopLevel(List.<JCTree.JCAnnotation>nil(), null, List.<JCTree>nil());
06bc494ca11e Initial load
duke
parents:
diff changeset
   654
            toplevel.packge = syms.unnamedPackage;
06bc494ca11e Initial load
duke
parents:
diff changeset
   655
            return attr.attribIdent(tree, toplevel);
06bc494ca11e Initial load
duke
parents:
diff changeset
   656
        } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
   657
            log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
   658
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   659
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   660
06bc494ca11e Initial load
duke
parents:
diff changeset
   661
    /** Emit plain Java source for a class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   662
     *  @param env    The attribution environment of the outermost class
06bc494ca11e Initial load
duke
parents:
diff changeset
   663
     *                containing this class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   664
     *  @param cdef   The class definition to be printed.
06bc494ca11e Initial load
duke
parents:
diff changeset
   665
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   666
    JavaFileObject printSource(Env<AttrContext> env, JCClassDecl cdef) throws IOException {
06bc494ca11e Initial load
duke
parents:
diff changeset
   667
        JavaFileObject outFile
06bc494ca11e Initial load
duke
parents:
diff changeset
   668
            = fileManager.getJavaFileForOutput(CLASS_OUTPUT,
06bc494ca11e Initial load
duke
parents:
diff changeset
   669
                                               cdef.sym.flatname.toString(),
06bc494ca11e Initial load
duke
parents:
diff changeset
   670
                                               JavaFileObject.Kind.SOURCE,
06bc494ca11e Initial load
duke
parents:
diff changeset
   671
                                               null);
06bc494ca11e Initial load
duke
parents:
diff changeset
   672
        if (inputFiles.contains(outFile)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   673
            log.error(cdef.pos(), "source.cant.overwrite.input.file", outFile);
06bc494ca11e Initial load
duke
parents:
diff changeset
   674
            return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   675
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   676
            BufferedWriter out = new BufferedWriter(outFile.openWriter());
06bc494ca11e Initial load
duke
parents:
diff changeset
   677
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   678
                new Pretty(out, true).printUnit(env.toplevel, cdef);
06bc494ca11e Initial load
duke
parents:
diff changeset
   679
                if (verbose)
06bc494ca11e Initial load
duke
parents:
diff changeset
   680
                    printVerbose("wrote.file", outFile);
06bc494ca11e Initial load
duke
parents:
diff changeset
   681
            } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
   682
                out.close();
06bc494ca11e Initial load
duke
parents:
diff changeset
   683
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   684
            return outFile;
06bc494ca11e Initial load
duke
parents:
diff changeset
   685
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   686
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   687
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
    /** Generate code and emit a class file for a given class
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
     *  @param env    The attribution environment of the outermost class
06bc494ca11e Initial load
duke
parents:
diff changeset
   690
     *                containing this class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   691
     *  @param cdef   The class definition from which code is generated.
06bc494ca11e Initial load
duke
parents:
diff changeset
   692
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   693
    JavaFileObject genCode(Env<AttrContext> env, JCClassDecl cdef) throws IOException {
06bc494ca11e Initial load
duke
parents:
diff changeset
   694
        try {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   695
            if (gen.genClass(env, cdef) && (errorCount() == 0))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
                return writer.writeClass(cdef.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
   697
        } catch (ClassWriter.PoolOverflow ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
            log.error(cdef.pos(), "limit.pool");
06bc494ca11e Initial load
duke
parents:
diff changeset
   699
        } catch (ClassWriter.StringOverflow ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
            log.error(cdef.pos(), "limit.string.overflow",
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
                      ex.value.substring(0, 20));
06bc494ca11e Initial load
duke
parents:
diff changeset
   702
        } catch (CompletionFailure ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
            chk.completionError(cdef.pos(), ex);
06bc494ca11e Initial load
duke
parents:
diff changeset
   704
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   705
        return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   706
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   707
06bc494ca11e Initial load
duke
parents:
diff changeset
   708
    /** Complete compiling a source file that has been accessed
06bc494ca11e Initial load
duke
parents:
diff changeset
   709
     *  by the class file reader.
06bc494ca11e Initial load
duke
parents:
diff changeset
   710
     *  @param c          The class the source file of which needs to be compiled.
06bc494ca11e Initial load
duke
parents:
diff changeset
   711
     *  @param filename   The name of the source file.
06bc494ca11e Initial load
duke
parents:
diff changeset
   712
     *  @param f          An input stream that reads the source file.
06bc494ca11e Initial load
duke
parents:
diff changeset
   713
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   714
    public void complete(ClassSymbol c) throws CompletionFailure {
06bc494ca11e Initial load
duke
parents:
diff changeset
   715
//      System.err.println("completing " + c);//DEBUG
06bc494ca11e Initial load
duke
parents:
diff changeset
   716
        if (completionFailureName == c.fullname) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   717
            throw new CompletionFailure(c, "user-selected completion failure by class name");
06bc494ca11e Initial load
duke
parents:
diff changeset
   718
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   719
        JCCompilationUnit tree;
06bc494ca11e Initial load
duke
parents:
diff changeset
   720
        JavaFileObject filename = c.classfile;
06bc494ca11e Initial load
duke
parents:
diff changeset
   721
        JavaFileObject prev = log.useSource(filename);
06bc494ca11e Initial load
duke
parents:
diff changeset
   722
06bc494ca11e Initial load
duke
parents:
diff changeset
   723
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   724
            tree = parse(filename, filename.getCharContent(false));
06bc494ca11e Initial load
duke
parents:
diff changeset
   725
        } catch (IOException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   726
            log.error("error.reading.file", filename, e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   727
            tree = make.TopLevel(List.<JCTree.JCAnnotation>nil(), null, List.<JCTree>nil());
06bc494ca11e Initial load
duke
parents:
diff changeset
   728
        } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
   729
            log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
   730
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   731
06bc494ca11e Initial load
duke
parents:
diff changeset
   732
        if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   733
            TaskEvent e = new TaskEvent(TaskEvent.Kind.ENTER, tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
   734
            taskListener.started(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   735
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   736
06bc494ca11e Initial load
duke
parents:
diff changeset
   737
        enter.complete(List.of(tree), c);
06bc494ca11e Initial load
duke
parents:
diff changeset
   738
06bc494ca11e Initial load
duke
parents:
diff changeset
   739
        if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   740
            TaskEvent e = new TaskEvent(TaskEvent.Kind.ENTER, tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
   741
            taskListener.finished(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   742
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   743
06bc494ca11e Initial load
duke
parents:
diff changeset
   744
        if (enter.getEnv(c) == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   745
            boolean isPkgInfo =
06bc494ca11e Initial load
duke
parents:
diff changeset
   746
                tree.sourcefile.isNameCompatible("package-info",
06bc494ca11e Initial load
duke
parents:
diff changeset
   747
                                                 JavaFileObject.Kind.SOURCE);
06bc494ca11e Initial load
duke
parents:
diff changeset
   748
            if (isPkgInfo) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   749
                if (enter.getEnv(tree.packge) == null) {
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   750
                    JCDiagnostic diag =
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   751
                        diagFactory.fragment("file.does.not.contain.package",
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   752
                                                 c.location());
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   753
                    throw reader.new BadClassFile(c, filename, diag);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   754
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   755
            } else {
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   756
                JCDiagnostic diag =
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   757
                        diagFactory.fragment("file.doesnt.contain.class",
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   758
                                            c.getQualifiedName());
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
   759
                throw reader.new BadClassFile(c, filename, diag);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   760
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   761
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   762
06bc494ca11e Initial load
duke
parents:
diff changeset
   763
        implicitSourceFilesRead = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   764
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   765
06bc494ca11e Initial load
duke
parents:
diff changeset
   766
    /** Track when the JavaCompiler has been used to compile something. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   767
    private boolean hasBeenUsed = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   768
    private long start_msec = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   769
    public long elapsed_msec = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   770
06bc494ca11e Initial load
duke
parents:
diff changeset
   771
    /** Track whether any errors occurred while parsing source text. */
06bc494ca11e Initial load
duke
parents:
diff changeset
   772
    private boolean parseErrors = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   773
06bc494ca11e Initial load
duke
parents:
diff changeset
   774
    public void compile(List<JavaFileObject> sourceFileObject)
06bc494ca11e Initial load
duke
parents:
diff changeset
   775
        throws Throwable {
06bc494ca11e Initial load
duke
parents:
diff changeset
   776
        compile(sourceFileObject, List.<String>nil(), null);
06bc494ca11e Initial load
duke
parents:
diff changeset
   777
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   778
06bc494ca11e Initial load
duke
parents:
diff changeset
   779
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   780
     * Main method: compile a list of files, return all compiled classes
06bc494ca11e Initial load
duke
parents:
diff changeset
   781
     *
06bc494ca11e Initial load
duke
parents:
diff changeset
   782
     * @param sourceFileObjects file objects to be compiled
06bc494ca11e Initial load
duke
parents:
diff changeset
   783
     * @param classnames class names to process for annotations
06bc494ca11e Initial load
duke
parents:
diff changeset
   784
     * @param processors user provided annotation processors to bypass
06bc494ca11e Initial load
duke
parents:
diff changeset
   785
     * discovery, {@code null} means that no processors were provided
06bc494ca11e Initial load
duke
parents:
diff changeset
   786
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   787
    public void compile(List<JavaFileObject> sourceFileObjects,
06bc494ca11e Initial load
duke
parents:
diff changeset
   788
                        List<String> classnames,
06bc494ca11e Initial load
duke
parents:
diff changeset
   789
                        Iterable<? extends Processor> processors)
06bc494ca11e Initial load
duke
parents:
diff changeset
   790
        throws IOException // TODO: temp, from JavacProcessingEnvironment
06bc494ca11e Initial load
duke
parents:
diff changeset
   791
    {
06bc494ca11e Initial load
duke
parents:
diff changeset
   792
        if (processors != null && processors.iterator().hasNext())
06bc494ca11e Initial load
duke
parents:
diff changeset
   793
            explicitAnnotationProcessingRequested = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   794
        // as a JavaCompiler can only be used once, throw an exception if
06bc494ca11e Initial load
duke
parents:
diff changeset
   795
        // it has been used before.
06bc494ca11e Initial load
duke
parents:
diff changeset
   796
        if (hasBeenUsed)
06bc494ca11e Initial load
duke
parents:
diff changeset
   797
            throw new AssertionError("attempt to reuse JavaCompiler");
06bc494ca11e Initial load
duke
parents:
diff changeset
   798
        hasBeenUsed = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   799
06bc494ca11e Initial load
duke
parents:
diff changeset
   800
        start_msec = now();
06bc494ca11e Initial load
duke
parents:
diff changeset
   801
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   802
            initProcessAnnotations(processors);
06bc494ca11e Initial load
duke
parents:
diff changeset
   803
06bc494ca11e Initial load
duke
parents:
diff changeset
   804
            // These method calls must be chained to avoid memory leaks
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   805
            delegateCompiler =
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   806
                processAnnotations(
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   807
                    enterTrees(stopIfError(CompileState.PARSE, parseFiles(sourceFileObjects))),
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   808
                    classnames);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   809
06bc494ca11e Initial load
duke
parents:
diff changeset
   810
            delegateCompiler.compile2();
06bc494ca11e Initial load
duke
parents:
diff changeset
   811
            delegateCompiler.close();
06bc494ca11e Initial load
duke
parents:
diff changeset
   812
            elapsed_msec = delegateCompiler.elapsed_msec;
06bc494ca11e Initial load
duke
parents:
diff changeset
   813
        } catch (Abort ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   814
            if (devVerbose)
06bc494ca11e Initial load
duke
parents:
diff changeset
   815
                ex.printStackTrace();
06bc494ca11e Initial load
duke
parents:
diff changeset
   816
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   817
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   818
06bc494ca11e Initial load
duke
parents:
diff changeset
   819
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   820
     * The phases following annotation processing: attribution,
06bc494ca11e Initial load
duke
parents:
diff changeset
   821
     * desugar, and finally code generation.
06bc494ca11e Initial load
duke
parents:
diff changeset
   822
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   823
    private void compile2() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   824
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
   825
            switch (compilePolicy) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   826
            case ATTR_ONLY:
06bc494ca11e Initial load
duke
parents:
diff changeset
   827
                attribute(todo);
06bc494ca11e Initial load
duke
parents:
diff changeset
   828
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   829
06bc494ca11e Initial load
duke
parents:
diff changeset
   830
            case CHECK_ONLY:
06bc494ca11e Initial load
duke
parents:
diff changeset
   831
                flow(attribute(todo));
06bc494ca11e Initial load
duke
parents:
diff changeset
   832
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   833
06bc494ca11e Initial load
duke
parents:
diff changeset
   834
            case SIMPLE:
06bc494ca11e Initial load
duke
parents:
diff changeset
   835
                generate(desugar(flow(attribute(todo))));
06bc494ca11e Initial load
duke
parents:
diff changeset
   836
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   837
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   838
            case BY_FILE: {
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   839
                    Queue<Queue<Env<AttrContext>>> q = todo.groupByFile();
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   840
                    while (!q.isEmpty() && !shouldStop(CompileState.ATTR)) {
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   841
                        generate(desugar(flow(attribute(q.remove()))));
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   842
                    }
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   843
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   844
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   845
06bc494ca11e Initial load
duke
parents:
diff changeset
   846
            case BY_TODO:
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   847
                while (!todo.isEmpty())
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
   848
                    generate(desugar(flow(attribute(todo.remove()))));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   849
                break;
06bc494ca11e Initial load
duke
parents:
diff changeset
   850
06bc494ca11e Initial load
duke
parents:
diff changeset
   851
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
   852
                assert false: "unknown compile policy";
06bc494ca11e Initial load
duke
parents:
diff changeset
   853
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   854
        } catch (Abort ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   855
            if (devVerbose)
06bc494ca11e Initial load
duke
parents:
diff changeset
   856
                ex.printStackTrace();
06bc494ca11e Initial load
duke
parents:
diff changeset
   857
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   858
06bc494ca11e Initial load
duke
parents:
diff changeset
   859
        if (verbose) {
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
   860
            elapsed_msec = elapsed(start_msec);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   861
            printVerbose("total", Long.toString(elapsed_msec));
06bc494ca11e Initial load
duke
parents:
diff changeset
   862
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   863
06bc494ca11e Initial load
duke
parents:
diff changeset
   864
        reportDeferredDiagnostics();
06bc494ca11e Initial load
duke
parents:
diff changeset
   865
06bc494ca11e Initial load
duke
parents:
diff changeset
   866
        if (!log.hasDiagnosticListener()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   867
            printCount("error", errorCount());
06bc494ca11e Initial load
duke
parents:
diff changeset
   868
            printCount("warn", warningCount());
06bc494ca11e Initial load
duke
parents:
diff changeset
   869
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   870
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   871
06bc494ca11e Initial load
duke
parents:
diff changeset
   872
    private List<JCClassDecl> rootClasses;
06bc494ca11e Initial load
duke
parents:
diff changeset
   873
06bc494ca11e Initial load
duke
parents:
diff changeset
   874
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   875
     * Parses a list of files.
06bc494ca11e Initial load
duke
parents:
diff changeset
   876
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   877
   public List<JCCompilationUnit> parseFiles(List<JavaFileObject> fileObjects) throws IOException {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   878
       if (shouldStop(CompileState.PARSE))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   879
           return List.nil();
06bc494ca11e Initial load
duke
parents:
diff changeset
   880
06bc494ca11e Initial load
duke
parents:
diff changeset
   881
        //parse all files
06bc494ca11e Initial load
duke
parents:
diff changeset
   882
        ListBuffer<JCCompilationUnit> trees = lb();
06bc494ca11e Initial load
duke
parents:
diff changeset
   883
        for (JavaFileObject fileObject : fileObjects)
06bc494ca11e Initial load
duke
parents:
diff changeset
   884
            trees.append(parse(fileObject));
06bc494ca11e Initial load
duke
parents:
diff changeset
   885
        return trees.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
   886
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   887
06bc494ca11e Initial load
duke
parents:
diff changeset
   888
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   889
     * Enter the symbols found in a list of parse trees.
06bc494ca11e Initial load
duke
parents:
diff changeset
   890
     * As a side-effect, this puts elements on the "todo" list.
06bc494ca11e Initial load
duke
parents:
diff changeset
   891
     * Also stores a list of all top level classes in rootClasses.
06bc494ca11e Initial load
duke
parents:
diff changeset
   892
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   893
    public List<JCCompilationUnit> enterTrees(List<JCCompilationUnit> roots) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   894
        //enter symbols for all files
06bc494ca11e Initial load
duke
parents:
diff changeset
   895
        if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   896
            for (JCCompilationUnit unit: roots) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   897
                TaskEvent e = new TaskEvent(TaskEvent.Kind.ENTER, unit);
06bc494ca11e Initial load
duke
parents:
diff changeset
   898
                taskListener.started(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   899
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   900
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   901
06bc494ca11e Initial load
duke
parents:
diff changeset
   902
        enter.main(roots);
06bc494ca11e Initial load
duke
parents:
diff changeset
   903
06bc494ca11e Initial load
duke
parents:
diff changeset
   904
        if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   905
            for (JCCompilationUnit unit: roots) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   906
                TaskEvent e = new TaskEvent(TaskEvent.Kind.ENTER, unit);
06bc494ca11e Initial load
duke
parents:
diff changeset
   907
                taskListener.finished(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
   908
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   909
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   910
06bc494ca11e Initial load
duke
parents:
diff changeset
   911
        //If generating source, remember the classes declared in
06bc494ca11e Initial load
duke
parents:
diff changeset
   912
        //the original compilation units listed on the command line.
06bc494ca11e Initial load
duke
parents:
diff changeset
   913
        if (sourceOutput || stubOutput) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   914
            ListBuffer<JCClassDecl> cdefs = lb();
06bc494ca11e Initial load
duke
parents:
diff changeset
   915
            for (JCCompilationUnit unit : roots) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   916
                for (List<JCTree> defs = unit.defs;
06bc494ca11e Initial load
duke
parents:
diff changeset
   917
                     defs.nonEmpty();
06bc494ca11e Initial load
duke
parents:
diff changeset
   918
                     defs = defs.tail) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   919
                    if (defs.head instanceof JCClassDecl)
06bc494ca11e Initial load
duke
parents:
diff changeset
   920
                        cdefs.append((JCClassDecl)defs.head);
06bc494ca11e Initial load
duke
parents:
diff changeset
   921
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   922
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   923
            rootClasses = cdefs.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
   924
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   925
        return roots;
06bc494ca11e Initial load
duke
parents:
diff changeset
   926
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   927
06bc494ca11e Initial load
duke
parents:
diff changeset
   928
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   929
     * Set to true to enable skeleton annotation processing code.
06bc494ca11e Initial load
duke
parents:
diff changeset
   930
     * Currently, we assume this variable will be replaced more
06bc494ca11e Initial load
duke
parents:
diff changeset
   931
     * advanced logic to figure out if annotation processing is
06bc494ca11e Initial load
duke
parents:
diff changeset
   932
     * needed.
06bc494ca11e Initial load
duke
parents:
diff changeset
   933
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   934
    boolean processAnnotations = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   935
06bc494ca11e Initial load
duke
parents:
diff changeset
   936
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   937
     * Object to handle annotation processing.
06bc494ca11e Initial load
duke
parents:
diff changeset
   938
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   939
    JavacProcessingEnvironment procEnvImpl = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   940
06bc494ca11e Initial load
duke
parents:
diff changeset
   941
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   942
     * Check if we should process annotations.
06bc494ca11e Initial load
duke
parents:
diff changeset
   943
     * If so, and if no scanner is yet registered, then set up the DocCommentScanner
06bc494ca11e Initial load
duke
parents:
diff changeset
   944
     * to catch doc comments, and set keepComments so the parser records them in
06bc494ca11e Initial load
duke
parents:
diff changeset
   945
     * the compilation unit.
06bc494ca11e Initial load
duke
parents:
diff changeset
   946
     *
06bc494ca11e Initial load
duke
parents:
diff changeset
   947
     * @param processors user provided annotation processors to bypass
06bc494ca11e Initial load
duke
parents:
diff changeset
   948
     * discovery, {@code null} means that no processors were provided
06bc494ca11e Initial load
duke
parents:
diff changeset
   949
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   950
    public void initProcessAnnotations(Iterable<? extends Processor> processors) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   951
        // Process annotations if processing is not disabled and there
06bc494ca11e Initial load
duke
parents:
diff changeset
   952
        // is at least one Processor available.
06bc494ca11e Initial load
duke
parents:
diff changeset
   953
        Options options = Options.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   954
        if (options.get("-proc:none") != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   955
            processAnnotations = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   956
        } else if (procEnvImpl == null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   957
            procEnvImpl = new JavacProcessingEnvironment(context, processors);
06bc494ca11e Initial load
duke
parents:
diff changeset
   958
            processAnnotations = procEnvImpl.atLeastOneProcessor();
06bc494ca11e Initial load
duke
parents:
diff changeset
   959
06bc494ca11e Initial load
duke
parents:
diff changeset
   960
            if (processAnnotations) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   961
                if (context.get(Scanner.Factory.scannerFactoryKey) == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   962
                    DocCommentScanner.Factory.preRegister(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
   963
                options.put("save-parameter-names", "save-parameter-names");
06bc494ca11e Initial load
duke
parents:
diff changeset
   964
                reader.saveParameterNames = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   965
                keepComments = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   966
                if (taskListener != null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   967
                    taskListener.started(new TaskEvent(TaskEvent.Kind.ANNOTATION_PROCESSING));
06bc494ca11e Initial load
duke
parents:
diff changeset
   968
06bc494ca11e Initial load
duke
parents:
diff changeset
   969
06bc494ca11e Initial load
duke
parents:
diff changeset
   970
            } else { // free resources
06bc494ca11e Initial load
duke
parents:
diff changeset
   971
                procEnvImpl.close();
06bc494ca11e Initial load
duke
parents:
diff changeset
   972
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   973
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   974
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   975
06bc494ca11e Initial load
duke
parents:
diff changeset
   976
    // TODO: called by JavacTaskImpl
06bc494ca11e Initial load
duke
parents:
diff changeset
   977
    public JavaCompiler processAnnotations(List<JCCompilationUnit> roots) throws IOException {
06bc494ca11e Initial load
duke
parents:
diff changeset
   978
        return processAnnotations(roots, List.<String>nil());
06bc494ca11e Initial load
duke
parents:
diff changeset
   979
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   980
06bc494ca11e Initial load
duke
parents:
diff changeset
   981
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
   982
     * Process any anotations found in the specifed compilation units.
06bc494ca11e Initial load
duke
parents:
diff changeset
   983
     * @param roots a list of compilation units
06bc494ca11e Initial load
duke
parents:
diff changeset
   984
     * @return an instance of the compiler in which to complete the compilation
06bc494ca11e Initial load
duke
parents:
diff changeset
   985
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   986
    public JavaCompiler processAnnotations(List<JCCompilationUnit> roots,
06bc494ca11e Initial load
duke
parents:
diff changeset
   987
                                           List<String> classnames)
06bc494ca11e Initial load
duke
parents:
diff changeset
   988
        throws IOException  { // TODO: see TEMP note in JavacProcessingEnvironment
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
   989
        if (shouldStop(CompileState.PROCESS)) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   990
            // Errors were encountered.  If todo is empty, then the
06bc494ca11e Initial load
duke
parents:
diff changeset
   991
            // encountered errors were parse errors.  Otherwise, the
06bc494ca11e Initial load
duke
parents:
diff changeset
   992
            // errors were found during the enter phase which should
06bc494ca11e Initial load
duke
parents:
diff changeset
   993
            // be ignored when processing annotations.
06bc494ca11e Initial load
duke
parents:
diff changeset
   994
06bc494ca11e Initial load
duke
parents:
diff changeset
   995
            if (todo.isEmpty())
06bc494ca11e Initial load
duke
parents:
diff changeset
   996
                return this;
06bc494ca11e Initial load
duke
parents:
diff changeset
   997
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   998
06bc494ca11e Initial load
duke
parents:
diff changeset
   999
        // ASSERT: processAnnotations and procEnvImpl should have been set up by
06bc494ca11e Initial load
duke
parents:
diff changeset
  1000
        // by initProcessAnnotations
06bc494ca11e Initial load
duke
parents:
diff changeset
  1001
06bc494ca11e Initial load
duke
parents:
diff changeset
  1002
        // NOTE: The !classnames.isEmpty() checks should be refactored to Main.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1003
06bc494ca11e Initial load
duke
parents:
diff changeset
  1004
        if (!processAnnotations) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1005
            // If there are no annotation processors present, and
06bc494ca11e Initial load
duke
parents:
diff changeset
  1006
            // annotation processing is to occur with compilation,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1007
            // emit a warning.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1008
            Options options = Options.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1009
            if (options.get("-proc:only") != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1010
                log.warning("proc.proc-only.requested.no.procs");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1011
                todo.clear();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1012
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1013
            // If not processing annotations, classnames must be empty
06bc494ca11e Initial load
duke
parents:
diff changeset
  1014
            if (!classnames.isEmpty()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1015
                log.error("proc.no.explicit.annotation.processing.requested",
06bc494ca11e Initial load
duke
parents:
diff changeset
  1016
                          classnames);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1017
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1018
            return this; // continue regular compilation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1019
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1020
06bc494ca11e Initial load
duke
parents:
diff changeset
  1021
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1022
            List<ClassSymbol> classSymbols = List.nil();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1023
            List<PackageSymbol> pckSymbols = List.nil();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1024
            if (!classnames.isEmpty()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1025
                 // Check for explicit request for annotation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1026
                 // processing
06bc494ca11e Initial load
duke
parents:
diff changeset
  1027
                if (!explicitAnnotationProcessingRequested()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1028
                    log.error("proc.no.explicit.annotation.processing.requested",
06bc494ca11e Initial load
duke
parents:
diff changeset
  1029
                              classnames);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1030
                    return this; // TODO: Will this halt compilation?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1031
                } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1032
                    boolean errors = false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1033
                    for (String nameStr : classnames) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1034
                        Symbol sym = resolveIdent(nameStr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1035
                        if (sym == null || (sym.kind == Kinds.PCK && !processPcks)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1036
                            log.error("proc.cant.find.class", nameStr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1037
                            errors = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1038
                            continue;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1039
                        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1040
                        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1041
                            if (sym.kind == Kinds.PCK)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1042
                                sym.complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1043
                            if (sym.exists()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1044
                                Name name = names.fromString(nameStr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1045
                                if (sym.kind == Kinds.PCK)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1046
                                    pckSymbols = pckSymbols.prepend((PackageSymbol)sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1047
                                else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1048
                                    classSymbols = classSymbols.prepend((ClassSymbol)sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1049
                                continue;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1050
                            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1051
                            assert sym.kind == Kinds.PCK;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1052
                            log.warning("proc.package.does.not.exist", nameStr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1053
                            pckSymbols = pckSymbols.prepend((PackageSymbol)sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1054
                        } catch (CompletionFailure e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1055
                            log.error("proc.cant.find.class", nameStr);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1056
                            errors = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1057
                            continue;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1058
                        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1059
                    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1060
                    if (errors)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1061
                        return this;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1062
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1063
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1064
            JavaCompiler c = procEnvImpl.doProcessing(context, roots, classSymbols, pckSymbols);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1065
            if (c != this)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1066
                annotationProcessingOccurred = c.annotationProcessingOccurred = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1067
            return c;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1068
        } catch (CompletionFailure ex) {
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  1069
            log.error("cant.access", ex.sym, ex.getDetailValue());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1070
            return this;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1071
06bc494ca11e Initial load
duke
parents:
diff changeset
  1072
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1073
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1074
06bc494ca11e Initial load
duke
parents:
diff changeset
  1075
    boolean explicitAnnotationProcessingRequested() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1076
        Options options = Options.instance(context);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1077
        return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1078
            explicitAnnotationProcessingRequested ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1079
            options.get("-processor") != null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1080
            options.get("-processorpath") != null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1081
            options.get("-proc:only") != null ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1082
            options.get("-Xprint") != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1083
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1084
06bc494ca11e Initial load
duke
parents:
diff changeset
  1085
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1086
     * Attribute a list of parse trees, such as found on the "todo" list.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1087
     * Note that attributing classes may cause additional files to be
06bc494ca11e Initial load
duke
parents:
diff changeset
  1088
     * parsed and entered via the SourceCompleter.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1089
     * Attribution of the entries in the list does not stop if any errors occur.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1090
     * @returns a list of environments for attributd classes.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1091
     */
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1092
    public Queue<Env<AttrContext>> attribute(Queue<Env<AttrContext>> envs) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1093
        ListBuffer<Env<AttrContext>> results = lb();
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1094
        while (!envs.isEmpty())
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1095
            results.append(attribute(envs.remove()));
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1096
        return stopIfError(CompileState.ATTR, results);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1097
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1098
06bc494ca11e Initial load
duke
parents:
diff changeset
  1099
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1100
     * Attribute a parse tree.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1101
     * @returns the attributed parse tree
06bc494ca11e Initial load
duke
parents:
diff changeset
  1102
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1103
    public Env<AttrContext> attribute(Env<AttrContext> env) {
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1104
        if (compileStates.isDone(env, CompileState.ATTR))
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1105
            return env;
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1106
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1107
        if (verboseCompilePolicy)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1108
            log.printLines(log.noticeWriter, "[attribute " + env.enclClass.sym + "]");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1109
        if (verbose)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1110
            printVerbose("checking.attribution", env.enclClass.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1111
06bc494ca11e Initial load
duke
parents:
diff changeset
  1112
        if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1113
            TaskEvent e = new TaskEvent(TaskEvent.Kind.ANALYZE, env.toplevel, env.enclClass.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1114
            taskListener.started(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1115
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1116
06bc494ca11e Initial load
duke
parents:
diff changeset
  1117
        JavaFileObject prev = log.useSource(
06bc494ca11e Initial load
duke
parents:
diff changeset
  1118
                                  env.enclClass.sym.sourcefile != null ?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1119
                                  env.enclClass.sym.sourcefile :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1120
                                  env.toplevel.sourcefile);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1121
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1122
            attr.attribClass(env.tree.pos(), env.enclClass.sym);
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1123
            compileStates.put(env, CompileState.ATTR);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1124
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1125
        finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1126
            log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1127
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1128
06bc494ca11e Initial load
duke
parents:
diff changeset
  1129
        return env;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1130
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1131
06bc494ca11e Initial load
duke
parents:
diff changeset
  1132
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1133
     * Perform dataflow checks on attributed parse trees.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1134
     * These include checks for definite assignment and unreachable statements.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1135
     * If any errors occur, an empty list will be returned.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1136
     * @returns the list of attributed parse trees
06bc494ca11e Initial load
duke
parents:
diff changeset
  1137
     */
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1138
    public Queue<Env<AttrContext>> flow(Queue<Env<AttrContext>> envs) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1139
        ListBuffer<Env<AttrContext>> results = lb();
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1140
        for (Env<AttrContext> env: envs) {
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1141
            flow(env, results);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1142
        }
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1143
        return stopIfError(CompileState.FLOW, results);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1144
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1145
06bc494ca11e Initial load
duke
parents:
diff changeset
  1146
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1147
     * Perform dataflow checks on an attributed parse tree.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1148
     */
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1149
    public Queue<Env<AttrContext>> flow(Env<AttrContext> env) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1150
        ListBuffer<Env<AttrContext>> results = lb();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1151
        flow(env, results);
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1152
        return stopIfError(CompileState.FLOW, results);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1153
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1154
06bc494ca11e Initial load
duke
parents:
diff changeset
  1155
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1156
     * Perform dataflow checks on an attributed parse tree.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1157
     */
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1158
    protected void flow(Env<AttrContext> env, Queue<Env<AttrContext>> results) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1159
        try {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1160
            if (shouldStop(CompileState.FLOW))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1161
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1162
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1163
            if (relax || compileStates.isDone(env, CompileState.FLOW)) {
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1164
                results.add(env);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1165
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1166
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1167
06bc494ca11e Initial load
duke
parents:
diff changeset
  1168
            if (verboseCompilePolicy)
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1169
                printNote("[flow " + env.enclClass.sym + "]");
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1170
            JavaFileObject prev = log.useSource(
06bc494ca11e Initial load
duke
parents:
diff changeset
  1171
                                                env.enclClass.sym.sourcefile != null ?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1172
                                                env.enclClass.sym.sourcefile :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1173
                                                env.toplevel.sourcefile);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1174
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1175
                make.at(Position.FIRSTPOS);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1176
                TreeMaker localMake = make.forToplevel(env.toplevel);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1177
                flow.analyzeTree(env.tree, localMake);
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1178
                compileStates.put(env, CompileState.FLOW);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1179
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1180
                if (shouldStop(CompileState.FLOW))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1181
                    return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1182
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1183
                results.add(env);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1184
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1185
            finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1186
                log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1187
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1188
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1189
        finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1190
            if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1191
                TaskEvent e = new TaskEvent(TaskEvent.Kind.ANALYZE, env.toplevel, env.enclClass.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1192
                taskListener.finished(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1193
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1194
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1195
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1196
06bc494ca11e Initial load
duke
parents:
diff changeset
  1197
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1198
     * Prepare attributed parse trees, in conjunction with their attribution contexts,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1199
     * for source or code generation.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1200
     * If any errors occur, an empty list will be returned.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1201
     * @returns a list containing the classes to be generated
06bc494ca11e Initial load
duke
parents:
diff changeset
  1202
     */
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1203
    public Queue<Pair<Env<AttrContext>, JCClassDecl>> desugar(Queue<Env<AttrContext>> envs) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1204
        ListBuffer<Pair<Env<AttrContext>, JCClassDecl>> results = lb();
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1205
        for (Env<AttrContext> env: envs)
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1206
            desugar(env, results);
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1207
        return stopIfError(CompileState.FLOW, results);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1208
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1209
06bc494ca11e Initial load
duke
parents:
diff changeset
  1210
    /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1211
     * Prepare attributed parse trees, in conjunction with their attribution contexts,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1212
     * for source or code generation. If the file was not listed on the command line,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1213
     * the current implicitSourcePolicy is taken into account.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1214
     * The preparation stops as soon as an error is found.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1215
     */
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1216
    protected void desugar(final Env<AttrContext> env, Queue<Pair<Env<AttrContext>, JCClassDecl>> results) {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1217
        if (shouldStop(CompileState.TRANSTYPES))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1218
            return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1219
06bc494ca11e Initial load
duke
parents:
diff changeset
  1220
        if (implicitSourcePolicy == ImplicitSourcePolicy.NONE
06bc494ca11e Initial load
duke
parents:
diff changeset
  1221
                && !inputFiles.contains(env.toplevel.sourcefile)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1222
            return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1223
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1224
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1225
        /**
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1226
         * As erasure (TransTypes) destroys information needed in flow analysis,
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1227
         * including information in supertypes, we need to ensure that supertypes
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1228
         * are processed through attribute and flow before subtypes are translated.
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1229
         */
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1230
        class ScanNested extends TreeScanner {
1046
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1231
            Set<Env<AttrContext>> dependencies = new LinkedHashSet<Env<AttrContext>>();
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1232
            @Override
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1233
            public void visitClassDef(JCClassDecl node) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1234
                Type st = types.supertype(node.sym.type);
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1235
                if (st.tag == TypeTags.CLASS) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1236
                    ClassSymbol c = st.tsym.outermostClass();
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1237
                    Env<AttrContext> stEnv = enter.getEnv(c);
1046
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1238
                    if (stEnv != null && env != stEnv) {
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1239
                        if (dependencies.add(stEnv))
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1240
                            scan(stEnv.tree);
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1241
                    }
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1242
                }
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1243
                super.visitClassDef(node);
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1244
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1245
        }
936
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1246
        ScanNested scanner = new ScanNested();
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1247
        scanner.scan(env.tree);
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1248
        for (Env<AttrContext> dep: scanner.dependencies) {
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1249
            if (!compileStates.isDone(dep, CompileState.FLOW))
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1250
                flow(attribute(dep));
1d395a623f16 6726015: JavaCompiler: replace desugarLater by compileStates
jjg
parents: 864
diff changeset
  1251
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1252
1046
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1253
        //We need to check for error another time as more classes might
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1254
        //have been attributed and analyzed at this stage
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1255
        if (shouldStop(CompileState.TRANSTYPES))
1046
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1256
            return;
e395ce284cbf 6734819: Javac performs flows analysis on already translated classes
mcimadamore
parents: 936
diff changeset
  1257
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1258
        if (verboseCompilePolicy)
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1259
            printNote("[desugar " + env.enclClass.sym + "]");
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1260
06bc494ca11e Initial load
duke
parents:
diff changeset
  1261
        JavaFileObject prev = log.useSource(env.enclClass.sym.sourcefile != null ?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1262
                                  env.enclClass.sym.sourcefile :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1263
                                  env.toplevel.sourcefile);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1264
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1265
            //save tree prior to rewriting
06bc494ca11e Initial load
duke
parents:
diff changeset
  1266
            JCTree untranslated = env.tree;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1267
06bc494ca11e Initial load
duke
parents:
diff changeset
  1268
            make.at(Position.FIRSTPOS);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1269
            TreeMaker localMake = make.forToplevel(env.toplevel);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1270
06bc494ca11e Initial load
duke
parents:
diff changeset
  1271
            if (env.tree instanceof JCCompilationUnit) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1272
                if (!(stubOutput || sourceOutput || printFlat)) {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1273
                    if (shouldStop(CompileState.LOWER))
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1274
                        return;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1275
                    List<JCTree> pdef = lower.translateTopLevelClass(env, env.tree, localMake);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1276
                    if (pdef.head != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1277
                        assert pdef.tail.isEmpty();
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1278
                        results.add(new Pair<Env<AttrContext>, JCClassDecl>(env, (JCClassDecl)pdef.head));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1279
                    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1280
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1281
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1282
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1283
06bc494ca11e Initial load
duke
parents:
diff changeset
  1284
            if (stubOutput) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1285
                //emit stub Java source file, only for compilation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1286
                //units enumerated explicitly on the command line
06bc494ca11e Initial load
duke
parents:
diff changeset
  1287
                JCClassDecl cdef = (JCClassDecl)env.tree;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1288
                if (untranslated instanceof JCClassDecl &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1289
                    rootClasses.contains((JCClassDecl)untranslated) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1290
                    ((cdef.mods.flags & (Flags.PROTECTED|Flags.PUBLIC)) != 0 ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1291
                     cdef.sym.packge().getQualifiedName() == names.java_lang)) {
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1292
                    results.add(new Pair<Env<AttrContext>, JCClassDecl>(env, removeMethodBodies(cdef)));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1293
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1294
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1295
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1296
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1297
            if (shouldStop(CompileState.TRANSTYPES))
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1298
                return;
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1299
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1300
            env.tree = transTypes.translateTopLevelClass(env.tree, localMake);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1301
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1302
            if (shouldStop(CompileState.LOWER))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1303
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1304
06bc494ca11e Initial load
duke
parents:
diff changeset
  1305
            if (sourceOutput) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1306
                //emit standard Java source file, only for compilation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1307
                //units enumerated explicitly on the command line
06bc494ca11e Initial load
duke
parents:
diff changeset
  1308
                JCClassDecl cdef = (JCClassDecl)env.tree;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1309
                if (untranslated instanceof JCClassDecl &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1310
                    rootClasses.contains((JCClassDecl)untranslated)) {
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1311
                    results.add(new Pair<Env<AttrContext>, JCClassDecl>(env, cdef));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1312
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1313
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1314
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1315
06bc494ca11e Initial load
duke
parents:
diff changeset
  1316
            //translate out inner classes
06bc494ca11e Initial load
duke
parents:
diff changeset
  1317
            List<JCTree> cdefs = lower.translateTopLevelClass(env, env.tree, localMake);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1318
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1319
            if (shouldStop(CompileState.LOWER))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1320
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1321
06bc494ca11e Initial load
duke
parents:
diff changeset
  1322
            //generate code for each class
06bc494ca11e Initial load
duke
parents:
diff changeset
  1323
            for (List<JCTree> l = cdefs; l.nonEmpty(); l = l.tail) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1324
                JCClassDecl cdef = (JCClassDecl)l.head;
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1325
                results.add(new Pair<Env<AttrContext>, JCClassDecl>(env, cdef));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1326
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1327
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1328
        finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1329
            log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1330
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1331
06bc494ca11e Initial load
duke
parents:
diff changeset
  1332
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1333
06bc494ca11e Initial load
duke
parents:
diff changeset
  1334
    /** Generates the source or class file for a list of classes.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1335
     * The decision to generate a source file or a class file is
06bc494ca11e Initial load
duke
parents:
diff changeset
  1336
     * based upon the compiler's options.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1337
     * Generation stops if an error occurs while writing files.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1338
     */
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1339
    public void generate(Queue<Pair<Env<AttrContext>, JCClassDecl>> queue) {
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1340
        generate(queue, null);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1341
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1342
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1343
    public void generate(Queue<Pair<Env<AttrContext>, JCClassDecl>> queue, Queue<JavaFileObject> results) {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1344
        if (shouldStop(CompileState.GENERATE))
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1345
            return;
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1346
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1347
        boolean usePrintSource = (stubOutput || sourceOutput || printFlat);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1348
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1349
        for (Pair<Env<AttrContext>, JCClassDecl> x: queue) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1350
            Env<AttrContext> env = x.fst;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1351
            JCClassDecl cdef = x.snd;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1352
06bc494ca11e Initial load
duke
parents:
diff changeset
  1353
            if (verboseCompilePolicy) {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1354
                printNote("[generate "
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1355
                               + (usePrintSource ? " source" : "code")
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1356
                               + " " + cdef.sym + "]");
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1357
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1358
06bc494ca11e Initial load
duke
parents:
diff changeset
  1359
            if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1360
                TaskEvent e = new TaskEvent(TaskEvent.Kind.GENERATE, env.toplevel, cdef.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1361
                taskListener.started(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1362
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1363
06bc494ca11e Initial load
duke
parents:
diff changeset
  1364
            JavaFileObject prev = log.useSource(env.enclClass.sym.sourcefile != null ?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1365
                                      env.enclClass.sym.sourcefile :
06bc494ca11e Initial load
duke
parents:
diff changeset
  1366
                                      env.toplevel.sourcefile);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1367
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1368
                JavaFileObject file;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1369
                if (usePrintSource)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1370
                    file = printSource(env, cdef);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1371
                else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1372
                    file = genCode(env, cdef);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1373
                if (results != null && file != null)
1355
74cc97efef51 6420151: need to improve byfile compile policy to eliminate footprint issues
jjg
parents: 1260
diff changeset
  1374
                    results.add(file);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1375
            } catch (IOException ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1376
                log.error(cdef.pos(), "class.cant.write",
06bc494ca11e Initial load
duke
parents:
diff changeset
  1377
                          cdef.sym, ex.getMessage());
06bc494ca11e Initial load
duke
parents:
diff changeset
  1378
                return;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1379
            } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1380
                log.useSource(prev);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1381
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1382
06bc494ca11e Initial load
duke
parents:
diff changeset
  1383
            if (taskListener != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1384
                TaskEvent e = new TaskEvent(TaskEvent.Kind.GENERATE, env.toplevel, cdef.sym);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1385
                taskListener.finished(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1386
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1387
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1388
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1389
06bc494ca11e Initial load
duke
parents:
diff changeset
  1390
        // where
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1391
        Map<JCCompilationUnit, Queue<Env<AttrContext>>> groupByFile(Queue<Env<AttrContext>> envs) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1392
            // use a LinkedHashMap to preserve the order of the original list as much as possible
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1393
            Map<JCCompilationUnit, Queue<Env<AttrContext>>> map = new LinkedHashMap<JCCompilationUnit, Queue<Env<AttrContext>>>();
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1394
            for (Env<AttrContext> env: envs) {
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1395
                Queue<Env<AttrContext>> sublist = map.get(env.toplevel);
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1396
                if (sublist == null) {
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1397
                    sublist = new ListBuffer<Env<AttrContext>>();
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1398
                    map.put(env.toplevel, sublist);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1399
                }
864
b1cf6afb8244 6724551: Use Queues instead of Lists to link compiler phases
jjg
parents: 735
diff changeset
  1400
                sublist.add(env);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1401
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1402
            return map;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1403
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1404
06bc494ca11e Initial load
duke
parents:
diff changeset
  1405
        JCClassDecl removeMethodBodies(JCClassDecl cdef) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1406
            final boolean isInterface = (cdef.mods.flags & Flags.INTERFACE) != 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1407
            class MethodBodyRemover extends TreeTranslator {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1408
                @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1409
                public void visitMethodDef(JCMethodDecl tree) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1410
                    tree.mods.flags &= ~Flags.SYNCHRONIZED;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1411
                    for (JCVariableDecl vd : tree.params)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1412
                        vd.mods.flags &= ~Flags.FINAL;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1413
                    tree.body = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1414
                    super.visitMethodDef(tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1415
                }
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1416
                @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1417
                public void visitVarDef(JCVariableDecl tree) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1418
                    if (tree.init != null && tree.init.type.constValue() == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1419
                        tree.init = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1420
                    super.visitVarDef(tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1421
                }
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1422
                @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1423
                public void visitClassDef(JCClassDecl tree) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1424
                    ListBuffer<JCTree> newdefs = lb();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1425
                    for (List<JCTree> it = tree.defs; it.tail != null; it = it.tail) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1426
                        JCTree t = it.head;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1427
                        switch (t.getTag()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1428
                        case JCTree.CLASSDEF:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1429
                            if (isInterface ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1430
                                (((JCClassDecl) t).mods.flags & (Flags.PROTECTED|Flags.PUBLIC)) != 0 ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1431
                                (((JCClassDecl) t).mods.flags & (Flags.PRIVATE)) == 0 && ((JCClassDecl) t).sym.packge().getQualifiedName() == names.java_lang)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1432
                                newdefs.append(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1433
                            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1434
                        case JCTree.METHODDEF:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1435
                            if (isInterface ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1436
                                (((JCMethodDecl) t).mods.flags & (Flags.PROTECTED|Flags.PUBLIC)) != 0 ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1437
                                ((JCMethodDecl) t).sym.name == names.init ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1438
                                (((JCMethodDecl) t).mods.flags & (Flags.PRIVATE)) == 0 && ((JCMethodDecl) t).sym.packge().getQualifiedName() == names.java_lang)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1439
                                newdefs.append(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1440
                            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1441
                        case JCTree.VARDEF:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1442
                            if (isInterface || (((JCVariableDecl) t).mods.flags & (Flags.PROTECTED|Flags.PUBLIC)) != 0 ||
06bc494ca11e Initial load
duke
parents:
diff changeset
  1443
                                (((JCVariableDecl) t).mods.flags & (Flags.PRIVATE)) == 0 && ((JCVariableDecl) t).sym.packge().getQualifiedName() == names.java_lang)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1444
                                newdefs.append(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1445
                            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1446
                        default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1447
                            break;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1448
                        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1449
                    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1450
                    tree.defs = newdefs.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1451
                    super.visitClassDef(tree);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1452
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1453
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1454
            MethodBodyRemover r = new MethodBodyRemover();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1455
            return r.translate(cdef);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1456
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1457
06bc494ca11e Initial load
duke
parents:
diff changeset
  1458
    public void reportDeferredDiagnostics() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1459
        if (annotationProcessingOccurred
06bc494ca11e Initial load
duke
parents:
diff changeset
  1460
                && implicitSourceFilesRead
06bc494ca11e Initial load
duke
parents:
diff changeset
  1461
                && implicitSourcePolicy == ImplicitSourcePolicy.UNSET) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1462
            if (explicitAnnotationProcessingRequested())
06bc494ca11e Initial load
duke
parents:
diff changeset
  1463
                log.warning("proc.use.implicit");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1464
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1465
                log.warning("proc.use.proc.or.implicit");
06bc494ca11e Initial load
duke
parents:
diff changeset
  1466
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1467
        chk.reportDeferredDiagnostics();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1468
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1469
06bc494ca11e Initial load
duke
parents:
diff changeset
  1470
    /** Close the compiler, flushing the logs
06bc494ca11e Initial load
duke
parents:
diff changeset
  1471
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1472
    public void close() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1473
        close(true);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1474
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1475
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1258
diff changeset
  1476
    public void close(boolean disposeNames) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1477
        rootClasses = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1478
        reader = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1479
        make = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1480
        writer = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1481
        enter = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1482
        if (todo != null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1483
            todo.clear();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1484
        todo = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1485
        parserFactory = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1486
        syms = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1487
        source = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1488
        attr = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1489
        chk = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1490
        gen = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1491
        flow = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1492
        transTypes = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1493
        lower = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1494
        annotate = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1495
        types = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1496
06bc494ca11e Initial load
duke
parents:
diff changeset
  1497
        log.flush();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1498
        try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1499
            fileManager.flush();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1500
        } catch (IOException e) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1501
            throw new Abort(e);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1502
        } finally {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1503
            if (names != null && disposeNames)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1504
                names.dispose();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1505
            names = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1506
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1507
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1508
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1509
    protected void printNote(String lines) {
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1510
        Log.printLines(log.noticeWriter, lines);
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1511
    }
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1512
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1513
    /** Output for "-verbose" option.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1514
     *  @param key The key to look up the correct internationalized string.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1515
     *  @param arg An argument for substitution into the output string.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1516
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1517
    protected void printVerbose(String key, Object arg) {
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1518
        Log.printLines(log.noticeWriter, Log.getLocalizedString("verbose." + key, arg));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1519
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1520
06bc494ca11e Initial load
duke
parents:
diff changeset
  1521
    /** Print numbers of errors and warnings.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1522
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1523
    protected void printCount(String kind, int count) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1524
        if (count != 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1525
            String text;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1526
            if (count == 1)
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1527
                text = Log.getLocalizedString("count." + kind, String.valueOf(count));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1528
            else
2514
f8929e3790b4 6813059: replace use of JavaCompiler.errorCount with shouldContinue
jjg
parents: 2212
diff changeset
  1529
                text = Log.getLocalizedString("count." + kind + ".plural", String.valueOf(count));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1530
            Log.printLines(log.errWriter, text);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1531
            log.errWriter.flush();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1532
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1533
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1534
06bc494ca11e Initial load
duke
parents:
diff changeset
  1535
    private static long now() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1536
        return System.currentTimeMillis();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1537
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1538
06bc494ca11e Initial load
duke
parents:
diff changeset
  1539
    private static long elapsed(long then) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1540
        return now() - then;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1541
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1542
06bc494ca11e Initial load
duke
parents:
diff changeset
  1543
    public void initRound(JavaCompiler prev) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1544
        keepComments = prev.keepComments;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1545
        start_msec = prev.start_msec;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1546
        hasBeenUsed = true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1547
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1548
06bc494ca11e Initial load
duke
parents:
diff changeset
  1549
    public static void enableLogging() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1550
        Logger logger = Logger.getLogger(com.sun.tools.javac.Main.class.getPackage().getName());
06bc494ca11e Initial load
duke
parents:
diff changeset
  1551
        logger.setLevel(Level.ALL);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1552
        for (Handler h : logger.getParent().getHandlers()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1553
            h.setLevel(Level.ALL);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1554
       }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1555
06bc494ca11e Initial load
duke
parents:
diff changeset
  1556
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1557
}