langtools/test/tools/javac/lib/DPrinter.java
author jjg
Wed, 30 Jan 2013 09:47:12 -0800
changeset 15553 1636d13162e0
child 15560 d0509841a622
permissions -rw-r--r--
8007034: debug printer for javac internals Reviewed-by: mcimadamore
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
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   213
            printString(label, "");
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);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   386
                out.println(": " + String.format("0x%x", sym.kind)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   387
                        + "--" + Kinds.kindName(sym).name()
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   388
                        + " " + sym.getKind()
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   389
                        + " " + sym.name
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   390
                        + " " + String.format("#%x", sym.hashCode()));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   391
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   392
                indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   393
                if (showSrc) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   394
                    JCTree tree = (JCTree) trees.getTree(sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   395
                    if (tree != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   396
                        printSource("src", tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   397
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   398
                printString("flags", String.format("0x%x--%s",
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   399
                        sym.flags_field, Flags.toString(sym.flags_field)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   400
                printObject("completer", sym.completer, Details.SUMMARY); // what if too long?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   401
                printSymbol("owner", sym.owner, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   402
                printType("type", sym.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   403
                printType("erasure", sym.erasure_field, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   404
                sym.accept(symVisitor, true);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   405
                printAnnotations("annotations", sym.annotations, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   406
                indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   407
            }
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
    protected String toString(Symbol sym) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   412
        return (printer != null) ? printer.visit(sym, locale) : String.valueOf(sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   413
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   414
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   415
    protected void printTree(String label, JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   416
        if (tree == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   417
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   418
        } else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   419
            indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   420
            out.print(label + ": " + tree.getTag());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   421
            if (showPositions) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   422
                // We can always get start position, but to get end position
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   423
                // and/or line+offset, we would need a JCCompilationUnit
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   424
                out.print(" pos:" + tree.pos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   425
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   426
            if (showTreeTypes && tree.type != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   427
                out.print(" type:" + toString(tree.type));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   428
            Symbol sym;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   429
            if (showTreeSymbols && (sym = TreeInfo.symbolFor(tree)) != null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   430
                out.print(" sym:" + toString(sym));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   431
            out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   432
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   433
            indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   434
            if (showSrc) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   435
                indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   436
                out.println("src: " + Pretty.toSimpleString(tree, maxSrcLength));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   437
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   438
            tree.accept(treeVisitor);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   439
            indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   440
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   441
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   442
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   443
    public void printType(String label, Type type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   444
        printType(label, type, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   445
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   446
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   447
    protected void printType(String label, Type type, Details details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   448
        if (type == null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   449
            printNull(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   450
        else {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   451
            switch (details) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   452
                case SUMMARY:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   453
                    printString(label, toString(type));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   454
                    break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   455
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   456
                case FULL:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   457
                    indent();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   458
                    out.print(label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   459
                    out.println(": " + type.getTag()
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   460
                            + " " + String.format("#%x", type.hashCode()));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   461
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   462
                    indent(+1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   463
                    printSymbol("tsym", type.tsym, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   464
                    printObject("constValue", type.constValue(), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   465
                    type.accept(typeVisitor, true);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   466
                    indent(-1);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   467
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   468
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   469
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   470
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   471
    protected String toString(Type type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   472
        return (printer != null) ? printer.visit(type, locale) : String.valueOf(type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   473
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   474
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   475
    private int indent = 0;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   476
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   477
    protected void indent() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   478
        for (int i = 0; i < indent; i++) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   479
            out.print("  ");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   480
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   481
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   482
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   483
    protected void indent(int n) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   484
        indent += n;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   485
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   486
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   487
    protected Object getField(Object o, Class<?> clazz, String name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   488
        try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   489
            Field f = clazz.getDeclaredField(name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   490
            boolean prev = f.isAccessible();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   491
            f.setAccessible(true);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   492
            try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   493
                return f.get(o);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   494
            } finally {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   495
                f.setAccessible(prev);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   496
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   497
        } catch (ReflectiveOperationException e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   498
            return e;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   499
        } catch (SecurityException e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   500
            return e;
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
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   504
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   505
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   506
    // <editor-fold defaultstate="collapsed" desc="JCTree visitor methods">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   507
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   508
    protected JCTree.Visitor treeVisitor = new TreeVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   509
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   510
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   511
     * Default visitor class for JCTree (AST) objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   512
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   513
    public class TreeVisitor extends JCTree.Visitor {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   514
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   515
        public void visitTopLevel(JCCompilationUnit tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   516
            printList("packageAnnotations", tree.packageAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   517
            printTree("pid", tree.pid);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   518
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   519
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   520
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   521
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   522
        public void visitImport(JCImport tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   523
            printTree("qualid", tree.qualid);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   524
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   525
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   526
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   527
        public void visitClassDef(JCClassDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   528
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   529
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   530
            printList("typarams", tree.typarams);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   531
            printTree("extending", tree.extending);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   532
            printList("implementing", tree.implementing);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   533
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   534
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   535
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   536
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   537
        public void visitMethodDef(JCMethodDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   538
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   539
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   540
            printTree("restype", tree.restype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   541
            printList("typarams", tree.typarams);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   542
            printTree("recvparam", tree.recvparam);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   543
            printList("params", tree.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   544
            printList("thrown", tree.thrown);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   545
            printTree("defaultValue", tree.defaultValue);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   546
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   547
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   548
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   549
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   550
        public void visitVarDef(JCVariableDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   551
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   552
            printTree("mods", tree.mods);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   553
            printTree("vartype", tree.vartype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   554
            printTree("init", tree.init);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   555
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   556
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   557
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   558
        public void visitSkip(JCSkip tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   559
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   560
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   561
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   562
        public void visitBlock(JCBlock tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   563
            printList("stats", tree.stats);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   564
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   565
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   566
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   567
        public void visitDoLoop(JCDoWhileLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   568
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   569
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   570
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   571
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   572
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   573
        public void visitWhileLoop(JCWhileLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   574
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   575
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   576
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   577
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   578
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   579
        public void visitForLoop(JCForLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   580
            printList("init", tree.init);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   581
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   582
            printList("step", tree.step);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   583
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   584
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   585
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   586
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   587
        public void visitForeachLoop(JCEnhancedForLoop tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   588
            printTree("var", tree.var);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   589
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   590
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   591
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   592
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   593
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   594
        public void visitLabelled(JCLabeledStatement tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   595
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   596
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   597
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   598
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   599
        public void visitSwitch(JCSwitch tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   600
            printTree("selector", tree.selector);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   601
            printList("cases", tree.cases);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   602
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   603
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   604
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   605
        public void visitCase(JCCase tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   606
            printTree("pat", tree.pat);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   607
            printList("stats", tree.stats);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   608
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   609
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   610
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   611
        public void visitSynchronized(JCSynchronized tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   612
            printTree("lock", tree.lock);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   613
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   614
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   615
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   616
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   617
        public void visitTry(JCTry tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   618
            printList("resources", tree.resources);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   619
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   620
            printList("catchers", tree.catchers);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   621
            printTree("finalizer", tree.finalizer);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   622
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   623
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   624
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   625
        public void visitCatch(JCCatch tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   626
            printTree("param", tree.param);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   627
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   628
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   629
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   630
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   631
        public void visitConditional(JCConditional tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   632
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   633
            printTree("truepart", tree.truepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   634
            printTree("falsepart", tree.falsepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   635
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   636
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   637
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   638
        public void visitIf(JCIf tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   639
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   640
            printTree("thenpart", tree.thenpart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   641
            printTree("elsepart", tree.elsepart);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   642
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   643
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   644
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   645
        public void visitExec(JCExpressionStatement tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   646
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   647
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   648
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   649
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   650
        public void visitBreak(JCBreak tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   651
            printName("label", tree.label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   652
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   653
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   654
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   655
        public void visitContinue(JCContinue tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   656
            printName("label", tree.label);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   657
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   658
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   659
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   660
        public void visitReturn(JCReturn tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   661
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   662
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   663
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   664
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   665
        public void visitThrow(JCThrow tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   666
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   667
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   668
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   669
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   670
        public void visitAssert(JCAssert tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   671
            printTree("cond", tree.cond);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   672
            printTree("detail", tree.detail);
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 visitApply(JCMethodInvocation tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   677
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   678
            printTree("meth", tree.meth);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   679
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   680
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   681
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   682
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   683
        public void visitNewClass(JCNewClass tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   684
            printTree("encl", tree.encl);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   685
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   686
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   687
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   688
            printTree("def", tree.def);
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 visitNewArray(JCNewArray tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   693
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   694
            printTree("elemtype", tree.elemtype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   695
            printList("dims", tree.dims);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   696
            printList("dimAnnotations", tree.dimAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   697
            printList("elems", tree.elems);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   698
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   699
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   700
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   701
        public void visitLambda(JCLambda tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   702
            printTree("body", tree.body);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   703
            printList("params", tree.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   704
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   705
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   706
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   707
        public void visitParens(JCParens tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   708
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   709
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   710
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   711
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   712
        public void visitAssign(JCAssign tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   713
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   714
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   715
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   716
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   717
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   718
        public void visitAssignop(JCAssignOp tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   719
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   720
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   721
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   722
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   723
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   724
        public void visitUnary(JCUnary tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   725
            printTree("arg", tree.arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   726
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   727
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   728
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   729
        public void visitBinary(JCBinary tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   730
            printTree("lhs", tree.lhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   731
            printTree("rhs", tree.rhs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   732
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   733
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   734
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   735
        public void visitTypeCast(JCTypeCast tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   736
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   737
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   738
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   739
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   740
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   741
        public void visitTypeTest(JCInstanceOf tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   742
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   743
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   744
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   745
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   746
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   747
        public void visitIndexed(JCArrayAccess tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   748
            printTree("indexed", tree.indexed);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   749
            printTree("index", tree.index);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   750
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   751
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   752
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   753
        public void visitSelect(JCFieldAccess tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   754
            printTree("selected", tree.selected);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   755
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   756
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   757
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   758
        public void visitReference(JCMemberReference tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   759
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   760
            printList("typeargs", tree.typeargs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   761
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   762
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   763
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   764
        public void visitIdent(JCIdent tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   765
            printName("name", tree.name);
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 visitLiteral(JCLiteral tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   770
            printString("value", Pretty.toSimpleString(tree, 32));
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 visitTypeIdent(JCPrimitiveTypeTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   775
            printString("typetag", tree.typetag.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   776
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   777
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   778
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   779
        public void visitTypeArray(JCArrayTypeTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   780
            printTree("elemtype", tree.elemtype);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   781
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   782
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   783
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   784
        public void visitTypeApply(JCTypeApply tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   785
            printTree("clazz", tree.clazz);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   786
            printList("arguments", tree.arguments);
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 visitTypeUnion(JCTypeUnion tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   791
            printList("alternatives", tree.alternatives);
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 visitTypeIntersection(JCTypeIntersection tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   796
            printList("bounds", tree.bounds);
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 visitTypeParameter(JCTypeParameter tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   801
            printName("name", tree.name);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   802
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   803
            printList("bounds", tree.bounds);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   804
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   805
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   806
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   807
        public void visitWildcard(JCWildcard tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   808
            printTree("kind", tree.kind);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   809
            printTree("inner", tree.inner);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   810
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   811
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   812
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   813
        public void visitTypeBoundKind(TypeBoundKind tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   814
            printString("kind", tree.kind.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   815
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   816
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   817
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   818
        public void visitModifiers(JCModifiers tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   819
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   820
            printString("flags", String.valueOf(Flags.asFlagSet(tree.flags)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   821
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   822
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   823
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   824
        public void visitAnnotation(JCAnnotation tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   825
            printTree("annotationType", tree.annotationType);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   826
            printList("args", tree.args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   827
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   828
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   829
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   830
        public void visitAnnotatedType(JCAnnotatedType tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   831
            printList("annotations", tree.annotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   832
            printTree("underlyingType", tree.underlyingType);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   833
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   834
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   835
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   836
        public void visitErroneous(JCErroneous tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   837
            printList("errs", tree.errs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   838
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   839
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   840
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   841
        public void visitLetExpr(LetExpr tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   842
            printList("defs", tree.defs);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   843
            printTree("expr", tree.expr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   844
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   845
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   846
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   847
        public void visitTree(JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   848
            Assert.error();
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
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   852
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   853
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   854
    // <editor-fold defaultstate="collapsed" desc="Symbol visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   855
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   856
    protected Symbol.Visitor<Void,Boolean> symVisitor = new SymbolVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   857
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   858
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   859
     * Default visitor class for Symbol objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   860
     * Note: each visitXYZ method ends by calling the corresponding
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   861
     * visit method for its superclass.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   862
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   863
    class SymbolVisitor implements Symbol.Visitor<Void,Boolean> {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   864
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   865
        public Void visitClassSymbol(ClassSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   866
            if (impl) printImplClass(sym, ClassSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   867
            printName("fullname", sym.fullname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   868
            printName("flatname", sym.flatname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   869
            printScope("members", sym.members_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   870
            printFileObject("sourcefile", sym.sourcefile);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   871
            printFileObject("classfile", sym.classfile);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   872
            // trans-local?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   873
            // pool?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   874
            return visitTypeSymbol(sym, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   875
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   876
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   877
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   878
        public Void visitMethodSymbol(MethodSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   879
            if (impl) printImplClass(sym, MethodSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   880
            // code
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   881
            printList("params", sym.params);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   882
            printList("savedParameterNames", sym.savedParameterNames);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   883
            return visitSymbol(sym, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   884
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   885
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   886
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   887
        public Void visitPackageSymbol(PackageSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   888
            if (impl) printImplClass(sym, PackageSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   889
            printName("fullname", sym.fullname);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   890
            printScope("members", sym.members_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   891
            printSymbol("package-info", sym.package_info, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   892
            return visitTypeSymbol(sym, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   893
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   894
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   895
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   896
        public Void visitOperatorSymbol(OperatorSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   897
            if (impl) printImplClass(sym, OperatorSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   898
            printInt("opcode", sym.opcode);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   899
            return visitMethodSymbol(sym, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   900
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   901
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   902
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   903
        public Void visitVarSymbol(VarSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   904
            if (impl) printImplClass(sym, VarSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   905
            printInt("pos", sym.pos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   906
            printInt("adm", sym.adr);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   907
            // data is a private field, and the standard accessors may
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   908
            // mutate it as part of lazy evaluation. Therefore, use
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   909
            // reflection to get the raw data.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   910
            printObject("data", getField(sym, VarSymbol.class, "data"), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   911
            return visitSymbol(sym, false);
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
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   915
        public Void visitTypeSymbol(TypeSymbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   916
            if (impl) printImplClass(sym, TypeSymbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   917
            return visitSymbol(sym, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   918
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   919
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   920
        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   921
        public Void visitSymbol(Symbol sym, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   922
            if (impl) printImplClass(sym, Symbol.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   923
            return null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   924
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   925
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   926
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   927
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   928
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   929
    // <editor-fold defaultstate="collapsed" desc="Type visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   930
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   931
    protected Type.Visitor<Void,Boolean> typeVisitor = new TypeVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   932
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   933
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   934
     * Default visitor class for Type objects.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   935
     * Note: each visitXYZ method ends by calling the corresponding
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   936
     * visit method for its superclass.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   937
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   938
    public class TypeVisitor implements Type.Visitor<Void,Boolean> {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   939
        public Void visitAnnotatedType(AnnotatedType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   940
            if (impl) printImplClass(type, AnnotatedType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   941
            printList("typeAnnotations", type.typeAnnotations);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   942
            printType("underlyingType", type.underlyingType, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   943
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   944
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   945
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   946
        public Void visitArrayType(ArrayType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   947
            if (impl) printImplClass(type, ArrayType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   948
            printType("elemType", type.elemtype, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   949
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   950
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   951
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   952
        public Void visitCapturedType(CapturedType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   953
            if (impl) printImplClass(type, CapturedType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   954
            printType("wildcard", type.wildcard, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   955
            return visitTypeVar(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   956
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   957
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   958
        public Void visitClassType(ClassType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   959
            if (impl) printImplClass(type, ClassType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   960
            printType("outer", type.getEnclosingType(), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   961
            printList("typarams", type.typarams_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   962
            printList("allparams", type.allparams_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   963
            printType("supertype", type.supertype_field, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   964
            printList("interfaces", type.interfaces_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   965
            printList("allinterfaces", type.all_interfaces_field);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   966
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   967
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   968
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   969
        public Void visitErrorType(ErrorType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   970
            if (impl) printImplClass(type, ErrorType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   971
            printType("originalType", type.getOriginalType(), Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   972
            return visitClassType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   973
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   974
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   975
        public Void visitForAll(ForAll type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   976
            if (impl) printImplClass(type, ForAll.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   977
            printList("tvars", type.tvars);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   978
            return visitDelegatedType(type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   979
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   980
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   981
        public Void visitMethodType(MethodType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   982
            if (impl) printImplClass(type, MethodType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   983
            printList("argtypes", type.argtypes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   984
            printType("restype", type.restype, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   985
            printList("thrown", type.thrown);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   986
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   987
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   988
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   989
        public Void visitPackageType(PackageType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   990
            if (impl) printImplClass(type, PackageType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   991
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   992
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   993
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   994
        public Void visitTypeVar(TypeVar type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
   995
            if (impl) printImplClass(type, TypeVar.class);
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);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1004
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1005
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1006
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1007
        public Void visitUndetVar(UndetVar type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1008
            if (impl) printImplClass(type, UndetVar.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1009
            for (UndetVar.InferenceBound ib: UndetVar.InferenceBound.values())
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1010
                printList("bounds." + ib, type.getBounds(ib));
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
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1015
        public Void visitWildcardType(WildcardType type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1016
            if (impl) printImplClass(type, WildcardType.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1017
            printType("type", type.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1018
            printString("kind", type.kind.name());
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1019
            printType("bound", type.bound, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1020
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1021
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1022
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1023
        protected Void visitDelegatedType(DelegatedType type) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1024
            printType("qtype", type.qtype, Details.FULL);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1025
            return visitType(type, false);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1026
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1027
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1028
        public Void visitType(Type type, Boolean impl) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1029
            if (impl) printImplClass(type, Type.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1030
            return null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1031
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1032
    }
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>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1035
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1036
    // <editor-fold defaultstate="collapsed" desc="Attribute (annotations) visitor">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1037
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1038
    protected Attribute.Visitor attrVisitor = new AttributeVisitor();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1039
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1040
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1041
     * Default visitor class for Attribute (annotation) objects.
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 class AttributeVisitor implements Attribute.Visitor {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1044
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1045
        public void visitConstant(Attribute.Constant a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1046
            printObject("value", a.value, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1047
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1048
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1049
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1050
        public void visitClass(Attribute.Class a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1051
            printObject("classType", a.classType, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1052
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1053
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1054
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1055
        public void visitCompound(Attribute.Compound a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1056
            if (a instanceof Attribute.TypeCompound) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1057
                Attribute.TypeCompound ta = (Attribute.TypeCompound) a;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1058
                // consider a custom printer?
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1059
                printObject("position", ta.position, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1060
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1061
            printObject("synthesized", a.isSynthesized(), Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1062
            printList("values", a.values);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1063
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1064
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1065
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1066
        public void visitArray(Attribute.Array a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1067
            printList("values", Arrays.asList(a.values));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1068
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1069
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1070
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1071
        public void visitEnum(Attribute.Enum a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1072
            printSymbol("value", a.value, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1073
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1074
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1075
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1076
        public void visitError(Attribute.Error a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1077
            visitAttribute(a);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1078
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1079
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1080
        public void visitAttribute(Attribute a) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1081
            printType("type", a.type, Details.SUMMARY);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1082
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1083
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>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1086
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1087
    // <editor-fold defaultstate="collapsed" desc="Utility front end">
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1088
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1089
    /**
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1090
     * Utility class to invoke DPrinter from the command line.
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1091
     */
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1092
    static class Main {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1093
        public static void main(String... args) throws IOException {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1094
            PrintWriter out = new PrintWriter(System.out);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1095
            try {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1096
                if (args.length == 0)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1097
                    usage(out);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1098
                else
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1099
                    new Main().run(out, args);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1100
            } finally {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1101
                out.flush();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1102
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1103
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1104
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1105
        static void usage(PrintWriter out) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1106
            out.println("Usage:");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1107
            out.println("  java " + Main.class.getName() + " mode [options] [javac-options]");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1108
            out.println("where options include:");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1109
            out.println("  -before PARSE|ENTER|ANALYZE|GENERATE|ANNOTATION_PROCESSING|ANNOTATION_PROCESSING_ROUND");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1110
            out.println("  -after PARSE|ENTER|ANALYZE|GENERATE|ANNOTATION_PROCESSING|ANNOTATION_PROCESSING_ROUND");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1111
            out.println("  -showPositions");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1112
            out.println("  -showSource");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1113
            out.println("  -showTreeSymbols");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1114
            out.println("  -showTreeTypes");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1115
            out.println("  -hideEmptyItems");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1116
            out.println("  -hideNulls");
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1117
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1118
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1119
        void run(PrintWriter out, String... args) throws IOException {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1120
            JavaCompiler c = ToolProvider.getSystemJavaCompiler();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1121
            StandardJavaFileManager fm = c.getStandardFileManager(null, null, null);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1122
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1123
            // DPrinter options
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1124
            final Set<TaskEvent.Kind> before = EnumSet.noneOf(TaskEvent.Kind.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1125
            final Set<TaskEvent.Kind> after = EnumSet.noneOf(TaskEvent.Kind.class);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1126
            boolean showPositions = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1127
            boolean showSource = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1128
            boolean showTreeSymbols = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1129
            boolean showTreeTypes = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1130
            boolean showEmptyItems = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1131
            boolean showNulls = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1132
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1133
            // javac options
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1134
            Collection<String> options = new ArrayList<String>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1135
            Collection<File> files = new ArrayList<File>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1136
            String classpath = null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1137
            String classoutdir = null;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1138
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1139
            final Handler h = getHandlers().get(args[0]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1140
            if (h == null)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1141
                throw new IllegalArgumentException(args[0]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1142
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1143
            for (int i = 1; i < args.length; i++) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1144
                String arg = args[i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1145
                if (arg.equals("-before") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1146
                    before.add(getKind(args[++i]));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1147
                } else if (arg.equals("-after") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1148
                    after.add(getKind(args[++i]));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1149
                } else if (arg.equals("-showPositions")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1150
                    showPositions = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1151
                } else if (arg.equals("-showSource")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1152
                    showSource = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1153
                } else if (arg.equals("-showTreeSymbols")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1154
                    showTreeSymbols = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1155
                } else if (arg.equals("-showTreeTypes")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1156
                    showTreeTypes = true;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1157
                } else if (arg.equals("-hideEmptyLists")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1158
                    showEmptyItems = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1159
                } else if (arg.equals("-hideNulls")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1160
                    showNulls = false;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1161
                } else if (arg.equals("-classpath") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1162
                    classpath = args[++i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1163
                } else if (arg.equals("-d") && i + 1 < args.length) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1164
                    classoutdir = args[++i];
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1165
                } else if (arg.startsWith("-")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1166
                    int n = c.isSupportedOption(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1167
                    if (n < 0) throw new IllegalArgumentException(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1168
                    options.add(arg);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1169
                    while (n > 0) options.add(args[++i]);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1170
                } else if (arg.endsWith(".java")) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1171
                    files.add(new File(arg));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1172
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1173
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1174
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1175
            if (classoutdir != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1176
                fm.setLocation(StandardLocation.CLASS_OUTPUT, Arrays.asList(new File(classoutdir)));
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1177
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1178
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1179
            if (classpath != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1180
                Collection<File> path = new ArrayList<File>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1181
                for (String p: classpath.split(File.pathSeparator)) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1182
                    if (p.isEmpty()) continue;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1183
                    File f = new File(p);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1184
                    if (f.exists()) path.add(f);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1185
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1186
                fm.setLocation(StandardLocation.CLASS_PATH, path);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1187
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1188
            Iterable<? extends JavaFileObject> fos = fm.getJavaFileObjectsFromFiles(files);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1189
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1190
            JavacTask task = (JavacTask) c.getTask(out, fm, null, options, null, fos);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1191
            final Trees trees = Trees.instance(task);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1192
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1193
            final DPrinter dprinter = new DPrinter(out, trees);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1194
            dprinter.source(showSource)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1195
                    .emptyItems(showEmptyItems)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1196
                    .nulls(showNulls)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1197
                    .positions(showPositions)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1198
                    .treeSymbols(showTreeSymbols)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1199
                    .treeTypes(showTreeTypes);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1200
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1201
            if (before.isEmpty() && after.isEmpty()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1202
                if (h.name.equals("trees") && !showTreeSymbols && !showTreeTypes)
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1203
                    after.add(TaskEvent.Kind.PARSE);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1204
                else
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1205
                    after.add(TaskEvent.Kind.ANALYZE);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1206
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1207
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1208
            task.addTaskListener(new TaskListener() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1209
                public void started(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1210
                    if (before.contains(e.getKind()))
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1211
                        handle(e);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1212
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1213
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1214
                public void finished(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1215
                    if (after.contains(e.getKind()))
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1216
                        handle(e);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1217
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1218
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1219
                private void handle(TaskEvent e) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1220
                     switch (e.getKind()) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1221
                         case PARSE:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1222
                         case ENTER:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1223
                             h.handle(e.getSourceFile().getName(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1224
                                     (JCTree) e.getCompilationUnit(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1225
                                     dprinter);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1226
                             break;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1227
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1228
                         default:
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1229
                             TypeElement elem = e.getTypeElement();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1230
                             h.handle(elem.toString(),
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1231
                                     (JCTree) trees.getTree(elem),
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
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1236
            });
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1237
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1238
            task.call();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1239
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1240
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1241
        TaskEvent.Kind getKind(String s) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1242
            return TaskEvent.Kind.valueOf(s.toUpperCase());
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
        static protected abstract class Handler {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1246
            final String name;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1247
            Handler(String name) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1248
                this.name = name;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1249
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1250
            abstract void handle(String label, JCTree tree, DPrinter dprinter);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1251
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1252
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1253
        Map<String,Handler> getHandlers() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1254
            Map<String,Handler> map = new HashMap<String, Handler>();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1255
            for (Handler h: defaultHandlers) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1256
                map.put(h.name, h);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1257
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1258
            return map;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1259
        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1260
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1261
        protected final Handler[] defaultHandlers = {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1262
            new Handler("trees") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1263
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1264
                void handle(String name, JCTree tree, DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1265
                    dprinter.printTree(name, tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1266
                    dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1267
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1268
            },
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1269
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1270
            new Handler("symbols") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1271
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1272
                void handle(String name, JCTree tree, final DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1273
                    TreeScanner ds = new TreeScanner() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1274
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1275
                        public void visitClassDef(JCClassDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1276
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1277
                            super.visitClassDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1278
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1279
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1280
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1281
                        public void visitMethodDef(JCMethodDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1282
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1283
                            super.visitMethodDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1284
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1285
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1286
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1287
                        public void visitVarDef(JCVariableDecl tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1288
                            visitDecl(tree, tree.sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1289
                            super.visitVarDef(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1290
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1291
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1292
                        void visitDecl(JCTree tree, Symbol sym) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1293
                            dprinter.printSymbol(sym.name.toString(), sym);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1294
                            dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1295
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1296
                    };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1297
                    ds.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1298
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1299
            },
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1300
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1301
            new Handler("types") {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1302
                @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1303
                void handle(String name, JCTree tree, final DPrinter dprinter) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1304
                    TreeScanner ts = new TreeScanner() {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1305
                        @Override
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1306
                        public void scan(JCTree tree) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1307
                            if (tree == null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1308
                                return;
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1309
                            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1310
                            if (tree.type != null) {
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1311
                                String label = Pretty.toSimpleString(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1312
                                dprinter.printType(label, tree.type);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1313
                                dprinter.out.println();
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1314
                            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1315
                            super.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1316
                        }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1317
                    };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1318
                    ts.scan(tree);
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1319
                }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1320
            }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1321
        };
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1322
    }
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1323
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1324
    // </editor-fold>
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1325
1636d13162e0 8007034: debug printer for javac internals
jjg
parents:
diff changeset
  1326
}