langtools/test/tools/javac/lib/DPrinter.java
author jjg
Tue, 04 Jun 2013 14:17:50 -0700
changeset 18010 604faee85350
parent 17578 46ac954e4a84
child 19928 adce50c2b76c
permissions -rw-r--r--
8004643: Reduce javac space overhead introduced with compiler support for repeating annotations Reviewed-by: mcimadamore, jfranck
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     1
/*
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     2
 * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     4
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     7
 * published by the Free Software Foundation.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     8
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    13
 * accompanied this code).
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    14
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    18
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    21
 * questions.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    22
 */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    23
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    24
import java.io.File;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    25
import java.io.IOException;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    26
import java.io.PrintWriter;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    27
import java.lang.reflect.Field;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    28
import java.util.ArrayList;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    29
import java.util.Arrays;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    30
import java.util.Collection;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    31
import java.util.EnumSet;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    32
import java.util.HashMap;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    33
import java.util.List;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    34
import java.util.Locale;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    35
import java.util.Map;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    36
import java.util.Set;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    37
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    38
import javax.lang.model.element.Name;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    39
import javax.lang.model.element.TypeElement;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    40
import javax.tools.FileObject;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    41
import javax.tools.JavaCompiler;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    42
import javax.tools.JavaFileObject;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    43
import javax.tools.StandardJavaFileManager;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    44
import javax.tools.StandardLocation;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    45
import javax.tools.ToolProvider;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    46
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    47
import com.sun.source.util.JavacTask;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    48
import com.sun.source.util.TaskEvent;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    49
import com.sun.source.util.TaskListener;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    50
import com.sun.source.util.Trees;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    51
import com.sun.tools.javac.api.JavacTrees;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    52
import com.sun.tools.javac.code.Annotations;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    53
import com.sun.tools.javac.code.Attribute;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    54
import com.sun.tools.javac.code.Flags;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    55
import com.sun.tools.javac.code.Kinds;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    56
import com.sun.tools.javac.code.Printer;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    57
import com.sun.tools.javac.code.Scope;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    58
import com.sun.tools.javac.code.Scope.CompoundScope;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    59
import com.sun.tools.javac.code.Symbol;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    60
import com.sun.tools.javac.code.Symbol.*;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    61
import com.sun.tools.javac.code.Type;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    62
import com.sun.tools.javac.code.Type.*;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    63
import com.sun.tools.javac.code.TypeTag;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    64
import com.sun.tools.javac.tree.JCTree;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    65
import com.sun.tools.javac.tree.JCTree.*;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    66
import com.sun.tools.javac.tree.Pretty;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    67
import com.sun.tools.javac.tree.TreeInfo;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    68
import com.sun.tools.javac.tree.TreeScanner;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    69
import com.sun.tools.javac.util.Assert;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    70
import com.sun.tools.javac.util.Context;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    71
import com.sun.tools.javac.util.Log;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    72
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    73
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    74
/**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    75
 * Debug printer for javac internals, for when toString() just isn't enough.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    76
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    77
 * <p>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    78
 * The printer provides an API to generate structured views of javac objects,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    79
 * such as AST nodes, symbol, types and annotations. Various aspects of the
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    80
 * output can be configured, such as whether to show nulls, empty lists, or
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    81
 * a compressed representation of the source code. Visitors are used to walk
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    82
 * object hierarchies, and can be replaced with custom visitors if the default
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    83
 * visitors are not flexible enough.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    84
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    85
 * <p>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    86
 * In general, nodes are printed with an initial line identifying the node
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    87
 * followed by indented lines for the child nodes. Currently, graphs are
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    88
 * represented by printing a spanning subtree.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    89
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    90
 * <p>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    91
 * The printer can be accessed via a simple command-line utility,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    92
 * which makes it easy to see the internal representation of source code,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    93
 * such as simple test programs, during the compilation pipeline.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    94
 *
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    95
 *  <p><b>This is NOT part of any supported API.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    96
 *  If you write code that depends on this, you do so at your own risk.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    97
 *  This code and its internal interfaces are subject to change or
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    98
 *  deletion without notice.</b>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
    99
 */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   100
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   101
public class DPrinter {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   102
    protected final PrintWriter out;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   103
    protected final Trees trees;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   104
    protected Printer printer;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   105
    protected boolean showEmptyItems = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   106
    protected boolean showNulls = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   107
    protected boolean showPositions = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   108
    protected boolean showSrc;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   109
    protected boolean showTreeSymbols;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   110
    protected boolean showTreeTypes;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   111
    protected int maxSrcLength = 32;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   112
    protected Locale locale = Locale.getDefault();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   113
    protected static final String NULL = "#null";
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   114
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   115
    // <editor-fold defaultstate="collapsed" desc="Configuration">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   116
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   117
    public static DPrinter instance(Context context) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   118
        DPrinter dp = context.get(DPrinter.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   119
        if (dp == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   120
            dp = new DPrinter(context);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   121
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   122
        return dp;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   123
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   124
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   125
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   126
    protected DPrinter(Context context) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   127
        context.put(DPrinter.class, this);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   128
        out = context.get(Log.outKey);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   129
        trees = JavacTrees.instance(context);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   130
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   131
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   132
    public DPrinter(PrintWriter out, Trees trees) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   133
        this.out = out;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   134
        this.trees = trees;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   135
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   136
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   137
    public DPrinter emptyItems(boolean showEmptyItems) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   138
        this.showEmptyItems = showEmptyItems;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   139
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   140
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   141
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   142
    public DPrinter nulls(boolean showNulls) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   143
        this.showNulls = showNulls;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   144
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   145
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   146
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   147
    public DPrinter positions(boolean showPositions) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   148
        this.showPositions = showPositions;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   149
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   150
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   151
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   152
    public DPrinter source(boolean showSrc) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   153
        this.showSrc = showSrc;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   154
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   155
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   156
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   157
    public DPrinter source(int maxSrcLength) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   158
        this.showSrc = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   159
        this.maxSrcLength = maxSrcLength;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   160
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   161
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   162
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   163
    public DPrinter treeSymbols(boolean showTreeSymbols) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   164
        this.showTreeSymbols = showTreeSymbols;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   165
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   166
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   167
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   168
    public DPrinter treeTypes(boolean showTreeTypes) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   169
        this.showTreeTypes = showTreeTypes;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   170
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   171
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   172
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   173
    public DPrinter typeSymbolPrinter(Printer p) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   174
        printer = p;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   175
        return this;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   176
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   177
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   178
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   179
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   180
    // <editor-fold defaultstate="collapsed" desc="Printing">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   181
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   182
    protected enum Details {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   183
        /** A one-line non-recursive summary */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   184
        SUMMARY,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   185
        /** Multi-line, possibly recursive. */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   186
        FULL
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   187
    };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   188
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   189
    public void printAnnotations(String label, Annotations annotations) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   190
        printAnnotations(label, annotations, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   191
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   192
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   193
    protected void printAnnotations(String label, Annotations annotations, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   194
        if (annotations == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   195
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   196
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   197
            // no SUMMARY format currently available to use
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   198
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   199
            // use reflection to get at private fields
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   200
            Object DECL_NOT_STARTED = getField(null, Annotations.class, "DECL_NOT_STARTED");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   201
            Object DECL_IN_PROGRESS = getField(null, Annotations.class, "DECL_IN_PROGRESS");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   202
            Object attributes = getField(annotations, Annotations.class, "attributes");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   203
            Object type_attributes = getField(annotations, Annotations.class, "type_attributes");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   204
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   205
            if (!showEmptyItems) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   206
                if (attributes instanceof List && ((List) attributes).isEmpty()
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   207
                        && attributes != DECL_NOT_STARTED
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   208
                        && attributes != DECL_IN_PROGRESS
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   209
                        && type_attributes instanceof List && ((List) type_attributes).isEmpty())
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   210
                    return;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   211
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   212
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   213
            printString(label, hashString(annotations));
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   214
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   215
            indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   216
            if (attributes == DECL_NOT_STARTED)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   217
                printString("attributes", "DECL_NOT_STARTED");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   218
            else if (attributes == DECL_IN_PROGRESS)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   219
                printString("attributes", "DECL_IN_PROGRESS");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   220
            else if (attributes instanceof List)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   221
                printList("attributes", (List) attributes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   222
            else
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   223
                printObject("attributes", attributes, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   224
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   225
            if (attributes instanceof List)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   226
                printList("type_attributes", (List) type_attributes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   227
            else
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   228
                printObject("type_attributes", type_attributes, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   229
            indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   230
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   231
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   232
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   233
    public void printAttribute(String label, Attribute attr) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   234
        if (attr == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   235
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   236
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   237
            printString(label, attr.getClass().getSimpleName());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   238
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   239
            indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   240
            attr.accept(attrVisitor);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   241
            indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   242
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   243
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   244
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   245
    public void printFileObject(String label, FileObject fo) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   246
        if (fo == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   247
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   248
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   249
            printString(label, fo.getName());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   250
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   251
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   252
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   253
    protected <T> void printImplClass(T item, Class<? extends T> stdImplClass) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   254
        if (item.getClass() != stdImplClass)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   255
            printString("impl", item.getClass().getName());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   256
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   257
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   258
    public void printInt(String label, int i) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   259
        printString(label, String.valueOf(i));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   260
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   261
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   262
    public void printList(String label, List<?> list) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   263
        if (list == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   264
             printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   265
        } else if (!list.isEmpty() || showEmptyItems) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   266
            printString(label, "[" + list.size() + "]");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   267
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   268
            indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   269
            int i = 0;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   270
            for (Object item: list) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   271
                printObject(String.valueOf(i++), item, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   272
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   273
            indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   274
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   275
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   276
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   277
    public void printName(String label, Name name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   278
        if (name == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   279
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   280
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   281
            printString(label, name.toString());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   282
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   283
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   284
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   285
    public void printNull(String label) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   286
        if (showNulls)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   287
            printString(label, NULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   288
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   289
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   290
    protected void printObject(String label, Object item, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   291
        if (item == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   292
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   293
        } else if (item instanceof Attribute) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   294
            printAttribute(label, (Attribute) item);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   295
        } else if (item instanceof Symbol) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   296
            printSymbol(label, (Symbol) item, details);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   297
        } else if (item instanceof Type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   298
            printType(label, (Type) item, details);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   299
        } else if (item instanceof JCTree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   300
            printTree(label, (JCTree) item);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   301
        } else if (item instanceof List) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   302
            printList(label, (List) item);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   303
        } else if (item instanceof Name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   304
            printName(label, (Name) item);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   305
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   306
            printString(label, String.valueOf(item));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   307
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   308
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   309
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   310
    public void printScope(String label, Scope scope) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   311
        printScope(label, scope, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   312
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   313
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   314
    public void printScope(String label, Scope scope, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   315
        if (scope == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   316
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   317
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   318
            switch (details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   319
                case SUMMARY: {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   320
                    indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   321
                    out.print(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   322
                    out.print(": [");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   323
                    String sep = "";
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   324
                    for (Symbol sym: scope.getElements()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   325
                        out.print(sep);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   326
                        out.print(sym.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   327
                        sep = ",";
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   328
                    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   329
                    out.println("]");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   330
                    break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   331
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   332
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   333
                case FULL: {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   334
                    indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   335
                    out.println(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   336
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   337
                    indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   338
                    printImplClass(scope, Scope.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   339
                    printSymbol("owner", scope.owner, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   340
                    printScope("next", scope.next, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   341
                    printObject("shared", getField(scope, Scope.class, "shared"), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   342
                    if (scope instanceof CompoundScope) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   343
                        printObject("subScopes",
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   344
                                getField(scope, CompoundScope.class, "subScopes"),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   345
                                Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   346
                    } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   347
                        for (Symbol sym : scope.getElements()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   348
                            printSymbol(sym.name.toString(), sym, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   349
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   350
                    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   351
                    indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   352
                    break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   353
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   354
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   355
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   356
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   357
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   358
    public void printSource(String label, JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   359
        printString(label, Pretty.toSimpleString(tree, maxSrcLength));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   360
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   361
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   362
    public void printString(String label, String text) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   363
        indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   364
        out.print(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   365
        out.print(": ");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   366
        out.print(text);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   367
        out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   368
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   369
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   370
    public void printSymbol(String label, Symbol symbol) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   371
        printSymbol(label, symbol, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   372
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   373
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   374
    protected void printSymbol(String label, Symbol sym, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   375
        if (sym == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   376
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   377
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   378
            switch (details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   379
            case SUMMARY:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   380
                printString(label, toString(sym));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   381
                break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   382
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   383
            case FULL:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   384
                indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   385
                out.print(label);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   386
                out.println(": " +
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   387
                        info(sym.getClass(),
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   388
                            String.format("0x%x--%s", sym.kind, Kinds.kindName(sym)),
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   389
                            sym.getKind())
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   390
                        + " " + sym.name
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   391
                        + " " + hashString(sym));
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   392
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   393
                indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   394
                if (showSrc) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   395
                    JCTree tree = (JCTree) trees.getTree(sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   396
                    if (tree != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   397
                        printSource("src", tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   398
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   399
                printString("flags", String.format("0x%x--%s",
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   400
                        sym.flags_field, Flags.toString(sym.flags_field)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   401
                printObject("completer", sym.completer, Details.SUMMARY); // what if too long?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   402
                printSymbol("owner", sym.owner, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   403
                printType("type", sym.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   404
                printType("erasure", sym.erasure_field, Details.SUMMARY);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   405
                sym.accept(symVisitor, null);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17578
diff changeset
   406
                printAnnotations("annotations", sym.getAnnotations(), Details.SUMMARY);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   407
                indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   408
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   409
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   410
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   411
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   412
    protected String toString(Symbol sym) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   413
        return (printer != null) ? printer.visit(sym, locale) : String.valueOf(sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   414
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   415
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   416
    protected void printTree(String label, JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   417
        if (tree == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   418
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   419
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   420
            indent();
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   421
            String ext;
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   422
            try {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   423
                ext = tree.getKind().name();
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   424
            } catch (Throwable t) {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   425
                ext = "n/a";
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   426
            }
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   427
            out.print(label + ": " + info(tree.getClass(), tree.getTag(), ext));
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   428
            if (showPositions) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   429
                // We can always get start position, but to get end position
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   430
                // and/or line+offset, we would need a JCCompilationUnit
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   431
                out.print(" pos:" + tree.pos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   432
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   433
            if (showTreeTypes && tree.type != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   434
                out.print(" type:" + toString(tree.type));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   435
            Symbol sym;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   436
            if (showTreeSymbols && (sym = TreeInfo.symbolFor(tree)) != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   437
                out.print(" sym:" + toString(sym));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   438
            out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   439
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   440
            indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   441
            if (showSrc) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   442
                indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   443
                out.println("src: " + Pretty.toSimpleString(tree, maxSrcLength));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   444
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   445
            tree.accept(treeVisitor);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   446
            indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   447
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   448
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   449
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   450
    public void printType(String label, Type type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   451
        printType(label, type, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   452
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   453
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   454
    protected void printType(String label, Type type, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   455
        if (type == null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   456
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   457
        else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   458
            switch (details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   459
                case SUMMARY:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   460
                    printString(label, toString(type));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   461
                    break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   462
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   463
                case FULL:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   464
                    indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   465
                    out.print(label);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   466
                    out.println(": " + info(type.getClass(), type.getTag(), type.getKind())
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   467
                            + " " + hashString(type));
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   468
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   469
                    indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   470
                    printSymbol("tsym", type.tsym, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   471
                    printObject("constValue", type.constValue(), Details.SUMMARY);
17578
46ac954e4a84 8013852: update reference impl for type-annotations
jjg
parents: 15705
diff changeset
   472
                    printObject("annotations", type.getAnnotationMirrors(), Details.SUMMARY);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   473
                    type.accept(typeVisitor, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   474
                    indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   475
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   476
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   477
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   478
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   479
    protected String toString(Type type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   480
        return (printer != null) ? printer.visit(type, locale) : String.valueOf(type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   481
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   482
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   483
    protected String hashString(Object obj) {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   484
        return String.format("#%x", obj.hashCode());
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   485
    }
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   486
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   487
    protected String info(Class<?> clazz, Object internal, Object external) {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   488
        return String.format("%s,%s,%s", clazz.getSimpleName(), internal, external);
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   489
    }
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   490
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   491
    private int indent = 0;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   492
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   493
    protected void indent() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   494
        for (int i = 0; i < indent; i++) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   495
            out.print("  ");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   496
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   497
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   498
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   499
    protected void indent(int n) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   500
        indent += n;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   501
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   502
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   503
    protected Object getField(Object o, Class<?> clazz, String name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   504
        try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   505
            Field f = clazz.getDeclaredField(name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   506
            boolean prev = f.isAccessible();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   507
            f.setAccessible(true);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   508
            try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   509
                return f.get(o);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   510
            } finally {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   511
                f.setAccessible(prev);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   512
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   513
        } catch (ReflectiveOperationException e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   514
            return e;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   515
        } catch (SecurityException e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   516
            return e;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   517
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   518
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   519
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   520
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   521
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   522
    // <editor-fold defaultstate="collapsed" desc="JCTree visitor methods">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   523
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   524
    protected JCTree.Visitor treeVisitor = new TreeVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   525
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   526
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   527
     * Default visitor class for JCTree (AST) objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   528
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   529
    public class TreeVisitor extends JCTree.Visitor {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   530
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   531
        public void visitTopLevel(JCCompilationUnit tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   532
            printList("packageAnnotations", tree.packageAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   533
            printTree("pid", tree.pid);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   534
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   535
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   536
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   537
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   538
        public void visitImport(JCImport tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   539
            printTree("qualid", tree.qualid);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   540
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   541
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   542
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   543
        public void visitClassDef(JCClassDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   544
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   545
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   546
            printList("typarams", tree.typarams);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   547
            printTree("extending", tree.extending);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   548
            printList("implementing", tree.implementing);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   549
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   550
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   551
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   552
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   553
        public void visitMethodDef(JCMethodDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   554
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   555
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   556
            printTree("restype", tree.restype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   557
            printList("typarams", tree.typarams);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   558
            printTree("recvparam", tree.recvparam);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   559
            printList("params", tree.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   560
            printList("thrown", tree.thrown);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   561
            printTree("defaultValue", tree.defaultValue);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   562
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   563
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   564
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   565
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   566
        public void visitVarDef(JCVariableDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   567
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   568
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   569
            printTree("vartype", tree.vartype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   570
            printTree("init", tree.init);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   571
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   572
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   573
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   574
        public void visitSkip(JCSkip tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   575
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   576
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   577
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   578
        public void visitBlock(JCBlock tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   579
            printList("stats", tree.stats);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   580
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   581
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   582
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   583
        public void visitDoLoop(JCDoWhileLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   584
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   585
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   586
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   587
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   588
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   589
        public void visitWhileLoop(JCWhileLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   590
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   591
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   592
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   593
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   594
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   595
        public void visitForLoop(JCForLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   596
            printList("init", tree.init);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   597
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   598
            printList("step", tree.step);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   599
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   600
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   601
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   602
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   603
        public void visitForeachLoop(JCEnhancedForLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   604
            printTree("var", tree.var);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   605
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   606
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   607
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   608
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   609
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   610
        public void visitLabelled(JCLabeledStatement tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   611
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   612
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   613
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   614
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   615
        public void visitSwitch(JCSwitch tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   616
            printTree("selector", tree.selector);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   617
            printList("cases", tree.cases);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   618
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   619
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   620
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   621
        public void visitCase(JCCase tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   622
            printTree("pat", tree.pat);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   623
            printList("stats", tree.stats);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   624
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   625
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   626
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   627
        public void visitSynchronized(JCSynchronized tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   628
            printTree("lock", tree.lock);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   629
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   630
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   631
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   632
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   633
        public void visitTry(JCTry tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   634
            printList("resources", tree.resources);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   635
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   636
            printList("catchers", tree.catchers);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   637
            printTree("finalizer", tree.finalizer);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   638
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   639
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   640
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   641
        public void visitCatch(JCCatch tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   642
            printTree("param", tree.param);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   643
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   644
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   645
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   646
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   647
        public void visitConditional(JCConditional tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   648
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   649
            printTree("truepart", tree.truepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   650
            printTree("falsepart", tree.falsepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   651
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   652
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   653
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   654
        public void visitIf(JCIf tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   655
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   656
            printTree("thenpart", tree.thenpart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   657
            printTree("elsepart", tree.elsepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   658
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   659
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   660
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   661
        public void visitExec(JCExpressionStatement tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   662
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   663
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   664
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   665
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   666
        public void visitBreak(JCBreak tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   667
            printName("label", tree.label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   668
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   669
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   670
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   671
        public void visitContinue(JCContinue tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   672
            printName("label", tree.label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   673
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   674
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   675
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   676
        public void visitReturn(JCReturn tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   677
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   678
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   679
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   680
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   681
        public void visitThrow(JCThrow tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   682
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   683
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   684
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   685
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   686
        public void visitAssert(JCAssert tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   687
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   688
            printTree("detail", tree.detail);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   689
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   690
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   691
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   692
        public void visitApply(JCMethodInvocation tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   693
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   694
            printTree("meth", tree.meth);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   695
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   696
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   697
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   698
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   699
        public void visitNewClass(JCNewClass tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   700
            printTree("encl", tree.encl);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   701
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   702
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   703
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   704
            printTree("def", tree.def);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   705
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   706
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   707
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   708
        public void visitNewArray(JCNewArray tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   709
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   710
            printTree("elemtype", tree.elemtype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   711
            printList("dims", tree.dims);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   712
            printList("dimAnnotations", tree.dimAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   713
            printList("elems", tree.elems);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   714
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   715
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   716
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   717
        public void visitLambda(JCLambda tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   718
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   719
            printList("params", tree.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   720
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   721
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   722
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   723
        public void visitParens(JCParens tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   724
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   725
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   726
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   727
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   728
        public void visitAssign(JCAssign tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   729
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   730
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   731
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   732
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   733
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   734
        public void visitAssignop(JCAssignOp tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   735
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   736
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   737
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   738
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   739
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   740
        public void visitUnary(JCUnary tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   741
            printTree("arg", tree.arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   742
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   743
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   744
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   745
        public void visitBinary(JCBinary tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   746
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   747
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   748
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   749
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   750
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   751
        public void visitTypeCast(JCTypeCast tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   752
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   753
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   754
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   755
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   756
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   757
        public void visitTypeTest(JCInstanceOf tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   758
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   759
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   760
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   761
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   762
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   763
        public void visitIndexed(JCArrayAccess tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   764
            printTree("indexed", tree.indexed);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   765
            printTree("index", tree.index);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   766
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   767
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   768
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   769
        public void visitSelect(JCFieldAccess tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   770
            printTree("selected", tree.selected);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   771
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   772
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   773
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   774
        public void visitReference(JCMemberReference tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   775
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   776
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   777
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   778
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   779
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   780
        public void visitIdent(JCIdent tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   781
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   782
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   783
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   784
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   785
        public void visitLiteral(JCLiteral tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   786
            printString("value", Pretty.toSimpleString(tree, 32));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   787
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   788
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   789
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   790
        public void visitTypeIdent(JCPrimitiveTypeTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   791
            printString("typetag", tree.typetag.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   792
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   793
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   794
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   795
        public void visitTypeArray(JCArrayTypeTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   796
            printTree("elemtype", tree.elemtype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   797
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   798
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   799
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   800
        public void visitTypeApply(JCTypeApply tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   801
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   802
            printList("arguments", tree.arguments);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   803
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   804
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   805
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   806
        public void visitTypeUnion(JCTypeUnion tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   807
            printList("alternatives", tree.alternatives);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   808
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   809
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   810
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   811
        public void visitTypeIntersection(JCTypeIntersection tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   812
            printList("bounds", tree.bounds);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   813
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   814
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   815
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   816
        public void visitTypeParameter(JCTypeParameter tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   817
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   818
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   819
            printList("bounds", tree.bounds);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   820
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   821
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   822
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   823
        public void visitWildcard(JCWildcard tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   824
            printTree("kind", tree.kind);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   825
            printTree("inner", tree.inner);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   826
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   827
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   828
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   829
        public void visitTypeBoundKind(TypeBoundKind tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   830
            printString("kind", tree.kind.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   831
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   832
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   833
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   834
        public void visitModifiers(JCModifiers tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   835
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   836
            printString("flags", String.valueOf(Flags.asFlagSet(tree.flags)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   837
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   838
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   839
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   840
        public void visitAnnotation(JCAnnotation tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   841
            printTree("annotationType", tree.annotationType);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   842
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   843
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   844
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   845
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   846
        public void visitAnnotatedType(JCAnnotatedType tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   847
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   848
            printTree("underlyingType", tree.underlyingType);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   849
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   850
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   851
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   852
        public void visitErroneous(JCErroneous tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   853
            printList("errs", tree.errs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   854
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   855
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   856
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   857
        public void visitLetExpr(LetExpr tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   858
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   859
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   860
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   861
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   862
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   863
        public void visitTree(JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   864
            Assert.error();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   865
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   866
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   867
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   868
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   869
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   870
    // <editor-fold defaultstate="collapsed" desc="Symbol visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   871
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   872
    protected Symbol.Visitor<Void,Void> symVisitor = new SymbolVisitor();
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   873
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   874
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   875
     * Default visitor class for Symbol objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   876
     * Note: each visitXYZ method ends by calling the corresponding
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   877
     * visit method for its superclass.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   878
     */
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   879
    class SymbolVisitor implements Symbol.Visitor<Void,Void> {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   880
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   881
        public Void visitClassSymbol(ClassSymbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   882
            printName("fullname", sym.fullname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   883
            printName("flatname", sym.flatname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   884
            printScope("members", sym.members_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   885
            printFileObject("sourcefile", sym.sourcefile);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   886
            printFileObject("classfile", sym.classfile);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   887
            // trans-local?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   888
            // pool?
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   889
            return visitTypeSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   890
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   891
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   892
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   893
        public Void visitMethodSymbol(MethodSymbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   894
            // code
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   895
            printList("params", sym.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   896
            printList("savedParameterNames", sym.savedParameterNames);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   897
            return visitSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   898
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   899
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   900
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   901
        public Void visitPackageSymbol(PackageSymbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   902
            printName("fullname", sym.fullname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   903
            printScope("members", sym.members_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   904
            printSymbol("package-info", sym.package_info, Details.SUMMARY);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   905
            return visitTypeSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   906
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   907
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   908
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   909
        public Void visitOperatorSymbol(OperatorSymbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   910
            printInt("opcode", sym.opcode);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   911
            return visitMethodSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   912
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   913
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   914
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   915
        public Void visitVarSymbol(VarSymbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   916
            printInt("pos", sym.pos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   917
            printInt("adm", sym.adr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   918
            // data is a private field, and the standard accessors may
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   919
            // mutate it as part of lazy evaluation. Therefore, use
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   920
            // reflection to get the raw data.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   921
            printObject("data", getField(sym, VarSymbol.class, "data"), Details.SUMMARY);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   922
            return visitSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   923
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   924
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   925
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   926
        public Void visitTypeSymbol(TypeSymbol sym, Void ignore) {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   927
            return visitSymbol(sym, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   928
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   929
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   930
        @Override
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   931
        public Void visitSymbol(Symbol sym, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   932
            return null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   933
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   934
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   935
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   936
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   937
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   938
    // <editor-fold defaultstate="collapsed" desc="Type visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   939
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   940
    protected Type.Visitor<Void,Void> typeVisitor = new TypeVisitor();
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   941
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   942
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   943
     * Default visitor class for Type objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   944
     * Note: each visitXYZ method ends by calling the corresponding
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   945
     * visit method for its superclass.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   946
     */
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   947
    public class TypeVisitor implements Type.Visitor<Void,Void> {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   948
        public Void visitAnnotatedType(AnnotatedType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   949
            printList("typeAnnotations", type.typeAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   950
            printType("underlyingType", type.underlyingType, Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   951
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   952
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   953
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   954
        public Void visitArrayType(ArrayType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   955
            printType("elemType", type.elemtype, Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   956
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   957
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   958
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   959
        public Void visitCapturedType(CapturedType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   960
            printType("wildcard", type.wildcard, Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   961
            return visitTypeVar(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   962
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   963
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   964
        public Void visitClassType(ClassType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   965
            printType("outer", type.getEnclosingType(), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   966
            printList("typarams", type.typarams_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   967
            printList("allparams", type.allparams_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   968
            printType("supertype", type.supertype_field, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   969
            printList("interfaces", type.interfaces_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   970
            printList("allinterfaces", type.all_interfaces_field);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   971
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   972
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   973
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   974
        public Void visitErrorType(ErrorType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   975
            printType("originalType", type.getOriginalType(), Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   976
            return visitClassType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   977
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   978
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   979
        public Void visitForAll(ForAll type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   980
            printList("tvars", type.tvars);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   981
            return visitDelegatedType(type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   982
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   983
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   984
        public Void visitMethodType(MethodType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   985
            printList("argtypes", type.argtypes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   986
            printType("restype", type.restype, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   987
            printList("thrown", type.thrown);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   988
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   989
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   990
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   991
        public Void visitPackageType(PackageType type, Void ignore) {
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   992
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   993
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   994
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
   995
        public Void visitTypeVar(TypeVar type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   996
            // For TypeVars (and not subtypes), the bound should always be
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   997
            // null or bot. So, only print the bound for subtypes of TypeVar,
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   998
            // or if the bound is (erroneously) not null or bot.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   999
            if (!type.hasTag(TypeTag.TYPEVAR)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1000
                    || !(type.bound == null || type.bound.hasTag(TypeTag.BOT))) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1001
                printType("bound", type.bound, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1002
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1003
            printType("lower", type.lower, Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1004
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1005
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1006
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1007
        public Void visitUndetVar(UndetVar type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1008
            for (UndetVar.InferenceBound ib: UndetVar.InferenceBound.values())
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1009
                printList("bounds." + ib, type.getBounds(ib));
15705
c4124695db0c 8007463: Cleanup inference related classes
mcimadamore
parents: 15561
diff changeset
  1010
            printInt("declaredCount", type.declaredCount);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1011
            printType("inst", type.inst, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1012
            return visitDelegatedType(type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1013
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1014
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1015
        public Void visitWildcardType(WildcardType type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1016
            printType("type", type.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1017
            printString("kind", type.kind.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1018
            printType("bound", type.bound, Details.SUMMARY);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1019
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1020
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1021
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1022
        protected Void visitDelegatedType(DelegatedType type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1023
            printType("qtype", type.qtype, Details.FULL);
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1024
            return visitType(type, null);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1025
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1026
15560
d0509841a622 8007306: DPrinter: improve display of impl-class, internal tag/kind, and external tag/kind
jjg
parents: 15553
diff changeset
  1027
        public Void visitType(Type type, Void ignore) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1028
            return null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1029
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1030
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1031
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1032
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1033
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1034
    // <editor-fold defaultstate="collapsed" desc="Attribute (annotations) visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1035
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1036
    protected Attribute.Visitor attrVisitor = new AttributeVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1037
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1038
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1039
     * Default visitor class for Attribute (annotation) objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1040
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1041
    public class AttributeVisitor implements Attribute.Visitor {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1042
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1043
        public void visitConstant(Attribute.Constant a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1044
            printObject("value", a.value, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1045
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1046
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1047
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1048
        public void visitClass(Attribute.Class a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1049
            printObject("classType", a.classType, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1050
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1051
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1052
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1053
        public void visitCompound(Attribute.Compound a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1054
            if (a instanceof Attribute.TypeCompound) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1055
                Attribute.TypeCompound ta = (Attribute.TypeCompound) a;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1056
                // consider a custom printer?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1057
                printObject("position", ta.position, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1058
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1059
            printObject("synthesized", a.isSynthesized(), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1060
            printList("values", a.values);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1061
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1062
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1063
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1064
        public void visitArray(Attribute.Array a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1065
            printList("values", Arrays.asList(a.values));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1066
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1067
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1068
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1069
        public void visitEnum(Attribute.Enum a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1070
            printSymbol("value", a.value, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1071
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1072
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1073
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1074
        public void visitError(Attribute.Error a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1075
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1076
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1077
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1078
        public void visitAttribute(Attribute a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1079
            printType("type", a.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1080
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1081
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1082
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1083
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1084
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1085
    // <editor-fold defaultstate="collapsed" desc="Utility front end">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1086
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1087
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1088
     * Utility class to invoke DPrinter from the command line.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1089
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1090
    static class Main {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1091
        public static void main(String... args) throws IOException {
15561
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1092
            Main m = new Main();
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1093
            PrintWriter out = new PrintWriter(System.out);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1094
            try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1095
                if (args.length == 0)
15561
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1096
                    m.usage(out);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1097
                else
15561
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1098
                    m.run(out, args);
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1099
            } finally {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1100
                out.flush();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1101
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1102
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1103
15561
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1104
        void usage(PrintWriter out) {
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1105
            out.println("Usage:");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1106
            out.println("  java " + Main.class.getName() + " mode [options] [javac-options]");
15561
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1107
            out.print("where mode is one of: ");
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1108
            String sep = "";
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1109
            for (Handler h: getHandlers().values()) {
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1110
                out.print(sep);
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1111
                out.print(h.name);
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1112
                sep = ", ";
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1113
            }
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1114
            out.println();
ef818953c598 8007305: DPrinter: provide better usage message
jjg
parents: 15560
diff changeset
  1115
            out.println("and where options include:");
15553
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1116
            out.println("  -before PARSE|ENTER|ANALYZE|GENERATE|ANNOTATION_PROCESSING|ANNOTATION_PROCESSING_ROUND");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1117
            out.println("  -after PARSE|ENTER|ANALYZE|GENERATE|ANNOTATION_PROCESSING|ANNOTATION_PROCESSING_ROUND");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1118
            out.println("  -showPositions");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1119
            out.println("  -showSource");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1120
            out.println("  -showTreeSymbols");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1121
            out.println("  -showTreeTypes");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1122
            out.println("  -hideEmptyItems");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1123
            out.println("  -hideNulls");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1124
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1125
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1126
        void run(PrintWriter out, String... args) throws IOException {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1127
            JavaCompiler c = ToolProvider.getSystemJavaCompiler();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1128
            StandardJavaFileManager fm = c.getStandardFileManager(null, null, null);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1129
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1130
            // DPrinter options
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1131
            final Set<TaskEvent.Kind> before = EnumSet.noneOf(TaskEvent.Kind.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1132
            final Set<TaskEvent.Kind> after = EnumSet.noneOf(TaskEvent.Kind.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1133
            boolean showPositions = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1134
            boolean showSource = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1135
            boolean showTreeSymbols = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1136
            boolean showTreeTypes = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1137
            boolean showEmptyItems = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1138
            boolean showNulls = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1139
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1140
            // javac options
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1141
            Collection<String> options = new ArrayList<String>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1142
            Collection<File> files = new ArrayList<File>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1143
            String classpath = null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1144
            String classoutdir = null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1145
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1146
            final Handler h = getHandlers().get(args[0]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1147
            if (h == null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1148
                throw new IllegalArgumentException(args[0]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1149
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1150
            for (int i = 1; i < args.length; i++) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1151
                String arg = args[i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1152
                if (arg.equals("-before") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1153
                    before.add(getKind(args[++i]));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1154
                } else if (arg.equals("-after") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1155
                    after.add(getKind(args[++i]));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1156
                } else if (arg.equals("-showPositions")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1157
                    showPositions = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1158
                } else if (arg.equals("-showSource")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1159
                    showSource = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1160
                } else if (arg.equals("-showTreeSymbols")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1161
                    showTreeSymbols = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1162
                } else if (arg.equals("-showTreeTypes")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1163
                    showTreeTypes = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1164
                } else if (arg.equals("-hideEmptyLists")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1165
                    showEmptyItems = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1166
                } else if (arg.equals("-hideNulls")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1167
                    showNulls = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1168
                } else if (arg.equals("-classpath") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1169
                    classpath = args[++i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1170
                } else if (arg.equals("-d") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1171
                    classoutdir = args[++i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1172
                } else if (arg.startsWith("-")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1173
                    int n = c.isSupportedOption(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1174
                    if (n < 0) throw new IllegalArgumentException(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1175
                    options.add(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1176
                    while (n > 0) options.add(args[++i]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1177
                } else if (arg.endsWith(".java")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1178
                    files.add(new File(arg));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1179
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1180
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1181
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1182
            if (classoutdir != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1183
                fm.setLocation(StandardLocation.CLASS_OUTPUT, Arrays.asList(new File(classoutdir)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1184
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1185
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1186
            if (classpath != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1187
                Collection<File> path = new ArrayList<File>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1188
                for (String p: classpath.split(File.pathSeparator)) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1189
                    if (p.isEmpty()) continue;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1190
                    File f = new File(p);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1191
                    if (f.exists()) path.add(f);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1192
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1193
                fm.setLocation(StandardLocation.CLASS_PATH, path);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1194
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1195
            Iterable<? extends JavaFileObject> fos = fm.getJavaFileObjectsFromFiles(files);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1196
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1197
            JavacTask task = (JavacTask) c.getTask(out, fm, null, options, null, fos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1198
            final Trees trees = Trees.instance(task);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1199
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1200
            final DPrinter dprinter = new DPrinter(out, trees);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1201
            dprinter.source(showSource)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1202
                    .emptyItems(showEmptyItems)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1203
                    .nulls(showNulls)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1204
                    .positions(showPositions)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1205
                    .treeSymbols(showTreeSymbols)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1206
                    .treeTypes(showTreeTypes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1207
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1208
            if (before.isEmpty() && after.isEmpty()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1209
                if (h.name.equals("trees") && !showTreeSymbols && !showTreeTypes)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1210
                    after.add(TaskEvent.Kind.PARSE);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1211
                else
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1212
                    after.add(TaskEvent.Kind.ANALYZE);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1213
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1214
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1215
            task.addTaskListener(new TaskListener() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1216
                public void started(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1217
                    if (before.contains(e.getKind()))
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1218
                        handle(e);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1219
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1220
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1221
                public void finished(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1222
                    if (after.contains(e.getKind()))
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1223
                        handle(e);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1224
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1225
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1226
                private void handle(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1227
                     switch (e.getKind()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1228
                         case PARSE:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1229
                         case ENTER:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1230
                             h.handle(e.getSourceFile().getName(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1231
                                     (JCTree) e.getCompilationUnit(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1232
                                     dprinter);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1233
                             break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1234
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1235
                         default:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1236
                             TypeElement elem = e.getTypeElement();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1237
                             h.handle(elem.toString(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1238
                                     (JCTree) trees.getTree(elem),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1239
                                     dprinter);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1240
                             break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1241
                     }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1242
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1243
            });
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1244
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1245
            task.call();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1246
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1247
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1248
        TaskEvent.Kind getKind(String s) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1249
            return TaskEvent.Kind.valueOf(s.toUpperCase());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1250
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1251
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1252
        static protected abstract class Handler {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1253
            final String name;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1254
            Handler(String name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1255
                this.name = name;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1256
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1257
            abstract void handle(String label, JCTree tree, DPrinter dprinter);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1258
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1259
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1260
        Map<String,Handler> getHandlers() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1261
            Map<String,Handler> map = new HashMap<String, Handler>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1262
            for (Handler h: defaultHandlers) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1263
                map.put(h.name, h);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1264
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1265
            return map;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1266
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1267
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1268
        protected final Handler[] defaultHandlers = {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1269
            new Handler("trees") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1270
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1271
                void handle(String name, JCTree tree, DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1272
                    dprinter.printTree(name, tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1273
                    dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1274
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1275
            },
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1276
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1277
            new Handler("symbols") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1278
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1279
                void handle(String name, JCTree tree, final DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1280
                    TreeScanner ds = new TreeScanner() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1281
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1282
                        public void visitClassDef(JCClassDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1283
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1284
                            super.visitClassDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1285
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1286
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1287
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1288
                        public void visitMethodDef(JCMethodDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1289
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1290
                            super.visitMethodDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1291
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1292
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1293
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1294
                        public void visitVarDef(JCVariableDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1295
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1296
                            super.visitVarDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1297
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1298
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1299
                        void visitDecl(JCTree tree, Symbol sym) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1300
                            dprinter.printSymbol(sym.name.toString(), sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1301
                            dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1302
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1303
                    };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1304
                    ds.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1305
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1306
            },
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1307
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1308
            new Handler("types") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1309
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1310
                void handle(String name, JCTree tree, final DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1311
                    TreeScanner ts = new TreeScanner() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1312
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1313
                        public void scan(JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1314
                            if (tree == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1315
                                return;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1316
                            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1317
                            if (tree.type != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1318
                                String label = Pretty.toSimpleString(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1319
                                dprinter.printType(label, tree.type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1320
                                dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1321
                            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1322
                            super.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1323
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1324
                    };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1325
                    ts.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1326
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1327
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1328
        };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1329
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1330
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1331
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1332
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1333
}