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