langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Symbol.java
author vromero
Fri, 02 Sep 2016 05:43:54 -0700
changeset 40774 bed459be3a01
parent 40772 de87954b8f20
child 41254 08f8dbf7741e
permissions -rw-r--r--
8160454: JSR269 jigsaw update: javax.lang.model.element.ModuleElement.getDirectives() causes NPE on unnamed modules Reviewed-by: jjg
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
     2
 * Copyright (c) 1999, 2016, Oracle and/or its affiliates. All rights reserved.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
06bc494ca11e Initial load
duke
parents:
diff changeset
     4
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
06bc494ca11e Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5321
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5321
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    10
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
06bc494ca11e Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
06bc494ca11e Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
06bc494ca11e Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
06bc494ca11e Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
06bc494ca11e Initial load
duke
parents:
diff changeset
    16
 *
06bc494ca11e Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
06bc494ca11e Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
06bc494ca11e Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
06bc494ca11e Initial load
duke
parents:
diff changeset
    20
 *
5520
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5321
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5321
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 5321
diff changeset
    23
 * questions.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    24
 */
06bc494ca11e Initial load
duke
parents:
diff changeset
    25
06bc494ca11e Initial load
duke
parents:
diff changeset
    26
package com.sun.tools.javac.code;
06bc494ca11e Initial load
duke
parents:
diff changeset
    27
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
    28
import java.lang.annotation.Annotation;
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
    29
import java.lang.annotation.Inherited;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    30
import java.util.Collections;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    31
import java.util.Map;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    32
import java.util.Set;
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
import java.util.concurrent.Callable;
14258
8d2148961366 8000663: clean up langtools imports
jjg
parents: 14062
diff changeset
    34
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    35
import javax.lang.model.element.Element;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    36
import javax.lang.model.element.ElementKind;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    37
import javax.lang.model.element.ElementVisitor;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    38
import javax.lang.model.element.ExecutableElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    39
import javax.lang.model.element.Modifier;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    40
import javax.lang.model.element.ModuleElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    41
import javax.lang.model.element.NestingKind;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    42
import javax.lang.model.element.PackageElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    43
import javax.lang.model.element.TypeElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    44
import javax.lang.model.element.TypeParameterElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    45
import javax.lang.model.element.VariableElement;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    46
import javax.tools.JavaFileManager;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    47
import javax.tools.JavaFileObject;
06bc494ca11e Initial load
duke
parents:
diff changeset
    48
37001
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
    49
import com.sun.tools.javac.code.ClassFinder.BadEnclosingMethodAttr;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    50
import com.sun.tools.javac.code.Kinds.Kind;
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
    51
import com.sun.tools.javac.comp.Annotate.AnnotationTypeMetadata;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
    52
import com.sun.tools.javac.code.Scope.WriteableScope;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
import com.sun.tools.javac.code.Type.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
import com.sun.tools.javac.comp.Attr;
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
import com.sun.tools.javac.comp.AttrContext;
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
import com.sun.tools.javac.comp.Env;
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
import com.sun.tools.javac.jvm.*;
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    58
import com.sun.tools.javac.tree.JCTree.JCFieldAccess;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
    59
import com.sun.tools.javac.tree.JCTree.JCVariableDecl;
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    60
import com.sun.tools.javac.tree.JCTree.Tag;
14258
8d2148961366 8000663: clean up langtools imports
jjg
parents: 14062
diff changeset
    61
import com.sun.tools.javac.util.*;
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
    62
import com.sun.tools.javac.util.DefinedBy.Api;
14258
8d2148961366 8000663: clean up langtools imports
jjg
parents: 14062
diff changeset
    63
import com.sun.tools.javac.util.Name;
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
    64
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    65
import static com.sun.tools.javac.code.Flags.*;
06bc494ca11e Initial load
duke
parents:
diff changeset
    66
import static com.sun.tools.javac.code.Kinds.*;
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
    67
import static com.sun.tools.javac.code.Kinds.Kind.*;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
    68
import static com.sun.tools.javac.code.Scope.LookupKind.NON_RECURSIVE;
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    69
import static com.sun.tools.javac.code.Symbol.OperatorSymbol.AccessCode.FIRSTASGOP;
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
    70
import static com.sun.tools.javac.code.TypeTag.CLASS;
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
    71
import static com.sun.tools.javac.code.TypeTag.FORALL;
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
    72
import static com.sun.tools.javac.code.TypeTag.TYPEVAR;
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    73
import static com.sun.tools.javac.jvm.ByteCodes.iadd;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    74
import static com.sun.tools.javac.jvm.ByteCodes.ishll;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    75
import static com.sun.tools.javac.jvm.ByteCodes.lushrl;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    76
import static com.sun.tools.javac.jvm.ByteCodes.lxor;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
    77
import static com.sun.tools.javac.jvm.ByteCodes.string_add;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    78
06bc494ca11e Initial load
duke
parents:
diff changeset
    79
/** Root class for Java symbols. It contains subclasses
06bc494ca11e Initial load
duke
parents:
diff changeset
    80
 *  for specific sorts of symbols, such as variables, methods and operators,
06bc494ca11e Initial load
duke
parents:
diff changeset
    81
 *  types, packages. Each subclass is represented as a static inner class
06bc494ca11e Initial load
duke
parents:
diff changeset
    82
 *  inside Symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
    83
 *
5847
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    84
 *  <p><b>This is NOT part of any supported API.
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    85
 *  If you write code that depends on this, you do so at your own risk.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    86
 *  This code and its internal interfaces are subject to change or
06bc494ca11e Initial load
duke
parents:
diff changeset
    87
 *  deletion without notice.</b>
06bc494ca11e Initial load
duke
parents:
diff changeset
    88
 */
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
    89
public abstract class Symbol extends AnnoConstruct implements Element {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    90
06bc494ca11e Initial load
duke
parents:
diff changeset
    91
    /** The kind of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
    92
     *  @see Kinds
06bc494ca11e Initial load
duke
parents:
diff changeset
    93
     */
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
    94
    public Kind kind;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    95
06bc494ca11e Initial load
duke
parents:
diff changeset
    96
    /** The flags of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
    97
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
    98
    public long flags_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
    99
06bc494ca11e Initial load
duke
parents:
diff changeset
   100
    /** An accessor method for the flags of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   101
     *  Flags of class symbols should be accessed through the accessor
06bc494ca11e Initial load
duke
parents:
diff changeset
   102
     *  method to make sure that the class symbol is loaded.
06bc494ca11e Initial load
duke
parents:
diff changeset
   103
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   104
    public long flags() { return flags_field; }
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
06bc494ca11e Initial load
duke
parents:
diff changeset
   106
    /** The name of this symbol in Utf8 representation.
06bc494ca11e Initial load
duke
parents:
diff changeset
   107
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
    public Name name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   109
06bc494ca11e Initial load
duke
parents:
diff changeset
   110
    /** The type of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   111
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   112
    public Type type;
06bc494ca11e Initial load
duke
parents:
diff changeset
   113
06bc494ca11e Initial load
duke
parents:
diff changeset
   114
    /** The owner of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   115
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   116
    public Symbol owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   117
06bc494ca11e Initial load
duke
parents:
diff changeset
   118
    /** The completer of this symbol.
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   119
     * This should never equal null (NULL_COMPLETER should be used instead).
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   120
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   121
    public Completer completer;
06bc494ca11e Initial load
duke
parents:
diff changeset
   122
06bc494ca11e Initial load
duke
parents:
diff changeset
   123
    /** A cache for the type erasure of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   124
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   125
    public Type erasure_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
   126
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   127
    // <editor-fold defaultstate="collapsed" desc="annotations">
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   128
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   129
    /** The attributes of this symbol are contained in this
19928
adce50c2b76c 8022260: Rename javac.code.Annotations to javac.code.SymbolMetadata
jfranck
parents: 19666
diff changeset
   130
     * SymbolMetadata. The SymbolMetadata instance is NOT immutable.
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   131
     */
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   132
    protected SymbolMetadata metadata;
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   133
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   134
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   135
    /** An accessor method for the attributes of this symbol.
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   136
     *  Attributes of class symbols should be accessed through the accessor
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   137
     *  method to make sure that the class symbol is loaded.
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   138
     */
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   139
    public List<Attribute.Compound> getRawAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   140
        return (metadata == null)
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   141
                ? List.<Attribute.Compound>nil()
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   142
                : metadata.getDeclarationAttributes();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   143
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   144
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   145
    /** An accessor method for the type attributes of this symbol.
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   146
     *  Attributes of class symbols should be accessed through the accessor
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   147
     *  method to make sure that the class symbol is loaded.
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   148
     */
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   149
    public List<Attribute.TypeCompound> getRawTypeAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   150
        return (metadata == null)
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   151
                ? List.<Attribute.TypeCompound>nil()
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   152
                : metadata.getTypeAttributes();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   153
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   154
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   155
    /** Fetch a particular annotation from a symbol. */
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   156
    public Attribute.Compound attribute(Symbol anno) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   157
        for (Attribute.Compound a : getRawAttributes()) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   158
            if (a.type.tsym == anno) return a;
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   159
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   160
        return null;
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   161
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   162
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   163
    public boolean annotationsPendingCompletion() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   164
        return metadata == null ? false : metadata.pendingCompletion();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   165
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   166
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   167
    public void appendAttributes(List<Attribute.Compound> l) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   168
        if (l.nonEmpty()) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   169
            initedMetadata().append(l);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   170
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   171
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   172
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   173
    public void appendClassInitTypeAttributes(List<Attribute.TypeCompound> l) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   174
        if (l.nonEmpty()) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   175
            initedMetadata().appendClassInitTypeAttributes(l);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   176
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   177
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   178
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   179
    public void appendInitTypeAttributes(List<Attribute.TypeCompound> l) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   180
        if (l.nonEmpty()) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   181
            initedMetadata().appendInitTypeAttributes(l);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   182
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   183
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   184
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   185
    public void appendUniqueTypeAttributes(List<Attribute.TypeCompound> l) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   186
        if (l.nonEmpty()) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   187
            initedMetadata().appendUniqueTypes(l);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   188
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   189
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   190
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   191
    public List<Attribute.TypeCompound> getClassInitTypeAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   192
        return (metadata == null)
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   193
                ? List.<Attribute.TypeCompound>nil()
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   194
                : metadata.getClassInitTypeAttributes();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   195
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   196
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   197
    public List<Attribute.TypeCompound> getInitTypeAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   198
        return (metadata == null)
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   199
                ? List.<Attribute.TypeCompound>nil()
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   200
                : metadata.getInitTypeAttributes();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   201
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   202
33712
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   203
    public void setInitTypeAttributes(List<Attribute.TypeCompound> l) {
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   204
        initedMetadata().setInitTypeAttributes(l);
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   205
    }
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   206
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   207
    public void setClassInitTypeAttributes(List<Attribute.TypeCompound> l) {
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   208
        initedMetadata().setClassInitTypeAttributes(l);
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   209
    }
fd1ce6d7ac63 8136419: Type annotations in initializers and lambda bodies not written to class file
sadayapalam
parents: 33367
diff changeset
   210
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   211
    public List<Attribute.Compound> getDeclarationAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   212
        return (metadata == null)
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   213
                ? List.<Attribute.Compound>nil()
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   214
                : metadata.getDeclarationAttributes();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   215
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   216
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   217
    public boolean hasAnnotations() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   218
        return (metadata != null && !metadata.isEmpty());
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   219
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   220
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   221
    public boolean hasTypeAnnotations() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   222
        return (metadata != null && !metadata.isTypesEmpty());
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   223
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   224
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   225
    public boolean isCompleted() {
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   226
        return completer.isTerminal();
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   227
    }
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   228
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   229
    public void prependAttributes(List<Attribute.Compound> l) {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   230
        if (l.nonEmpty()) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   231
            initedMetadata().prepend(l);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   232
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   233
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   234
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   235
    public void resetAnnotations() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   236
        initedMetadata().reset();
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   237
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   238
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   239
    public void setAttributes(Symbol other) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   240
        if (metadata != null || other.metadata != null) {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   241
            initedMetadata().setAttributes(other.metadata);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   242
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   243
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   244
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   245
    public void setDeclarationAttributes(List<Attribute.Compound> a) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   246
        if (metadata != null || a.nonEmpty()) {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   247
            initedMetadata().setDeclarationAttributes(a);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   248
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   249
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   250
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   251
    public void setTypeAttributes(List<Attribute.TypeCompound> a) {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   252
        if (metadata != null || a.nonEmpty()) {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   253
            if (metadata == null)
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   254
                metadata = new SymbolMetadata(this);
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   255
            metadata.setTypeAttributes(a);
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   256
        }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   257
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   258
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   259
    private SymbolMetadata initedMetadata() {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   260
        if (metadata == null)
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   261
            metadata = new SymbolMetadata(this);
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   262
        return metadata;
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   263
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   264
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   265
    /** This method is intended for debugging only. */
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   266
    public SymbolMetadata getMetadata() {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
   267
        return metadata;
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   268
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   269
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   270
    // </editor-fold>
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   271
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   272
    /** Construct a symbol with given kind, flags, name, type and owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
   273
     */
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   274
    public Symbol(Kind kind, long flags, Name name, Type type, Symbol owner) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   275
        this.kind = kind;
06bc494ca11e Initial load
duke
parents:
diff changeset
   276
        this.flags_field = flags;
06bc494ca11e Initial load
duke
parents:
diff changeset
   277
        this.type = type;
06bc494ca11e Initial load
duke
parents:
diff changeset
   278
        this.owner = owner;
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   279
        this.completer = Completer.NULL_COMPLETER;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   280
        this.erasure_field = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   281
        this.name = name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   282
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   283
06bc494ca11e Initial load
duke
parents:
diff changeset
   284
    /** Clone this symbol with new owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
   285
     *  Legal only for fields and methods.
06bc494ca11e Initial load
duke
parents:
diff changeset
   286
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   287
    public Symbol clone(Symbol newOwner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   288
        throw new AssertionError();
06bc494ca11e Initial load
duke
parents:
diff changeset
   289
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   290
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   291
    public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   292
        return v.visitSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   293
    }
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   294
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   295
    /** The Java source which this symbol represents.
06bc494ca11e Initial load
duke
parents:
diff changeset
   296
     *  A description of this symbol; overrides Object.
06bc494ca11e Initial load
duke
parents:
diff changeset
   297
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   298
    public String toString() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   299
        return name.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
   300
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   301
06bc494ca11e Initial load
duke
parents:
diff changeset
   302
    /** A Java source description of the location of this symbol; used for
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   303
     *  error reporting.
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   304
     *
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   305
     * @return null if the symbol is a package or a toplevel class defined in
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   306
     * the default package; otherwise, the owner symbol is returned
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   307
     */
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   308
    public Symbol location() {
10626
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
   309
        if (owner.name == null || (owner.name.isEmpty() &&
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   310
                                   (owner.flags() & BLOCK) == 0 &&
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   311
                                   owner.kind != PCK &&
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   312
                                   owner.kind != TYP)) {
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   313
            return null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   314
        }
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   315
        return owner;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   316
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   317
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   318
    public Symbol location(Type site, Types types) {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
   319
        if (owner.name == null || owner.name.isEmpty()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   320
            return location();
06bc494ca11e Initial load
duke
parents:
diff changeset
   321
        }
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
   322
        if (owner.type.hasTag(CLASS)) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   323
            Type ownertype = types.asOuterSuper(site, owner);
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   324
            if (ownertype != null) return ownertype.tsym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   325
        }
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   326
        return owner;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   327
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   328
14051
9097cec96212 7188968: New instance creation expression using diamond is checked twice
mcimadamore
parents: 14046
diff changeset
   329
    public Symbol baseSymbol() {
9097cec96212 7188968: New instance creation expression using diamond is checked twice
mcimadamore
parents: 14046
diff changeset
   330
        return this;
9097cec96212 7188968: New instance creation expression using diamond is checked twice
mcimadamore
parents: 14046
diff changeset
   331
    }
9097cec96212 7188968: New instance creation expression using diamond is checked twice
mcimadamore
parents: 14046
diff changeset
   332
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   333
    /** The symbol's erased type.
06bc494ca11e Initial load
duke
parents:
diff changeset
   334
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   335
    public Type erasure(Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   336
        if (erasure_field == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
   337
            erasure_field = types.erasure(type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   338
        return erasure_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
   339
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   340
06bc494ca11e Initial load
duke
parents:
diff changeset
   341
    /** The external type of a symbol. This is the symbol's erased type
06bc494ca11e Initial load
duke
parents:
diff changeset
   342
     *  except for constructors of inner classes which get the enclosing
06bc494ca11e Initial load
duke
parents:
diff changeset
   343
     *  instance class added as first argument.
06bc494ca11e Initial load
duke
parents:
diff changeset
   344
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   345
    public Type externalType(Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   346
        Type t = erasure(types);
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
   347
        if (name == name.table.names.init && owner.hasOuterInstance()) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   348
            Type outerThisType = types.erasure(owner.type.getEnclosingType());
06bc494ca11e Initial load
duke
parents:
diff changeset
   349
            return new MethodType(t.getParameterTypes().prepend(outerThisType),
06bc494ca11e Initial load
duke
parents:
diff changeset
   350
                                  t.getReturnType(),
06bc494ca11e Initial load
duke
parents:
diff changeset
   351
                                  t.getThrownTypes(),
06bc494ca11e Initial load
duke
parents:
diff changeset
   352
                                  t.tsym);
06bc494ca11e Initial load
duke
parents:
diff changeset
   353
        } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   354
            return t;
06bc494ca11e Initial load
duke
parents:
diff changeset
   355
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   356
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   357
18010
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   358
    public boolean isDeprecated() {
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   359
        return (flags_field & DEPRECATED) != 0;
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   360
    }
604faee85350 8004643: Reduce javac space overhead introduced with compiler support for repeating annotations
jjg
parents: 17278
diff changeset
   361
40772
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   362
    public boolean isDeprecatableViaAnnotation() {
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   363
        switch (getKind()) {
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   364
            case LOCAL_VARIABLE:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   365
            case PACKAGE:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   366
            case PARAMETER:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   367
            case RESOURCE_VARIABLE:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   368
            case EXCEPTION_PARAMETER:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   369
                return false;
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   370
            default:
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   371
                return true;
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   372
        }
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   373
    }
de87954b8f20 8164073: Javac should unconditionally warn if deprecated javadoc tag is used without @Deprecated annotation
sadayapalam
parents: 39920
diff changeset
   374
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   375
    public boolean isStatic() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   376
        return
06bc494ca11e Initial load
duke
parents:
diff changeset
   377
            (flags() & STATIC) != 0 ||
20598
aa7b86f98471 8024497: crash returning this-referencing lambda from default method
vromero
parents: 20249
diff changeset
   378
            (owner.flags() & INTERFACE) != 0 && kind != MTH &&
aa7b86f98471 8024497: crash returning this-referencing lambda from default method
vromero
parents: 20249
diff changeset
   379
             name != name.table.names._this;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   380
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   381
06bc494ca11e Initial load
duke
parents:
diff changeset
   382
    public boolean isInterface() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   383
        return (flags() & INTERFACE) != 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   384
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   385
15720
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   386
    public boolean isPrivate() {
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   387
        return (flags_field & Flags.AccessFlags) == PRIVATE;
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   388
    }
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   389
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   390
    public boolean isEnum() {
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   391
        return (flags() & ENUM) != 0;
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   392
    }
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
   393
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   394
    /** Is this symbol declared (directly or indirectly) local
06bc494ca11e Initial load
duke
parents:
diff changeset
   395
     *  to a method or variable initializer?
06bc494ca11e Initial load
duke
parents:
diff changeset
   396
     *  Also includes fields of inner classes which are in
06bc494ca11e Initial load
duke
parents:
diff changeset
   397
     *  turn local to a method or variable initializer.
06bc494ca11e Initial load
duke
parents:
diff changeset
   398
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   399
    public boolean isLocal() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   400
        return
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   401
            (owner.kind.matches(KindSelector.VAL_MTH) ||
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   402
             (owner.kind == TYP && owner.isLocal()));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   403
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   404
5321
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   405
    /** Has this symbol an empty name? This includes anonymous
16333
a6e1ded87200 8009138: javac, equals-hashCode warning tuning
vromero
parents: 16320
diff changeset
   406
     *  inner classes.
5321
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   407
     */
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   408
    public boolean isAnonymous() {
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   409
        return name.isEmpty();
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   410
    }
c8efe769cb3b 6939620: Switch to 'complex' diamond inference scheme
mcimadamore
parents: 5006
diff changeset
   411
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   412
    /** Is this symbol a constructor?
06bc494ca11e Initial load
duke
parents:
diff changeset
   413
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   414
    public boolean isConstructor() {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
   415
        return name == name.table.names.init;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   416
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   417
06bc494ca11e Initial load
duke
parents:
diff changeset
   418
    /** The fully qualified name of this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   419
     *  This is the same as the symbol's name except for class symbols,
06bc494ca11e Initial load
duke
parents:
diff changeset
   420
     *  which are handled separately.
06bc494ca11e Initial load
duke
parents:
diff changeset
   421
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   422
    public Name getQualifiedName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   423
        return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   424
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   425
06bc494ca11e Initial load
duke
parents:
diff changeset
   426
    /** The fully qualified name of this symbol after converting to flat
06bc494ca11e Initial load
duke
parents:
diff changeset
   427
     *  representation. This is the same as the symbol's name except for
06bc494ca11e Initial load
duke
parents:
diff changeset
   428
     *  class symbols, which are handled separately.
06bc494ca11e Initial load
duke
parents:
diff changeset
   429
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   430
    public Name flatName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   431
        return getQualifiedName();
06bc494ca11e Initial load
duke
parents:
diff changeset
   432
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   433
06bc494ca11e Initial load
duke
parents:
diff changeset
   434
    /** If this is a class or package, its members, otherwise null.
06bc494ca11e Initial load
duke
parents:
diff changeset
   435
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   436
    public WriteableScope members() {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   437
        return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   438
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   439
06bc494ca11e Initial load
duke
parents:
diff changeset
   440
    /** A class is an inner class if it it has an enclosing instance class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   441
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   442
    public boolean isInner() {
24219
e7dc661cafae 8029102: Enhance compiler warnings for Lambda
vromero
parents: 23814
diff changeset
   443
        return kind == TYP && type.getEnclosingType().hasTag(CLASS);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   444
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   445
06bc494ca11e Initial load
duke
parents:
diff changeset
   446
    /** An inner class has an outer instance if it is not an interface
06bc494ca11e Initial load
duke
parents:
diff changeset
   447
     *  it has an enclosing instance class which might be referenced from the class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   448
     *  Nested classes can see instance members of their enclosing class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   449
     *  Their constructors carry an additional this$n parameter, inserted
06bc494ca11e Initial load
duke
parents:
diff changeset
   450
     *  implicitly by the compiler.
06bc494ca11e Initial load
duke
parents:
diff changeset
   451
     *
06bc494ca11e Initial load
duke
parents:
diff changeset
   452
     *  @see #isInner
06bc494ca11e Initial load
duke
parents:
diff changeset
   453
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   454
    public boolean hasOuterInstance() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   455
        return
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
   456
            type.getEnclosingType().hasTag(CLASS) && (flags() & (INTERFACE | NOOUTERTHIS)) == 0;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   457
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   458
06bc494ca11e Initial load
duke
parents:
diff changeset
   459
    /** The closest enclosing class of this symbol's declaration.
34561
79c436257611 8144673: Suspect message regarding suitable enclosing instance not being in scope
sadayapalam
parents: 33712
diff changeset
   460
     *  Warning: this (misnamed) method returns the receiver itself
79c436257611 8144673: Suspect message regarding suitable enclosing instance not being in scope
sadayapalam
parents: 33712
diff changeset
   461
     *  when the receiver is a class (as opposed to its enclosing
79c436257611 8144673: Suspect message regarding suitable enclosing instance not being in scope
sadayapalam
parents: 33712
diff changeset
   462
     *  class as one may be misled to believe.)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   463
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   464
    public ClassSymbol enclClass() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   465
        Symbol c = this;
06bc494ca11e Initial load
duke
parents:
diff changeset
   466
        while (c != null &&
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   467
               (!c.kind.matches(KindSelector.TYP) || !c.type.hasTag(CLASS))) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   468
            c = c.owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   469
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   470
        return (ClassSymbol)c;
06bc494ca11e Initial load
duke
parents:
diff changeset
   471
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   472
06bc494ca11e Initial load
duke
parents:
diff changeset
   473
    /** The outermost class which indirectly owns this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   474
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   475
    public ClassSymbol outermostClass() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   476
        Symbol sym = this;
06bc494ca11e Initial load
duke
parents:
diff changeset
   477
        Symbol prev = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
   478
        while (sym.kind != PCK) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   479
            prev = sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   480
            sym = sym.owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   481
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   482
        return (ClassSymbol) prev;
06bc494ca11e Initial load
duke
parents:
diff changeset
   483
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   484
06bc494ca11e Initial load
duke
parents:
diff changeset
   485
    /** The package which indirectly owns this symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   486
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   487
    public PackageSymbol packge() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   488
        Symbol sym = this;
06bc494ca11e Initial load
duke
parents:
diff changeset
   489
        while (sym.kind != PCK) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   490
            sym = sym.owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   491
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   492
        return (PackageSymbol) sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   493
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   494
06bc494ca11e Initial load
duke
parents:
diff changeset
   495
    /** Is this symbol a subclass of `base'? Only defined for ClassSymbols.
06bc494ca11e Initial load
duke
parents:
diff changeset
   496
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   497
    public boolean isSubClass(Symbol base, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   498
        throw new AssertionError("isSubClass " + this);
06bc494ca11e Initial load
duke
parents:
diff changeset
   499
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   500
06bc494ca11e Initial load
duke
parents:
diff changeset
   501
    /** Fully check membership: hierarchy, protection, and hiding.
06bc494ca11e Initial load
duke
parents:
diff changeset
   502
     *  Does not exclude methods not inherited due to overriding.
06bc494ca11e Initial load
duke
parents:
diff changeset
   503
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   504
    public boolean isMemberOf(TypeSymbol clazz, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   505
        return
06bc494ca11e Initial load
duke
parents:
diff changeset
   506
            owner == clazz ||
06bc494ca11e Initial load
duke
parents:
diff changeset
   507
            clazz.isSubClass(owner, types) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
   508
            isInheritedIn(clazz, types) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
   509
            !hiddenIn((ClassSymbol)clazz, types);
06bc494ca11e Initial load
duke
parents:
diff changeset
   510
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   511
06bc494ca11e Initial load
duke
parents:
diff changeset
   512
    /** Is this symbol the same as or enclosed by the given class? */
06bc494ca11e Initial load
duke
parents:
diff changeset
   513
    public boolean isEnclosedBy(ClassSymbol clazz) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   514
        for (Symbol sym = this; sym.kind != PCK; sym = sym.owner)
06bc494ca11e Initial load
duke
parents:
diff changeset
   515
            if (sym == clazz) return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   516
        return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   517
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   518
06bc494ca11e Initial load
duke
parents:
diff changeset
   519
    private boolean hiddenIn(ClassSymbol clazz, Types types) {
19492
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   520
        Symbol sym = hiddenInInternal(clazz, types);
23396
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   521
        Assert.check(sym != null, "the result of hiddenInInternal() can't be null");
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   522
        /* If we find the current symbol then there is no symbol hiding it
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   523
         */
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   524
        return sym != this;
19492
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   525
    }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   526
23396
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   527
    /** This method looks in the supertypes graph that has the current class as the
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   528
     * initial node, till it finds the current symbol or another symbol that hides it.
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   529
     * If the current class has more than one supertype (extends one class and
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   530
     * implements one or more interfaces) then null can be returned, meaning that
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   531
     * a wrong path in the supertypes graph was selected. Null can only be returned
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   532
     * as a temporary value, as a result of the recursive call.
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   533
     */
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   534
    private Symbol hiddenInInternal(ClassSymbol currentClass, Types types) {
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   535
        if (currentClass == owner) {
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   536
            return this;
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   537
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   538
        for (Symbol sym : currentClass.members().getSymbolsByName(name)) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   539
            if (sym.kind == kind &&
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   540
                    (kind != MTH ||
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   541
                    (sym.flags() & STATIC) != 0 &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   542
                    types.isSubSignature(sym.type, type))) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   543
                return sym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   544
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   545
        }
23396
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   546
        Symbol hiddenSym = null;
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   547
        for (Type st : types.interfaces(currentClass.type)
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   548
                .prepend(types.supertype(currentClass.type))) {
19492
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   549
            if (st != null && (st.hasTag(CLASS))) {
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   550
                Symbol sym = hiddenInInternal((ClassSymbol)st.tsym, types);
23396
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   551
                if (sym == this) {
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   552
                    return this;
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   553
                } else if (sym != null) {
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   554
                    hiddenSym = sym;
19492
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   555
                }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   556
            }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 19126
diff changeset
   557
        }
23396
06e3726c6b3f 8034924: Incorrect inheritance of inaccessible static method
vromero
parents: 22163
diff changeset
   558
        return hiddenSym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   559
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   560
06bc494ca11e Initial load
duke
parents:
diff changeset
   561
    /** Is this symbol inherited into a given class?
06bc494ca11e Initial load
duke
parents:
diff changeset
   562
     *  PRE: If symbol's owner is a interface,
06bc494ca11e Initial load
duke
parents:
diff changeset
   563
     *       it is already assumed that the interface is a superinterface
06bc494ca11e Initial load
duke
parents:
diff changeset
   564
     *       of given class.
06bc494ca11e Initial load
duke
parents:
diff changeset
   565
     *  @param clazz  The class for which we want to establish membership.
06bc494ca11e Initial load
duke
parents:
diff changeset
   566
     *                This must be a subclass of the member's owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
   567
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   568
    public boolean isInheritedIn(Symbol clazz, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   569
        switch ((int)(flags_field & Flags.AccessFlags)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   570
        default: // error recovery
06bc494ca11e Initial load
duke
parents:
diff changeset
   571
        case PUBLIC:
06bc494ca11e Initial load
duke
parents:
diff changeset
   572
            return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   573
        case PRIVATE:
06bc494ca11e Initial load
duke
parents:
diff changeset
   574
            return this.owner == clazz;
06bc494ca11e Initial load
duke
parents:
diff changeset
   575
        case PROTECTED:
06bc494ca11e Initial load
duke
parents:
diff changeset
   576
            // we model interfaces as extending Object
06bc494ca11e Initial load
duke
parents:
diff changeset
   577
            return (clazz.flags() & INTERFACE) == 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   578
        case 0:
06bc494ca11e Initial load
duke
parents:
diff changeset
   579
            PackageSymbol thisPackage = this.packge();
06bc494ca11e Initial load
duke
parents:
diff changeset
   580
            for (Symbol sup = clazz;
06bc494ca11e Initial load
duke
parents:
diff changeset
   581
                 sup != null && sup != this.owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   582
                 sup = types.supertype(sup.type).tsym) {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
   583
                while (sup.type.hasTag(TYPEVAR))
1528
441d4ec466de 6711619: javac doesn't allow access to protected members in intersection types
mcimadamore
parents: 1357
diff changeset
   584
                    sup = sup.type.getUpperBound().tsym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   585
                if (sup.type.isErroneous())
06bc494ca11e Initial load
duke
parents:
diff changeset
   586
                    return true; // error recovery
06bc494ca11e Initial load
duke
parents:
diff changeset
   587
                if ((sup.flags() & COMPOUND) != 0)
06bc494ca11e Initial load
duke
parents:
diff changeset
   588
                    continue;
06bc494ca11e Initial load
duke
parents:
diff changeset
   589
                if (sup.packge() != thisPackage)
06bc494ca11e Initial load
duke
parents:
diff changeset
   590
                    return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   591
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   592
            return (clazz.flags() & INTERFACE) == 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
   593
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   594
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   595
06bc494ca11e Initial load
duke
parents:
diff changeset
   596
    /** The (variable or method) symbol seen as a member of given
06bc494ca11e Initial load
duke
parents:
diff changeset
   597
     *  class type`site' (this might change the symbol's type).
06bc494ca11e Initial load
duke
parents:
diff changeset
   598
     *  This is used exclusively for producing diagnostics.
06bc494ca11e Initial load
duke
parents:
diff changeset
   599
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   600
    public Symbol asMemberOf(Type site, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   601
        throw new AssertionError();
06bc494ca11e Initial load
duke
parents:
diff changeset
   602
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   603
06bc494ca11e Initial load
duke
parents:
diff changeset
   604
    /** Does this method symbol override `other' symbol, when both are seen as
06bc494ca11e Initial load
duke
parents:
diff changeset
   605
     *  members of class `origin'?  It is assumed that _other is a member
06bc494ca11e Initial load
duke
parents:
diff changeset
   606
     *  of origin.
06bc494ca11e Initial load
duke
parents:
diff changeset
   607
     *
06bc494ca11e Initial load
duke
parents:
diff changeset
   608
     *  It is assumed that both symbols have the same name.  The static
06bc494ca11e Initial load
duke
parents:
diff changeset
   609
     *  modifier is ignored for this test.
06bc494ca11e Initial load
duke
parents:
diff changeset
   610
     *
06bc494ca11e Initial load
duke
parents:
diff changeset
   611
     *  See JLS 8.4.6.1 (without transitivity) and 8.4.6.4
06bc494ca11e Initial load
duke
parents:
diff changeset
   612
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   613
    public boolean overrides(Symbol _other, TypeSymbol origin, Types types, boolean checkResult) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   614
        return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
   615
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   616
06bc494ca11e Initial load
duke
parents:
diff changeset
   617
    /** Complete the elaboration of this symbol's definition.
06bc494ca11e Initial load
duke
parents:
diff changeset
   618
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   619
    public void complete() throws CompletionFailure {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   620
        if (completer != Completer.NULL_COMPLETER) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   621
            Completer c = completer;
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
   622
            completer = Completer.NULL_COMPLETER;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   623
            c.complete(this);
06bc494ca11e Initial load
duke
parents:
diff changeset
   624
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   625
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   626
06bc494ca11e Initial load
duke
parents:
diff changeset
   627
    /** True if the symbol represents an entity that exists.
06bc494ca11e Initial load
duke
parents:
diff changeset
   628
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
   629
    public boolean exists() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   630
        return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
   631
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   632
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   633
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   634
    public Type asType() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   635
        return type;
06bc494ca11e Initial load
duke
parents:
diff changeset
   636
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   637
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   638
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   639
    public Symbol getEnclosingElement() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   640
        return owner;
06bc494ca11e Initial load
duke
parents:
diff changeset
   641
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   642
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   643
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   644
    public ElementKind getKind() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   645
        return ElementKind.OTHER;       // most unkind
06bc494ca11e Initial load
duke
parents:
diff changeset
   646
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   647
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   648
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   649
    public Set<Modifier> getModifiers() {
16970
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
   650
        return Flags.asModifierSet(flags());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   651
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   652
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   653
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   654
    public Name getSimpleName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   655
        return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   656
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   657
06bc494ca11e Initial load
duke
parents:
diff changeset
   658
    /**
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   659
     * This is the implementation for {@code
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   660
     * javax.lang.model.element.Element.getAnnotationMirrors()}.
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   661
     */
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   662
    @Override @DefinedBy(Api.LANGUAGE_MODEL)
17278
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   663
    public List<Attribute.Compound> getAnnotationMirrors() {
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   664
        return getRawAttributes();
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   665
    }
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
   666
15355
a4757c33cae9 7193719: Support repeating annotations in javax.lang.model
jfranck
parents: 15031
diff changeset
   667
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   668
    // TODO: getEnclosedElements should return a javac List, fix in FilteredMemberList
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   669
    @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   670
    public java.util.List<Symbol> getEnclosedElements() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   671
        return List.nil();
06bc494ca11e Initial load
duke
parents:
diff changeset
   672
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   673
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   674
    public List<TypeVariableSymbol> getTypeParameters() {
20249
93f8eae31092 6386236: Please rename com.sun.tools.javac.util.ListBuffer.lb()
alundblad
parents: 19942
diff changeset
   675
        ListBuffer<TypeVariableSymbol> l = new ListBuffer<>();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   676
        for (Type t : type.getTypeArguments()) {
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   677
            Assert.check(t.tsym.getKind() == ElementKind.TYPE_PARAMETER);
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   678
            l.append((TypeVariableSymbol)t.tsym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   679
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   680
        return l.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
   681
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   682
15564
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   683
    public static class DelegatedSymbol<T extends Symbol> extends Symbol {
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   684
        protected T other;
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   685
        public DelegatedSymbol(T other) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   686
            super(other.kind, other.flags_field, other.name, other.type, other.owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
   687
            this.other = other;
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
        public String toString() { return other.toString(); }
939
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   690
        public Symbol location() { return other.location(); }
38e24969c7e9 6717241: some diagnostic argument is prematurely converted into a String object
mcimadamore
parents: 735
diff changeset
   691
        public Symbol location(Type site, Types types) { return other.location(site, types); }
14547
86d8d242b0c4 8003280: Add lambda tests
mcimadamore
parents: 14443
diff changeset
   692
        public Symbol baseSymbol() { return other; }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   693
        public Type erasure(Types types) { return other.erasure(types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   694
        public Type externalType(Types types) { return other.externalType(types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   695
        public boolean isLocal() { return other.isLocal(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
        public boolean isConstructor() { return other.isConstructor(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   697
        public Name getQualifiedName() { return other.getQualifiedName(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
        public Name flatName() { return other.flatName(); }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   699
        public WriteableScope members() { return other.members(); }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
        public boolean isInner() { return other.isInner(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
        public boolean hasOuterInstance() { return other.hasOuterInstance(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   702
        public ClassSymbol enclClass() { return other.enclClass(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
        public ClassSymbol outermostClass() { return other.outermostClass(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   704
        public PackageSymbol packge() { return other.packge(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   705
        public boolean isSubClass(Symbol base, Types types) { return other.isSubClass(base, types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   706
        public boolean isMemberOf(TypeSymbol clazz, Types types) { return other.isMemberOf(clazz, types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   707
        public boolean isEnclosedBy(ClassSymbol clazz) { return other.isEnclosedBy(clazz); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   708
        public boolean isInheritedIn(Symbol clazz, Types types) { return other.isInheritedIn(clazz, types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   709
        public Symbol asMemberOf(Type site, Types types) { return other.asMemberOf(site, types); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   710
        public void complete() throws CompletionFailure { other.complete(); }
06bc494ca11e Initial load
duke
parents:
diff changeset
   711
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   712
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   713
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   714
            return other.accept(v, p);
06bc494ca11e Initial load
duke
parents:
diff changeset
   715
        }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   716
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   717
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   718
            return v.visitSymbol(other, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   719
        }
15564
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   720
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   721
        public T getUnderlyingSymbol() {
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   722
            return other;
6d8db91563a7 8005075: Pool.Method, and Pool.Variable redundant Symbol field should be removed
vromero
parents: 15385
diff changeset
   723
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   724
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   725
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   726
    /** A base class for Symbols representing types.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   727
     */
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   728
    public static abstract class TypeSymbol extends Symbol {
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   729
        public TypeSymbol(Kind kind, long flags, Name name, Type type, Symbol owner) {
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   730
            super(kind, flags, name, type, owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   731
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   732
        /** form a fully qualified name from a name and an owner
06bc494ca11e Initial load
duke
parents:
diff changeset
   733
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   734
        static public Name formFullName(Name name, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   735
            if (owner == null) return name;
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   736
            if ((owner.kind != ERR) &&
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   737
                (owner.kind.matches(KindSelector.VAL_MTH) ||
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   738
                 (owner.kind == TYP && owner.type.hasTag(TYPEVAR))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   739
                 )) return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   740
            Name prefix = owner.getQualifiedName();
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
   741
            if (prefix == null || prefix == prefix.table.names.empty)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   742
                return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   743
            else return prefix.append('.', name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   744
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   745
06bc494ca11e Initial load
duke
parents:
diff changeset
   746
        /** form a fully qualified name from a name and an owner, after
06bc494ca11e Initial load
duke
parents:
diff changeset
   747
         *  converting to flat representation
06bc494ca11e Initial load
duke
parents:
diff changeset
   748
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   749
        static public Name formFlatName(Name name, Symbol owner) {
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   750
            if (owner == null || owner.kind.matches(KindSelector.VAL_MTH) ||
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
   751
                (owner.kind == TYP && owner.type.hasTag(TYPEVAR))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   752
                ) return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   753
            char sep = owner.kind == TYP ? '$' : '.';
06bc494ca11e Initial load
duke
parents:
diff changeset
   754
            Name prefix = owner.flatName();
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
   755
            if (prefix == null || prefix == prefix.table.names.empty)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   756
                return name;
06bc494ca11e Initial load
duke
parents:
diff changeset
   757
            else return prefix.append(sep, name);
06bc494ca11e Initial load
duke
parents:
diff changeset
   758
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   759
06bc494ca11e Initial load
duke
parents:
diff changeset
   760
        /**
24293
0d889f759fac 8033718: Inference ignores capture variable as upper bound
dlsmith
parents: 24219
diff changeset
   761
         * A partial ordering between type symbols that refines the
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   762
         * class inheritance graph.
06bc494ca11e Initial load
duke
parents:
diff changeset
   763
         *
24293
0d889f759fac 8033718: Inference ignores capture variable as upper bound
dlsmith
parents: 24219
diff changeset
   764
         * Type variables always precede other kinds of symbols.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   765
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   766
        public final boolean precedes(TypeSymbol that, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   767
            if (this == that)
06bc494ca11e Initial load
duke
parents:
diff changeset
   768
                return false;
18646
e628560a86d1 8017104: javac should have a class for primitive types that inherits from Type
vromero
parents: 18389
diff changeset
   769
            if (type.hasTag(that.type.getTag())) {
e628560a86d1 8017104: javac should have a class for primitive types that inherits from Type
vromero
parents: 18389
diff changeset
   770
                if (type.hasTag(CLASS)) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   771
                    return
06bc494ca11e Initial load
duke
parents:
diff changeset
   772
                        types.rank(that.type) < types.rank(this.type) ||
06bc494ca11e Initial load
duke
parents:
diff changeset
   773
                        types.rank(that.type) == types.rank(this.type) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
   774
                        that.getQualifiedName().compareTo(this.getQualifiedName()) < 0;
18646
e628560a86d1 8017104: javac should have a class for primitive types that inherits from Type
vromero
parents: 18389
diff changeset
   775
                } else if (type.hasTag(TYPEVAR)) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   776
                    return types.isSubtype(this.type, that.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
   777
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
   778
            }
18646
e628560a86d1 8017104: javac should have a class for primitive types that inherits from Type
vromero
parents: 18389
diff changeset
   779
            return type.hasTag(TYPEVAR);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   780
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   781
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   782
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   783
        public java.util.List<Symbol> getEnclosedElements() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   784
            List<Symbol> list = List.nil();
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
   785
            if (kind == TYP && type.hasTag(TYPEVAR)) {
6584
c3d25d0ad536 6458749: TypeParameterElement.getEnclosedElements throws NPE within javac.
sundar
parents: 6148
diff changeset
   786
                return list;
c3d25d0ad536 6458749: TypeParameterElement.getEnclosedElements throws NPE within javac.
sundar
parents: 6148
diff changeset
   787
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
   788
            for (Symbol sym : members().getSymbols(NON_RECURSIVE)) {
37001
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   789
                try {
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   790
                    if (sym != null && (sym.flags() & SYNTHETIC) == 0 && sym.owner == this) {
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   791
                        list = list.prepend(sym);
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   792
                    }
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   793
                } catch (BadEnclosingMethodAttr badEnclosingMethod) {
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   794
                    // ignore the exception
594b4565d8a4 8151191: javac error when running javadoc on some inner classes
vromero
parents: 36526
diff changeset
   795
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   796
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   797
            return list;
06bc494ca11e Initial load
duke
parents:
diff changeset
   798
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   799
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   800
        public AnnotationTypeMetadata getAnnotationTypeMetadata() {
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   801
            Assert.error("Only on ClassSymbol");
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   802
            return null; //unreachable
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   803
        }
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   804
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   805
        public boolean isAnnotationType() { return false; }
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
   806
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   807
        @Override
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   808
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   809
            return v.visitTypeSymbol(this, p);
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   810
        }
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   811
    }
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   812
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   813
    /**
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   814
     * Type variables are represented by instances of this class.
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   815
     */
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   816
    public static class TypeVariableSymbol
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   817
            extends TypeSymbol implements TypeParameterElement {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   818
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   819
        public TypeVariableSymbol(long flags, Name name, Type type, Symbol owner) {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   820
            super(TYP, flags, name, type, owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   821
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   822
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   823
        @DefinedBy(Api.LANGUAGE_MODEL)
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   824
        public ElementKind getKind() {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   825
            return ElementKind.TYPE_PARAMETER;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   826
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   827
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   828
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   829
        public Symbol getGenericElement() {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   830
            return owner;
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   831
        }
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
   832
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   833
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   834
        public List<Type> getBounds() {
06bc494ca11e Initial load
duke
parents:
diff changeset
   835
            TypeVar t = (TypeVar)type;
06bc494ca11e Initial load
duke
parents:
diff changeset
   836
            Type bound = t.getUpperBound();
06bc494ca11e Initial load
duke
parents:
diff changeset
   837
            if (!bound.isCompound())
06bc494ca11e Initial load
duke
parents:
diff changeset
   838
                return List.of(bound);
06bc494ca11e Initial load
duke
parents:
diff changeset
   839
            ClassType ct = (ClassType)bound;
06bc494ca11e Initial load
duke
parents:
diff changeset
   840
            if (!ct.tsym.erasure_field.isInterface()) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   841
                return ct.interfaces_field.prepend(ct.supertype_field);
06bc494ca11e Initial load
duke
parents:
diff changeset
   842
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
   843
                // No superclass was given in bounds.
06bc494ca11e Initial load
duke
parents:
diff changeset
   844
                // In this case, supertype is Object, erasure is first interface.
06bc494ca11e Initial load
duke
parents:
diff changeset
   845
                return ct.interfaces_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
   846
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   847
        }
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   848
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   849
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
17278
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   850
        public List<Attribute.Compound> getAnnotationMirrors() {
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   851
            // Declaration annotations on type variables are stored in type attributes
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   852
            // on the owner of the TypeVariableSymbol
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   853
            List<Attribute.TypeCompound> candidates = owner.getRawTypeAttributes();
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   854
            int index = owner.getTypeParameters().indexOf(this);
17278
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   855
            List<Attribute.Compound> res = List.nil();
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   856
            for (Attribute.TypeCompound a : candidates) {
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   857
                if (isCurrentSymbolsAnnotation(a, index))
17278
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   858
                    res = res.prepend(a);
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   859
            }
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   860
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   861
            return res.reverse();
17278
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   862
        }
a48ec76f26e9 8011027: Type parameter annotations not passed through to javax.lang.model
jfranck
parents: 16970
diff changeset
   863
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   864
        // Helper to getAnnotation[s]
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   865
        @Override
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   866
        public <A extends Annotation> Attribute.Compound getAttribute(Class<A> annoType) {
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   867
            String name = annoType.getName();
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   868
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   869
            // Declaration annotations on type variables are stored in type attributes
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   870
            // on the owner of the TypeVariableSymbol
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   871
            List<Attribute.TypeCompound> candidates = owner.getRawTypeAttributes();
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   872
            int index = owner.getTypeParameters().indexOf(this);
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   873
            for (Attribute.TypeCompound anno : candidates)
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   874
                if (isCurrentSymbolsAnnotation(anno, index) &&
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   875
                    name.contentEquals(anno.type.tsym.flatName()))
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   876
                    return anno;
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   877
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   878
            return null;
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   879
        }
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   880
            //where:
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   881
            boolean isCurrentSymbolsAnnotation(Attribute.TypeCompound anno, int index) {
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   882
                return (anno.position.type == TargetType.CLASS_TYPE_PARAMETER ||
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   883
                        anno.position.type == TargetType.METHOD_TYPE_PARAMETER) &&
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   884
                        anno.position.parameter_index == index;
25009
55c823e853f2 8046916: Type parameter annotations don't work with multiple type parameters
jlahoda
parents: 24396
diff changeset
   885
            }
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   886
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
   887
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
   888
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   889
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   890
            return v.visitTypeParameter(this, p);
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
   891
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   892
    }
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   893
    /** A class for module symbols.
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   894
     */
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   895
    public static class ModuleSymbol extends TypeSymbol
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   896
            implements ModuleElement {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   897
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   898
        public Name version;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   899
        public JavaFileManager.Location sourceLocation;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   900
        public JavaFileManager.Location classLocation;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   901
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   902
        /** All directives, in natural order. */
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   903
        public List<com.sun.tools.javac.code.Directive> directives;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   904
        public List<com.sun.tools.javac.code.Directive.RequiresDirective> requires;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   905
        public List<com.sun.tools.javac.code.Directive.ExportsDirective> exports;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   906
        public List<com.sun.tools.javac.code.Directive.ProvidesDirective> provides;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   907
        public List<com.sun.tools.javac.code.Directive.UsesDirective> uses;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   908
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   909
        public ClassSymbol module_info;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   910
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   911
        public PackageSymbol unnamedPackage;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   912
        public Map<Name, PackageSymbol> visiblePackages;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   913
        public List<Symbol> enclosedPackages = List.nil();
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   914
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   915
        public Completer usesProvidesCompleter = Completer.NULL_COMPLETER;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   916
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   917
        /**
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   918
         * Create a ModuleSymbol with an associated module-info ClassSymbol.
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   919
         * The name of the module may be null, if it is not known yet.
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   920
         */
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   921
        public static ModuleSymbol create(Name name, Name module_info) {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   922
            ModuleSymbol msym = new ModuleSymbol(name, null);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   923
            ClassSymbol info = new ClassSymbol(Flags.MODULE, module_info, msym);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   924
            info.fullname = formFullName(module_info, msym);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   925
            info.flatname = info.fullname;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   926
            info.members_field = WriteableScope.create(info);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   927
            msym.module_info = info;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   928
            return msym;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   929
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   930
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   931
        public ModuleSymbol(Name name, Symbol owner) {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   932
            super(MDL, 0, name, null, owner);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   933
            this.type = new ModuleType(this);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   934
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   935
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   936
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   937
        public boolean isUnnamed() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   938
            return name.isEmpty() && owner == null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   939
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   940
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   941
        public boolean isNoModule() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   942
            return false;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   943
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   944
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   945
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   946
        public ElementKind getKind() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   947
            return ElementKind.MODULE;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   948
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   949
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   950
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   951
        public java.util.List<Directive> getDirectives() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   952
            completeUsesProvides();
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   953
            return Collections.unmodifiableList(directives);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   954
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   955
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   956
        public void completeUsesProvides() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   957
            if (usesProvidesCompleter != Completer.NULL_COMPLETER) {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   958
                Completer c = usesProvidesCompleter;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   959
                usesProvidesCompleter = Completer.NULL_COMPLETER;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   960
                c.complete(this);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   961
            }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   962
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   963
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   964
        @Override
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   965
        public ClassSymbol outermostClass() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   966
            return null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   967
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   968
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   969
        @Override
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   970
        public String toString() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   971
            // TODO: the following strings should be localized
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   972
            // Do this with custom anon subtypes in Symtab
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   973
            String n = (name == null) ? "<unknown>"
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   974
                    : (name.isEmpty()) ? "<unnamed>"
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   975
                    : String.valueOf(name);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   976
            return n;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   977
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   978
37848
3c8ff4204d2d 8154956: Module system implementation refresh (4/2016)
alanb
parents: 37001
diff changeset
   979
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   980
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   981
            return v.visitModule(this, p);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   982
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   983
37848
3c8ff4204d2d 8154956: Module system implementation refresh (4/2016)
alanb
parents: 37001
diff changeset
   984
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   985
        public List<Symbol> getEnclosedElements() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   986
            List<Symbol> list = List.nil();
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   987
            for (Symbol sym : enclosedPackages) {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   988
                if (sym.members().anyMatch(m -> m.kind == TYP))
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   989
                    list = list.prepend(sym);
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   990
            }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   991
            return list;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   992
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   993
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   994
        public void reset() {
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   995
            this.directives = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   996
            this.requires = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   997
            this.exports = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   998
            this.provides = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
   999
            this.uses = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1000
            this.visiblePackages = null;
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1001
        }
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1002
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1003
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1004
06bc494ca11e Initial load
duke
parents:
diff changeset
  1005
    /** A class for package symbols
06bc494ca11e Initial load
duke
parents:
diff changeset
  1006
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1007
    public static class PackageSymbol extends TypeSymbol
06bc494ca11e Initial load
duke
parents:
diff changeset
  1008
        implements PackageElement {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1009
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1010
        public WriteableScope members_field;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1011
        public Name fullname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1012
        public ClassSymbol package_info; // see bug 6443073
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1013
        public ModuleSymbol modle;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1014
06bc494ca11e Initial load
duke
parents:
diff changeset
  1015
        public PackageSymbol(Name name, Type type, Symbol owner) {
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
  1016
            super(PCK, 0, name, type, owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1017
            this.members_field = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1018
            this.fullname = formFullName(name, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1019
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1020
06bc494ca11e Initial load
duke
parents:
diff changeset
  1021
        public PackageSymbol(Name name, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1022
            this(name, null, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1023
            this.type = new PackageType(this);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1024
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1025
06bc494ca11e Initial load
duke
parents:
diff changeset
  1026
        public String toString() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1027
            return fullname.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1028
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1029
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1030
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1031
        public Name getQualifiedName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1032
            return fullname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1033
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1034
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1035
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1036
        public boolean isUnnamed() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1037
            return name.isEmpty() && owner != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1038
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1039
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1040
        public WriteableScope members() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1041
            complete();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1042
            return members_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1043
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1044
06bc494ca11e Initial load
duke
parents:
diff changeset
  1045
        public long flags() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1046
            complete();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1047
            return flags_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1048
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1049
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1050
        @Override
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1051
        public List<Attribute.Compound> getRawAttributes() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1052
            complete();
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1053
            if (package_info != null) {
4871
655bba719625 6499119: Created package-info class file modeled improperly
jjg
parents: 4077
diff changeset
  1054
                package_info.complete();
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1055
                mergeAttributes();
4871
655bba719625 6499119: Created package-info class file modeled improperly
jjg
parents: 4077
diff changeset
  1056
            }
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1057
            return super.getRawAttributes();
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1058
        }
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1059
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1060
        private void mergeAttributes() {
21480
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
  1061
            if (metadata == null &&
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
  1062
                package_info.metadata != null) {
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
  1063
                metadata = new SymbolMetadata(this);
9d08c2d0fafd 8025109: Better encapsulation for AnnotatedType
jjg
parents: 21007
diff changeset
  1064
                metadata.setAttributes(package_info.metadata);
13689
4d519199a6aa 7151010: Add compiler support for repeating annotations
jfranck
parents: 12335
diff changeset
  1065
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1066
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1067
06bc494ca11e Initial load
duke
parents:
diff changeset
  1068
        /** A package "exists" if a type or package that exists has
06bc494ca11e Initial load
duke
parents:
diff changeset
  1069
         *  been seen within it.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1070
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1071
        public boolean exists() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1072
            return (flags_field & EXISTS) != 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1073
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1074
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1075
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1076
        public ElementKind getKind() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1077
            return ElementKind.PACKAGE;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1078
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1079
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1080
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1081
        public Symbol getEnclosingElement() {
36526
3b41f1c69604 8142968: Module System implementation
alanb
parents: 34561
diff changeset
  1082
            return modle != null && !modle.isNoModule() ? modle : null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1083
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1084
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1085
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1086
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1087
            return v.visitPackage(this, p);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1088
        }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1089
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1090
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1091
            return v.visitPackageSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1092
        }
23810
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1093
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1094
        /**Resets the Symbol into the state good for next round of annotation processing.*/
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1095
        public void reset() {
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1096
            metadata = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1097
        }
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1098
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1099
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1100
06bc494ca11e Initial load
duke
parents:
diff changeset
  1101
    /** A class for class symbols
06bc494ca11e Initial load
duke
parents:
diff changeset
  1102
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1103
    public static class ClassSymbol extends TypeSymbol implements TypeElement {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1104
06bc494ca11e Initial load
duke
parents:
diff changeset
  1105
        /** a scope for all class members; variables, methods and inner classes
06bc494ca11e Initial load
duke
parents:
diff changeset
  1106
         *  type parameters are not part of this scope
06bc494ca11e Initial load
duke
parents:
diff changeset
  1107
         */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1108
        public WriteableScope members_field;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1109
06bc494ca11e Initial load
duke
parents:
diff changeset
  1110
        /** the fully qualified name of the class, i.e. pck.outer.inner.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1111
         *  null for anonymous classes
06bc494ca11e Initial load
duke
parents:
diff changeset
  1112
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1113
        public Name fullname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1114
06bc494ca11e Initial load
duke
parents:
diff changeset
  1115
        /** the fully qualified name of the class after converting to flat
06bc494ca11e Initial load
duke
parents:
diff changeset
  1116
         *  representation, i.e. pck.outer$inner,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1117
         *  set externally for local and anonymous classes
06bc494ca11e Initial load
duke
parents:
diff changeset
  1118
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1119
        public Name flatname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1120
06bc494ca11e Initial load
duke
parents:
diff changeset
  1121
        /** the sourcefile where the class came from
06bc494ca11e Initial load
duke
parents:
diff changeset
  1122
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1123
        public JavaFileObject sourcefile;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1124
06bc494ca11e Initial load
duke
parents:
diff changeset
  1125
        /** the classfile from where to load this class
06bc494ca11e Initial load
duke
parents:
diff changeset
  1126
         *  this will have extension .class or .java
06bc494ca11e Initial load
duke
parents:
diff changeset
  1127
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1128
        public JavaFileObject classfile;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1129
10627
d8e900b62e02 7003595: IncompatibleClassChangeError with unreferenced local class with subclass
mcimadamore
parents: 10626
diff changeset
  1130
        /** the list of translated local classes (used for generating
d8e900b62e02 7003595: IncompatibleClassChangeError with unreferenced local class with subclass
mcimadamore
parents: 10626
diff changeset
  1131
         * InnerClasses attribute)
d8e900b62e02 7003595: IncompatibleClassChangeError with unreferenced local class with subclass
mcimadamore
parents: 10626
diff changeset
  1132
         */
d8e900b62e02 7003595: IncompatibleClassChangeError with unreferenced local class with subclass
mcimadamore
parents: 10626
diff changeset
  1133
        public List<ClassSymbol> trans_local;
d8e900b62e02 7003595: IncompatibleClassChangeError with unreferenced local class with subclass
mcimadamore
parents: 10626
diff changeset
  1134
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1135
        /** the constant pool of the class
06bc494ca11e Initial load
duke
parents:
diff changeset
  1136
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1137
        public Pool pool;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1138
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1139
        /** the annotation metadata attached to this class */
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1140
        private AnnotationTypeMetadata annotationTypeMetadata;
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1141
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1142
        public ClassSymbol(long flags, Name name, Type type, Symbol owner) {
16967
79d444669f3f 7015104: use new subtype of TypeSymbol for type parameters
jfranck
parents: 16557
diff changeset
  1143
            super(TYP, flags, name, type, owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1144
            this.members_field = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1145
            this.fullname = formFullName(name, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1146
            this.flatname = formFlatName(name, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1147
            this.sourcefile = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1148
            this.classfile = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1149
            this.pool = null;
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1150
            this.annotationTypeMetadata = AnnotationTypeMetadata.notAnAnnotationType();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1151
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1152
06bc494ca11e Initial load
duke
parents:
diff changeset
  1153
        public ClassSymbol(long flags, Name name, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1154
            this(
06bc494ca11e Initial load
duke
parents:
diff changeset
  1155
                flags,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1156
                name,
26781
a786b07c7b91 8048614: Add TypeMetadata to contain type annotations and other type information
emc
parents: 26266
diff changeset
  1157
                new ClassType(Type.noType, null, null),
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1158
                owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1159
            this.type.tsym = this;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1160
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1161
06bc494ca11e Initial load
duke
parents:
diff changeset
  1162
        /** The Java source which this symbol represents.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1163
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1164
        public String toString() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1165
            return className();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1166
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1167
06bc494ca11e Initial load
duke
parents:
diff changeset
  1168
        public long flags() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1169
            complete();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1170
            return flags_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1171
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1172
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1173
        public WriteableScope members() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1174
            complete();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1175
            return members_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1176
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1177
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1178
        @Override
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1179
        public List<Attribute.Compound> getRawAttributes() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1180
            complete();
14961
e731935052af 8005098: Provide isSynthesized() information on Attribute.Compound
jfranck
parents: 14956
diff changeset
  1181
            return super.getRawAttributes();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1182
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1183
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1184
        @Override
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1185
        public List<Attribute.TypeCompound> getRawTypeAttributes() {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  1186
            complete();
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1187
            return super.getRawTypeAttributes();
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1188
        }
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1189
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1190
        public Type erasure(Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1191
            if (erasure_field == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1192
                erasure_field = new ClassType(types.erasure(type.getEnclosingType()),
24396
3c36c6afcbca 8040327: Eliminate AnnotatedType
emc
parents: 24293
diff changeset
  1193
                                              List.<Type>nil(), this,
26781
a786b07c7b91 8048614: Add TypeMetadata to contain type annotations and other type information
emc
parents: 26266
diff changeset
  1194
                                              type.getMetadata());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1195
            return erasure_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1196
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1197
06bc494ca11e Initial load
duke
parents:
diff changeset
  1198
        public String className() {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
  1199
            if (name.isEmpty())
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1200
                return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1201
                    Log.getLocalizedString("anonymous.class", flatname);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1202
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1203
                return fullname.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1204
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1205
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1206
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1207
        public Name getQualifiedName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1208
            return fullname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1209
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1210
06bc494ca11e Initial load
duke
parents:
diff changeset
  1211
        public Name flatName() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1212
            return flatname;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1213
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1214
06bc494ca11e Initial load
duke
parents:
diff changeset
  1215
        public boolean isSubClass(Symbol base, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1216
            if (this == base) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1217
                return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1218
            } else if ((base.flags() & INTERFACE) != 0) {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
  1219
                for (Type t = type; t.hasTag(CLASS); t = types.supertype(t))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1220
                    for (List<Type> is = types.interfaces(t);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1221
                         is.nonEmpty();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1222
                         is = is.tail)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1223
                        if (is.head.tsym.isSubClass(base, types)) return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1224
            } else {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
  1225
                for (Type t = type; t.hasTag(CLASS); t = types.supertype(t))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1226
                    if (t.tsym == base) return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1227
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1228
            return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1229
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1230
06bc494ca11e Initial load
duke
parents:
diff changeset
  1231
        /** Complete the elaboration of this symbol's definition.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1232
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1233
        public void complete() throws CompletionFailure {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1234
            try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1235
                super.complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1236
            } catch (CompletionFailure ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1237
                // quiet error recovery
06bc494ca11e Initial load
duke
parents:
diff changeset
  1238
                flags_field |= (PUBLIC|STATIC);
1257
873b053bf757 6557752: Original type of an AST should be made available even if it is replaced with an ErrorType
jjg
parents: 1045
diff changeset
  1239
                this.type = new ErrorType(this, Type.noType);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1240
                throw ex;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1241
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1242
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1243
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1244
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1245
        public List<Type> getInterfaces() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1246
            complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1247
            if (type instanceof ClassType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1248
                ClassType t = (ClassType)type;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1249
                if (t.interfaces_field == null) // FIXME: shouldn't be null
06bc494ca11e Initial load
duke
parents:
diff changeset
  1250
                    t.interfaces_field = List.nil();
8625
6b51ef804d49 6639645: Modeling type implementing missing interfaces
jjg
parents: 8427
diff changeset
  1251
                if (t.all_interfaces_field != null)
6b51ef804d49 6639645: Modeling type implementing missing interfaces
jjg
parents: 8427
diff changeset
  1252
                    return Type.getModelTypes(t.all_interfaces_field);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1253
                return t.interfaces_field;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1254
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1255
                return List.nil();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1256
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1257
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1258
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1259
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1260
        public Type getSuperclass() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1261
            complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1262
            if (type instanceof ClassType) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1263
                ClassType t = (ClassType)type;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1264
                if (t.supertype_field == null) // FIXME: shouldn't be null
06bc494ca11e Initial load
duke
parents:
diff changeset
  1265
                    t.supertype_field = Type.noType;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1266
                // An interface has no superclass; its supertype is Object.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1267
                return t.isInterface()
06bc494ca11e Initial load
duke
parents:
diff changeset
  1268
                    ? Type.noType
8625
6b51ef804d49 6639645: Modeling type implementing missing interfaces
jjg
parents: 8427
diff changeset
  1269
                    : t.supertype_field.getModelType();
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1270
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1271
                return Type.noType;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1272
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1273
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1274
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1275
        /**
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1276
         * Returns the next class to search for inherited annotations or {@code null}
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1277
         * if the next class can't be found.
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1278
         */
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1279
        private ClassSymbol getSuperClassToSearchForAnnotations() {
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1280
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1281
            Type sup = getSuperclass();
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1282
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1283
            if (!sup.hasTag(CLASS) || sup.isErroneous())
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1284
                return null;
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1285
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1286
            return (ClassSymbol) sup.tsym;
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1287
        }
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1288
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1289
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1290
        @Override
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1291
        protected <A extends Annotation> A[] getInheritedAnnotations(Class<A> annoType) {
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1292
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1293
            ClassSymbol sup = getSuperClassToSearchForAnnotations();
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1294
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1295
            return sup == null ? super.getInheritedAnnotations(annoType)
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1296
                               : sup.getAnnotationsByType(annoType);
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1297
        }
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1298
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1299
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1300
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1301
        public ElementKind getKind() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1302
            long flags = flags();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1303
            if ((flags & ANNOTATION) != 0)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1304
                return ElementKind.ANNOTATION_TYPE;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1305
            else if ((flags & INTERFACE) != 0)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1306
                return ElementKind.INTERFACE;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1307
            else if ((flags & ENUM) != 0)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1308
                return ElementKind.ENUM;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1309
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1310
                return ElementKind.CLASS;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1311
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1312
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1313
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
20610
81a202481805 8025118: Annotation processing api returns default modifier for interface without default methods
jlahoda
parents: 20598
diff changeset
  1314
        public Set<Modifier> getModifiers() {
81a202481805 8025118: Annotation processing api returns default modifier for interface without default methods
jlahoda
parents: 20598
diff changeset
  1315
            long flags = flags();
81a202481805 8025118: Annotation processing api returns default modifier for interface without default methods
jlahoda
parents: 20598
diff changeset
  1316
            return Flags.asModifierSet(flags & ~DEFAULT);
81a202481805 8025118: Annotation processing api returns default modifier for interface without default methods
jlahoda
parents: 20598
diff changeset
  1317
        }
81a202481805 8025118: Annotation processing api returns default modifier for interface without default methods
jlahoda
parents: 20598
diff changeset
  1318
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1319
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1320
        public NestingKind getNestingKind() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1321
            complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1322
            if (owner.kind == PCK)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1323
                return NestingKind.TOP_LEVEL;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1324
            else if (name.isEmpty())
06bc494ca11e Initial load
duke
parents:
diff changeset
  1325
                return NestingKind.ANONYMOUS;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1326
            else if (owner.kind == MTH)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1327
                return NestingKind.LOCAL;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1328
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1329
                return NestingKind.MEMBER;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1330
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1331
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1332
16557
67a3ae363f03 8007803: Implement javax.lang.model API for Type Annotations
jjg
parents: 16333
diff changeset
  1333
        @Override
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1334
        protected <A extends Annotation> Attribute.Compound getAttribute(final Class<A> annoType) {
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1335
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1336
            Attribute.Compound attrib = super.getAttribute(annoType);
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1337
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1338
            boolean inherited = annoType.isAnnotationPresent(Inherited.class);
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1339
            if (attrib != null || !inherited)
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1340
                return attrib;
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1341
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1342
            // Search supertypes
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1343
            ClassSymbol superType = getSuperClassToSearchForAnnotations();
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1344
            return superType == null ? null
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1345
                                     : superType.getAttribute(annoType);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1346
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1347
21007
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1348
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1349
484c9d902861 8021237: clean up JavacAnnotatedConstruct
alundblad
parents: 20610
diff changeset
  1350
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1351
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1352
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1353
            return v.visitType(this, p);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1354
        }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1355
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1356
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1357
            return v.visitClassSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1358
        }
23810
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1359
28459
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1360
        public void markAbstractIfNeeded(Types types) {
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1361
            if (types.enter.getEnv(this) != null &&
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1362
                (flags() & ENUM) != 0 && types.supertype(type).tsym == types.syms.enumSym &&
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1363
                (flags() & (FINAL | ABSTRACT)) == 0) {
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1364
                if (types.firstUnimplementedAbstract(this) != null)
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1365
                    // add the ABSTRACT flag to an enum
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1366
                    flags_field |= ABSTRACT;
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1367
            }
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1368
        }
48a68a485760 8068517: Compiler may generate wrong InnerClasses attribute for static enum reference
jlahoda
parents: 27224
diff changeset
  1369
23810
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1370
        /**Resets the Symbol into the state good for next round of annotation processing.*/
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1371
        public void reset() {
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1372
            kind = TYP;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1373
            erasure_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1374
            members_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1375
            flags_field = 0;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1376
            if (type instanceof ClassType) {
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1377
                ClassType t = (ClassType)type;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1378
                t.setEnclosingType(Type.noType);
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1379
                t.rank_field = -1;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1380
                t.typarams_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1381
                t.allparams_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1382
                t.supertype_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1383
                t.interfaces_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1384
                t.all_interfaces_field = null;
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1385
            }
39372
a42db8c180c3 8132446: AsssertionError in ClassSymbol.setAnnotationType
sadayapalam
parents: 37848
diff changeset
  1386
            clearAnnotationMetadata();
a42db8c180c3 8132446: AsssertionError in ClassSymbol.setAnnotationType
sadayapalam
parents: 37848
diff changeset
  1387
        }
a42db8c180c3 8132446: AsssertionError in ClassSymbol.setAnnotationType
sadayapalam
parents: 37848
diff changeset
  1388
a42db8c180c3 8132446: AsssertionError in ClassSymbol.setAnnotationType
sadayapalam
parents: 37848
diff changeset
  1389
        public void clearAnnotationMetadata() {
23810
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1390
            metadata = null;
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1391
            annotationTypeMetadata = AnnotationTypeMetadata.notAnAnnotationType();
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1392
        }
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1393
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1394
        @Override
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1395
        public AnnotationTypeMetadata getAnnotationTypeMetadata() {
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1396
            return annotationTypeMetadata;
23810
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1397
        }
b92eb80925f0 8038455: Use single Context for all rounds of annotation processing
jlahoda
parents: 23396
diff changeset
  1398
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1399
        @Override
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1400
        public boolean isAnnotationType() {
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1401
            return (flags_field & Flags.ANNOTATION) != 0;
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1402
        }
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1403
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1404
        public void setAnnotationTypeMetadata(AnnotationTypeMetadata a) {
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1405
            Assert.checkNonNull(a);
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1406
            Assert.check(!annotationTypeMetadata.isMetadataForAnnotationType());
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1407
            this.annotationTypeMetadata = a;
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1408
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1409
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1410
06bc494ca11e Initial load
duke
parents:
diff changeset
  1411
06bc494ca11e Initial load
duke
parents:
diff changeset
  1412
    /** A class for variable symbols
06bc494ca11e Initial load
duke
parents:
diff changeset
  1413
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1414
    public static class VarSymbol extends Symbol implements VariableElement {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1415
06bc494ca11e Initial load
duke
parents:
diff changeset
  1416
        /** The variable's declaration position.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1417
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1418
        public int pos = Position.NOPOS;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1419
06bc494ca11e Initial load
duke
parents:
diff changeset
  1420
        /** The variable's address. Used for different purposes during
06bc494ca11e Initial load
duke
parents:
diff changeset
  1421
         *  flow analysis, translation and code generation.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1422
         *  Flow analysis:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1423
         *    If this is a blank final or local variable, its sequence number.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1424
         *  Translation:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1425
         *    If this is a private field, its access number.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1426
         *  Code generation:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1427
         *    If this is a local variable, its logical slot number.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1428
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1429
        public int adr = -1;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1430
06bc494ca11e Initial load
duke
parents:
diff changeset
  1431
        /** Construct a variable symbol, given its flags, name, type and owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1432
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1433
        public VarSymbol(long flags, Name name, Type type, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1434
            super(VAR, flags, name, type, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1435
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1436
06bc494ca11e Initial load
duke
parents:
diff changeset
  1437
        /** Clone this symbol with new owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1438
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1439
        public VarSymbol clone(Symbol newOwner) {
14062
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1440
            VarSymbol v = new VarSymbol(flags_field, name, type, newOwner) {
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1441
                @Override
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1442
                public Symbol baseSymbol() {
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1443
                    return VarSymbol.this;
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1444
                }
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1445
            };
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1446
            v.pos = pos;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1447
            v.adr = adr;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1448
            v.data = data;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1449
//          System.out.println("clone " + v + " in " + newOwner);//DEBUG
06bc494ca11e Initial load
duke
parents:
diff changeset
  1450
            return v;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1451
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1452
06bc494ca11e Initial load
duke
parents:
diff changeset
  1453
        public String toString() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1454
            return name.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1455
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1456
06bc494ca11e Initial load
duke
parents:
diff changeset
  1457
        public Symbol asMemberOf(Type site, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1458
            return new VarSymbol(flags_field, name, types.memberType(site, this), owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1459
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1460
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1461
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1462
        public ElementKind getKind() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1463
            long flags = flags();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1464
            if ((flags & PARAMETER) != 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1465
                if (isExceptionParameter())
06bc494ca11e Initial load
duke
parents:
diff changeset
  1466
                    return ElementKind.EXCEPTION_PARAMETER;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1467
                else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1468
                    return ElementKind.PARAMETER;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1469
            } else if ((flags & ENUM) != 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1470
                return ElementKind.ENUM_CONSTANT;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1471
            } else if (owner.kind == TYP || owner.kind == ERR) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1472
                return ElementKind.FIELD;
6718
56ed1962d369 6967842: Element not returned from tree API for ARM resource variables.
sundar
parents: 6592
diff changeset
  1473
            } else if (isResourceVariable()) {
56ed1962d369 6967842: Element not returned from tree API for ARM resource variables.
sundar
parents: 6592
diff changeset
  1474
                return ElementKind.RESOURCE_VARIABLE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1475
            } else {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1476
                return ElementKind.LOCAL_VARIABLE;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1477
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1478
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1479
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1480
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1481
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1482
            return v.visitVariable(this, p);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1483
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1484
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1485
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1486
        public Object getConstantValue() { // Mirror API
06bc494ca11e Initial load
duke
parents:
diff changeset
  1487
            return Constants.decode(getConstValue(), type);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1488
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1489
06bc494ca11e Initial load
duke
parents:
diff changeset
  1490
        public void setLazyConstValue(final Env<AttrContext> env,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1491
                                      final Attr attr,
19942
e9dae0e41075 8021112: Spurious unchecked warning reported by javac
jlahoda
parents: 19928
diff changeset
  1492
                                      final JCVariableDecl variable)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1493
        {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1494
            setData(new Callable<Object>() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1495
                public Object call() {
19942
e9dae0e41075 8021112: Spurious unchecked warning reported by javac
jlahoda
parents: 19928
diff changeset
  1496
                    return attr.attribLazyConstantValue(env, variable, type);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1497
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1498
            });
06bc494ca11e Initial load
duke
parents:
diff changeset
  1499
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1500
06bc494ca11e Initial load
duke
parents:
diff changeset
  1501
        /**
06bc494ca11e Initial load
duke
parents:
diff changeset
  1502
         * The variable's constant value, if this is a constant.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1503
         * Before the constant value is evaluated, it points to an
19666
01a225608c25 8010310: [javadoc] Error processing sources with -private
jjg
parents: 19657
diff changeset
  1504
         * initializer environment.  If this is not a constant, it can
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1505
         * be used for other stuff.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1506
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1507
        private Object data;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1508
06bc494ca11e Initial load
duke
parents:
diff changeset
  1509
        public boolean isExceptionParameter() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1510
            return data == ElementKind.EXCEPTION_PARAMETER;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1511
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1512
6148
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1513
        public boolean isResourceVariable() {
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1514
            return data == ElementKind.RESOURCE_VARIABLE;
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1515
        }
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1516
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1517
        public Object getConstValue() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1518
            // TODO: Consider if getConstValue and getConstantValue can be collapsed
6148
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1519
            if (data == ElementKind.EXCEPTION_PARAMETER ||
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1520
                data == ElementKind.RESOURCE_VARIABLE) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1521
                return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1522
            } else if (data instanceof Callable<?>) {
6148
3a8158299c51 6911256: Project Coin: Support Automatic Resource Management (ARM) blocks in the compiler
darcy
parents: 5847
diff changeset
  1523
                // In this case, this is a final variable, with an as
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1524
                // yet unevaluated initializer.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1525
                Callable<?> eval = (Callable<?>)data;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1526
                data = null; // to make sure we don't evaluate this twice.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1527
                try {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1528
                    data = eval.call();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1529
                } catch (Exception ex) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1530
                    throw new AssertionError(ex);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1531
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1532
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1533
            return data;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1534
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1535
06bc494ca11e Initial load
duke
parents:
diff changeset
  1536
        public void setData(Object data) {
8032
e1aa25ccdabb 6396503: javac should not require assertions enabled
jjg
parents: 8031
diff changeset
  1537
            Assert.check(!(data instanceof Env<?>), this);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1538
            this.data = data;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1539
        }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1540
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1541
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1542
            return v.visitVarSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1543
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1544
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1545
06bc494ca11e Initial load
duke
parents:
diff changeset
  1546
    /** A class for method symbols.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1547
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1548
    public static class MethodSymbol extends Symbol implements ExecutableElement {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1549
06bc494ca11e Initial load
duke
parents:
diff changeset
  1550
        /** The code of the method. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1551
        public Code code = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1552
15720
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
  1553
        /** The extra (synthetic/mandated) parameters of the method. */
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
  1554
        public List<VarSymbol> extraParams = List.nil();
e61b2f7a5148 8006345: Report Synthesized Parameters in java.lang.reflect.Parameter API
mcimadamore
parents: 15719
diff changeset
  1555
19657
48226ff07b84 8020745: Suspicious MethodParameters attribute generated for local classes capturing local variables
emc
parents: 19492
diff changeset
  1556
        /** The captured local variables in an anonymous class */
48226ff07b84 8020745: Suspicious MethodParameters attribute generated for local classes capturing local variables
emc
parents: 19492
diff changeset
  1557
        public List<VarSymbol> capturedLocals = List.nil();
48226ff07b84 8020745: Suspicious MethodParameters attribute generated for local classes capturing local variables
emc
parents: 19492
diff changeset
  1558
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1559
        /** The parameters of the method. */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1560
        public List<VarSymbol> params = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1561
06bc494ca11e Initial load
duke
parents:
diff changeset
  1562
        /** The names of the parameters */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1563
        public List<Name> savedParameterNames;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1564
29842
826ac2519523 8031744: Annotations on many Language Model elements are not returned
jjg
parents: 28459
diff changeset
  1565
        /** For an annotation type element, its default value if any.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1566
         *  The value is null if none appeared in the method
06bc494ca11e Initial load
duke
parents:
diff changeset
  1567
         *  declaration.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1568
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1569
        public Attribute defaultValue = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1570
06bc494ca11e Initial load
duke
parents:
diff changeset
  1571
        /** Construct a method symbol, given its flags, name, type and owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1572
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1573
        public MethodSymbol(long flags, Name name, Type type, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1574
            super(MTH, flags, name, type, owner);
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
  1575
            if (owner.type.hasTag(TYPEVAR)) Assert.error(owner + "." + name);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1576
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1577
06bc494ca11e Initial load
duke
parents:
diff changeset
  1578
        /** Clone this symbol with new owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1579
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1580
        public MethodSymbol clone(Symbol newOwner) {
14062
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1581
            MethodSymbol m = new MethodSymbol(flags_field, name, type, newOwner) {
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1582
                @Override
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1583
                public Symbol baseSymbol() {
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1584
                    return MethodSymbol.this;
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1585
                }
b7439971a094 7177386: Add attribution support for method references
mcimadamore
parents: 14051
diff changeset
  1586
            };
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1587
            m.code = code;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1588
            return m;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1589
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1590
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1591
        @Override @DefinedBy(Api.LANGUAGE_MODEL)
16970
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
  1592
        public Set<Modifier> getModifiers() {
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
  1593
            long flags = flags();
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
  1594
            return Flags.asModifierSet((flags & DEFAULT) != 0 ? flags & ~ABSTRACT : flags);
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
  1595
        }
0967fa88590b 8011383: Symbol.getModifiers omits ACC_ABSTRACT from interface with default methods
mcimadamore
parents: 16967
diff changeset
  1596
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1597
        /** The Java source which this symbol represents.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1598
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1599
        public String toString() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1600
            if ((flags() & BLOCK) != 0) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1601
                return owner.name.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1602
            } else {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
  1603
                String s = (name == name.table.names.init)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1604
                    ? owner.name.toString()
06bc494ca11e Initial load
duke
parents:
diff changeset
  1605
                    : name.toString();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1606
                if (type != null) {
14359
d4099818ab70 7200915: convert TypeTags from a series of small ints to an enum
jjg
parents: 14258
diff changeset
  1607
                    if (type.hasTag(FORALL))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1608
                        s = "<" + ((ForAll)type).getTypeArguments() + ">" + s;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1609
                    s += "(" + type.argtypes((flags() & VARARGS) != 0) + ")";
06bc494ca11e Initial load
duke
parents:
diff changeset
  1610
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1611
                return s;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1612
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1613
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1614
14046
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1615
        public boolean isDynamic() {
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1616
            return false;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1617
        }
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1618
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1619
        /** find a symbol that this (proxy method) symbol implements.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1620
         *  @param    c       The class whose members are searched for
06bc494ca11e Initial load
duke
parents:
diff changeset
  1621
         *                    implementations
06bc494ca11e Initial load
duke
parents:
diff changeset
  1622
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1623
        public Symbol implemented(TypeSymbol c, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1624
            Symbol impl = null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1625
            for (List<Type> is = types.interfaces(c.type);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1626
                 impl == null && is.nonEmpty();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1627
                 is = is.tail) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1628
                TypeSymbol i = is.head.tsym;
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1629
                impl = implementedIn(i, types);
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1630
                if (impl == null)
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1631
                    impl = implemented(i, types);
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1632
            }
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1633
            return impl;
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1634
        }
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1635
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1636
        public Symbol implementedIn(TypeSymbol c, Types types) {
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1637
            Symbol impl = null;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1638
            for (Symbol sym : c.members().getSymbolsByName(name)) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1639
                if (this.overrides(sym, (TypeSymbol)owner, types, true) &&
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1640
                    // FIXME: I suspect the following requires a
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1641
                    // subst() for a parametric return type.
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 6718
diff changeset
  1642
                    types.isSameType(type.getReturnType(),
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1643
                                     types.memberType(owner.type, sym).getReturnType())) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1644
                    impl = sym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1645
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1646
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1647
            return impl;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1648
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1649
06bc494ca11e Initial load
duke
parents:
diff changeset
  1650
        /** Will the erasure of this method be considered by the VM to
06bc494ca11e Initial load
duke
parents:
diff changeset
  1651
         *  override the erasure of the other when seen from class `origin'?
06bc494ca11e Initial load
duke
parents:
diff changeset
  1652
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1653
        public boolean binaryOverrides(Symbol _other, TypeSymbol origin, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1654
            if (isConstructor() || _other.kind != MTH) return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1655
06bc494ca11e Initial load
duke
parents:
diff changeset
  1656
            if (this == _other) return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1657
            MethodSymbol other = (MethodSymbol)_other;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1658
06bc494ca11e Initial load
duke
parents:
diff changeset
  1659
            // check for a direct implementation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1660
            if (other.isOverridableIn((TypeSymbol)owner) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1661
                types.asSuper(owner.type, other.owner) != null &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1662
                types.isSameType(erasure(types), other.erasure(types)))
06bc494ca11e Initial load
duke
parents:
diff changeset
  1663
                return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1664
06bc494ca11e Initial load
duke
parents:
diff changeset
  1665
            // check for an inherited implementation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1666
            return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1667
                (flags() & ABSTRACT) == 0 &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1668
                other.isOverridableIn(origin) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1669
                this.isMemberOf(origin, types) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1670
                types.isSameType(erasure(types), other.erasure(types));
06bc494ca11e Initial load
duke
parents:
diff changeset
  1671
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1672
06bc494ca11e Initial load
duke
parents:
diff changeset
  1673
        /** The implementation of this (abstract) symbol in class origin,
06bc494ca11e Initial load
duke
parents:
diff changeset
  1674
         *  from the VM's point of view, null if method does not have an
06bc494ca11e Initial load
duke
parents:
diff changeset
  1675
         *  implementation in class.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1676
         *  @param origin   The class of which the implementation is a member.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1677
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1678
        public MethodSymbol binaryImplementation(ClassSymbol origin, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1679
            for (TypeSymbol c = origin; c != null; c = types.supertype(c.type).tsym) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1680
                for (Symbol sym : c.members().getSymbolsByName(name)) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1681
                    if (sym.kind == MTH &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1682
                        ((MethodSymbol)sym).binaryOverrides(this, origin, types))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 25009
diff changeset
  1683
                        return (MethodSymbol)sym;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1684
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1685
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1686
            return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1687
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1688
06bc494ca11e Initial load
duke
parents:
diff changeset
  1689
        /** Does this symbol override `other' symbol, when both are seen as
06bc494ca11e Initial load
duke
parents:
diff changeset
  1690
         *  members of class `origin'?  It is assumed that _other is a member
06bc494ca11e Initial load
duke
parents:
diff changeset
  1691
         *  of origin.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1692
         *
06bc494ca11e Initial load
duke
parents:
diff changeset
  1693
         *  It is assumed that both symbols have the same name.  The static
06bc494ca11e Initial load
duke
parents:
diff changeset
  1694
         *  modifier is ignored for this test.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1695
         *
33367
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1696
         *  A quirk in the works is that if the receiver is a method symbol for
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1697
         *  an inherited abstract method we answer false summarily all else being
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1698
         *  immaterial. Abstract "own" methods (i.e `this' is a direct member of
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1699
         *  origin) don't get rejected as summarily and are put to test against the
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1700
         *  suitable criteria.
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1701
         *
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1702
         *  See JLS 8.4.6.1 (without transitivity) and 8.4.6.4
06bc494ca11e Initial load
duke
parents:
diff changeset
  1703
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1704
        public boolean overrides(Symbol _other, TypeSymbol origin, Types types, boolean checkResult) {
33367
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1705
            return overrides(_other, origin, types, checkResult, true);
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1706
        }
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1707
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1708
        /** Does this symbol override `other' symbol, when both are seen as
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1709
         *  members of class `origin'?  It is assumed that _other is a member
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1710
         *  of origin.
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1711
         *
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1712
         *  Caveat: If `this' is an abstract inherited member of origin, it is
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1713
         *  deemed to override `other' only when `requireConcreteIfInherited'
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1714
         *  is false.
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1715
         *
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1716
         *  It is assumed that both symbols have the same name.  The static
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1717
         *  modifier is ignored for this test.
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1718
         *
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1719
         *  See JLS 8.4.6.1 (without transitivity) and 8.4.6.4
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1720
         */
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1721
        public boolean overrides(Symbol _other, TypeSymbol origin, Types types, boolean checkResult,
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1722
                                            boolean requireConcreteIfInherited) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1723
            if (isConstructor() || _other.kind != MTH) return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1724
06bc494ca11e Initial load
duke
parents:
diff changeset
  1725
            if (this == _other) return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1726
            MethodSymbol other = (MethodSymbol)_other;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1727
06bc494ca11e Initial load
duke
parents:
diff changeset
  1728
            // check for a direct implementation
06bc494ca11e Initial load
duke
parents:
diff changeset
  1729
            if (other.isOverridableIn((TypeSymbol)owner) &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1730
                types.asSuper(owner.type, other.owner) != null) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1731
                Type mt = types.memberType(owner.type, this);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1732
                Type ot = types.memberType(owner.type, other);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1733
                if (types.isSubSignature(mt, ot)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1734
                    if (!checkResult)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1735
                        return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1736
                    if (types.returnTypeSubstitutable(mt, ot))
06bc494ca11e Initial load
duke
parents:
diff changeset
  1737
                        return true;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1738
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1739
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1740
06bc494ca11e Initial load
duke
parents:
diff changeset
  1741
            // check for an inherited implementation
33367
546ffcb790a5 8074803: Name clash
sadayapalam
parents: 33364
diff changeset
  1742
            if (((flags() & ABSTRACT) != 0 && requireConcreteIfInherited) ||
14547
86d8d242b0c4 8003280: Add lambda tests
mcimadamore
parents: 14443
diff changeset
  1743
                    ((other.flags() & ABSTRACT) == 0 && (other.flags() & DEFAULT) == 0) ||
14443
91c05eb19277 7192246: Add type-checking support for default methods
mcimadamore
parents: 14359
diff changeset
  1744
                    !other.isOverridableIn(origin) ||
91c05eb19277 7192246: Add type-checking support for default methods
mcimadamore
parents: 14359
diff changeset
  1745
                    !this.isMemberOf(origin, types))
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1746
                return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1747
06bc494ca11e Initial load
duke
parents:
diff changeset
  1748
            // assert types.asSuper(origin.type, other.owner) != null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1749
            Type mt = types.memberType(origin.type, this);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1750
            Type ot = types.memberType(origin.type, other);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1751
            return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1752
                types.isSubSignature(mt, ot) &&
14547
86d8d242b0c4 8003280: Add lambda tests
mcimadamore
parents: 14443
diff changeset
  1753
                (!checkResult || types.resultSubtype(mt, ot, types.noWarnings));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1754
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1755
06bc494ca11e Initial load
duke
parents:
diff changeset
  1756
        private boolean isOverridableIn(TypeSymbol origin) {
9303
eae35c201e19 7032975: API files in javax.annotation.processing need to be updated for references to JLS
jjh
parents: 8625
diff changeset
  1757
            // JLS 8.4.6.1
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1758
            switch ((int)(flags_field & Flags.AccessFlags)) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1759
            case Flags.PRIVATE:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1760
                return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1761
            case Flags.PUBLIC:
15377
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1762
                return !this.owner.isInterface() ||
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1763
                        (flags_field & STATIC) == 0;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1764
            case Flags.PROTECTED:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1765
                return (origin.flags() & INTERFACE) == 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1766
            case 0:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1767
                // for package private: can only override in the same
06bc494ca11e Initial load
duke
parents:
diff changeset
  1768
                // package
06bc494ca11e Initial load
duke
parents:
diff changeset
  1769
                return
06bc494ca11e Initial load
duke
parents:
diff changeset
  1770
                    this.packge() == origin.packge() &&
06bc494ca11e Initial load
duke
parents:
diff changeset
  1771
                    (origin.flags() & INTERFACE) == 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1772
            default:
06bc494ca11e Initial load
duke
parents:
diff changeset
  1773
                return false;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1774
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1775
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1776
15377
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1777
        @Override
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1778
        public boolean isInheritedIn(Symbol clazz, Types types) {
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1779
            switch ((int)(flags_field & Flags.AccessFlags)) {
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1780
                case PUBLIC:
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1781
                    return !this.owner.isInterface() ||
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1782
                            clazz == owner ||
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1783
                            (flags_field & STATIC) == 0;
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1784
                default:
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1785
                    return super.isInheritedIn(clazz, types);
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1786
            }
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1787
        }
515846bb6637 8005166: Add support for static interface methods
mcimadamore
parents: 15355
diff changeset
  1788
33364
542040bb5990 8138729: javac -parameters should not emit parameter names for lambda expressions
sadayapalam
parents: 30066
diff changeset
  1789
        public boolean isLambdaMethod() {
542040bb5990 8138729: javac -parameters should not emit parameter names for lambda expressions
sadayapalam
parents: 30066
diff changeset
  1790
            return (flags() & LAMBDA_METHOD) == LAMBDA_METHOD;
542040bb5990 8138729: javac -parameters should not emit parameter names for lambda expressions
sadayapalam
parents: 30066
diff changeset
  1791
        }
542040bb5990 8138729: javac -parameters should not emit parameter names for lambda expressions
sadayapalam
parents: 30066
diff changeset
  1792
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1793
        /** The implementation of this (abstract) symbol in class origin;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1794
         *  null if none exists. Synthetic methods are not considered
06bc494ca11e Initial load
duke
parents:
diff changeset
  1795
         *  as possible implementations.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1796
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1797
        public MethodSymbol implementation(TypeSymbol origin, Types types, boolean checkResult) {
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1798
            return implementation(origin, types, checkResult, implementation_filter);
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1799
        }
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1800
        // where
16320
92ba27b7aaf3 8008436: javac should not issue a warning for overriding equals without hasCode if hashCode has been overriden by a superclass
vromero
parents: 15720
diff changeset
  1801
            public static final Filter<Symbol> implementation_filter = new Filter<Symbol>() {
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1802
                public boolean accepts(Symbol s) {
27224
228abfa87080 8054457: Refactor Symbol kinds from small ints to an enum
emc
parents: 26781
diff changeset
  1803
                    return s.kind == MTH &&
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1804
                            (s.flags() & SYNTHETIC) == 0;
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1805
                }
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1806
            };
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1807
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 6584
diff changeset
  1808
        public MethodSymbol implementation(TypeSymbol origin, Types types, boolean checkResult, Filter<Symbol> implFilter) {
8242
3873b4aaf4a8 7007615: java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123.
mcimadamore
parents: 8225
diff changeset
  1809
            MethodSymbol res = types.implementation(this, origin, checkResult, implFilter);
3539
3c265cb6f4e0 6827648: Extremely slow compilation time for visitor pattern code + generics
mcimadamore
parents: 3149
diff changeset
  1810
            if (res != null)
3c265cb6f4e0 6827648: Extremely slow compilation time for visitor pattern code + generics
mcimadamore
parents: 3149
diff changeset
  1811
                return res;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1812
            // if origin is derived from a raw type, we might have missed
06bc494ca11e Initial load
duke
parents:
diff changeset
  1813
            // an implementation because we do not know enough about instantiations.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1814
            // in this case continue with the supertype as origin.
12083
c9d98f7e59e8 7148556: Implementing a generic interface causes a public clone() to become inaccessible
mcimadamore
parents: 10627
diff changeset
  1815
            if (types.isDerivedRaw(origin.type) && !origin.isInterface())
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1816
                return implementation(types.supertype(origin.type).tsym, types, checkResult);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1817
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1818
                return null;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1819
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1820
06bc494ca11e Initial load
duke
parents:
diff changeset
  1821
        public List<VarSymbol> params() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1822
            owner.complete();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1823
            if (params == null) {
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1824
                // If ClassReader.saveParameterNames has been set true, then
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1825
                // savedParameterNames will be set to a list of names that
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1826
                // matches the types in type.getParameterTypes().  If any names
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1827
                // were not found in the class file, those names in the list will
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1828
                // be set to the empty name.
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1829
                // If ClassReader.saveParameterNames has been set false, then
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1830
                // savedParameterNames will be null.
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1831
                List<Name> paramNames = savedParameterNames;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1832
                savedParameterNames = null;
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1833
                // discard the provided names if the list of names is the wrong size.
15031
c4fad55a5681 8004727: Add compiler support for parameter reflection
jjg
parents: 14961
diff changeset
  1834
                if (paramNames == null || paramNames.size() != type.getParameterTypes().size()) {
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1835
                    paramNames = List.nil();
15031
c4fad55a5681 8004727: Add compiler support for parameter reflection
jjg
parents: 14961
diff changeset
  1836
                }
22163
3651128c74eb 8030244: Update langtools to use Diamond
briangoetz
parents: 21480
diff changeset
  1837
                ListBuffer<VarSymbol> buf = new ListBuffer<>();
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1838
                List<Name> remaining = paramNames;
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1839
                // assert: remaining and paramNames are both empty or both
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1840
                // have same cardinality as type.getParameterTypes()
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1841
                int i = 0;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1842
                for (Type t : type.getParameterTypes()) {
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1843
                    Name paramName;
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1844
                    if (remaining.isEmpty()) {
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1845
                        // no names for any parameters available
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1846
                        paramName = createArgName(i, paramNames);
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1847
                    } else {
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1848
                        paramName = remaining.head;
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1849
                        remaining = remaining.tail;
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1850
                        if (paramName.isEmpty()) {
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1851
                            // no name for this specific parameter
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1852
                            paramName = createArgName(i, paramNames);
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1853
                        }
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1854
                    }
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1855
                    buf.append(new VarSymbol(PARAMETER, paramName, t, this));
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1856
                    i++;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1857
                }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1858
                params = buf.toList();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1859
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1860
            return params;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1861
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1862
4077
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1863
        // Create a name for the argument at position 'index' that is not in
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1864
        // the exclude list. In normal use, either no names will have been
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1865
        // provided, in which case the exclude list is empty, or all the names
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1866
        // will have been provided, in which case this method will not be called.
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1867
        private Name createArgName(int index, List<Name> exclude) {
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1868
            String prefix = "arg";
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1869
            while (true) {
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1870
                Name argName = name.table.fromString(prefix + index);
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1871
                if (!exclude.contains(argName))
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1872
                    return argName;
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1873
                prefix += "$";
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1874
            }
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1875
        }
0096541a388e 6889255: javac MethodSymbol throws NPE if ClassReader does not read parameter names correctly
jjg
parents: 3539
diff changeset
  1876
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1877
        public Symbol asMemberOf(Type site, Types types) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1878
            return new MethodSymbol(flags_field, name, types.memberType(site, this), owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1879
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1880
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1881
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1882
        public ElementKind getKind() {
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
  1883
            if (name == name.table.names.init)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1884
                return ElementKind.CONSTRUCTOR;
1260
a772ba9ba43d 6574134: Allow for alternative implementation of Name Table with garbage collection of name bytes
jjg
parents: 1257
diff changeset
  1885
            else if (name == name.table.names.clinit)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1886
                return ElementKind.STATIC_INIT;
10626
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1887
            else if ((flags() & BLOCK) != 0)
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1888
                return isStatic() ? ElementKind.STATIC_INIT : ElementKind.INSTANCE_INIT;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1889
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1890
                return ElementKind.METHOD;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1891
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1892
10626
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1893
        public boolean isStaticOrInstanceInit() {
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1894
            return getKind() == ElementKind.STATIC_INIT ||
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1895
                    getKind() == ElementKind.INSTANCE_INIT;
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1896
        }
83f0c2860f5b 7086595: Error message bug: name of initializer is 'null'
mcimadamore
parents: 9812
diff changeset
  1897
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1898
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1899
        public Attribute getDefaultValue() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1900
            return defaultValue;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1901
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1902
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1903
        @DefinedBy(Api.LANGUAGE_MODEL)
15385
ee1eebe7e210 8006775: JSR 308: Compiler changes in JDK8
jjg
parents: 15377
diff changeset
  1904
        public List<VarSymbol> getParameters() {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1905
            return params();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1906
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1907
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1908
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1909
        public boolean isVarArgs() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1910
            return (flags() & VARARGS) != 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1911
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1912
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1913
        @DefinedBy(Api.LANGUAGE_MODEL)
14956
185bd7c693d8 8005046: Provide checking for a default method in javax.lang.model
darcy
parents: 14547
diff changeset
  1914
        public boolean isDefault() {
185bd7c693d8 8005046: Provide checking for a default method in javax.lang.model
darcy
parents: 14547
diff changeset
  1915
            return (flags() & DEFAULT) != 0;
185bd7c693d8 8005046: Provide checking for a default method in javax.lang.model
darcy
parents: 14547
diff changeset
  1916
        }
185bd7c693d8 8005046: Provide checking for a default method in javax.lang.model
darcy
parents: 14547
diff changeset
  1917
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1918
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1919
        public <R, P> R accept(ElementVisitor<R, P> v, P p) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1920
            return v.visitExecutable(this, p);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1921
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1922
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1923
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1924
            return v.visitMethodSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1925
        }
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1926
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1927
        @DefinedBy(Api.LANGUAGE_MODEL)
16557
67a3ae363f03 8007803: Implement javax.lang.model API for Type Annotations
jjg
parents: 16333
diff changeset
  1928
        public Type getReceiverType() {
67a3ae363f03 8007803: Implement javax.lang.model API for Type Annotations
jjg
parents: 16333
diff changeset
  1929
            return asType().getReceiverType();
67a3ae363f03 8007803: Implement javax.lang.model API for Type Annotations
jjg
parents: 16333
diff changeset
  1930
        }
67a3ae363f03 8007803: Implement javax.lang.model API for Type Annotations
jjg
parents: 16333
diff changeset
  1931
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1932
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1933
        public Type getReturnType() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1934
            return asType().getReturnType();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1935
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1936
26266
2d24bda701dc 8056061: Mark implementations of public interfaces with an annotation
jlahoda
parents: 25874
diff changeset
  1937
        @DefinedBy(Api.LANGUAGE_MODEL)
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1938
        public List<Type> getThrownTypes() {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1939
            return asType().getThrownTypes();
06bc494ca11e Initial load
duke
parents:
diff changeset
  1940
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1941
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1942
14046
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1943
    /** A class for invokedynamic method calls.
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1944
     */
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1945
    public static class DynamicMethodSymbol extends MethodSymbol {
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1946
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1947
        public Object[] staticArgs;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1948
        public Symbol bsm;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1949
        public int bsmKind;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1950
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1951
        public DynamicMethodSymbol(Name name, Symbol owner, int bsmKind, MethodSymbol bsm, Type type, Object[] staticArgs) {
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1952
            super(0, name, type, owner);
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1953
            this.bsm = bsm;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1954
            this.bsmKind = bsmKind;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1955
            this.staticArgs = staticArgs;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1956
        }
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1957
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1958
        @Override
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1959
        public boolean isDynamic() {
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1960
            return true;
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1961
        }
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1962
    }
8ef5d5b19998 7194586: Add back-end support for invokedynamic
mcimadamore
parents: 13689
diff changeset
  1963
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1964
    /** A class for predefined operators.
06bc494ca11e Initial load
duke
parents:
diff changeset
  1965
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  1966
    public static class OperatorSymbol extends MethodSymbol {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1967
06bc494ca11e Initial load
duke
parents:
diff changeset
  1968
        public int opcode;
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1969
        private int accessCode = Integer.MIN_VALUE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1970
06bc494ca11e Initial load
duke
parents:
diff changeset
  1971
        public OperatorSymbol(Name name, Type type, int opcode, Symbol owner) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1972
            super(PUBLIC | STATIC, name, type, owner);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1973
            this.opcode = opcode;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1974
        }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1975
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1976
        @Override
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1977
        public <R, P> R accept(Symbol.Visitor<R, P> v, P p) {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1978
            return v.visitOperatorSymbol(this, p);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  1979
        }
39920
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1980
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1981
        public int getAccessCode(Tag tag) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1982
            if (accessCode != Integer.MIN_VALUE && !tag.isIncOrDecUnaryOp()) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1983
                return accessCode;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1984
            }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1985
            accessCode = AccessCode.from(tag, opcode);
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1986
            return accessCode;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1987
        }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1988
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1989
        /** Access codes for dereferencing, assignment,
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1990
         *  and pre/post increment/decrement.
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1991
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1992
         *  All access codes for accesses to the current class are even.
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1993
         *  If a member of the superclass should be accessed instead (because
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1994
         *  access was via a qualified super), add one to the corresponding code
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1995
         *  for the current class, making the number odd.
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1996
         *  This numbering scheme is used by the backend to decide whether
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1997
         *  to issue an invokevirtual or invokespecial call.
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1998
         *
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  1999
         *  @see Gen#visitSelect(JCFieldAccess tree)
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2000
         */
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2001
        public enum AccessCode {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2002
            UNKNOWN(-1, Tag.NO_TAG),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2003
            DEREF(0, Tag.NO_TAG),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2004
            ASSIGN(2, Tag.ASSIGN),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2005
            PREINC(4, Tag.PREINC),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2006
            PREDEC(6, Tag.PREDEC),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2007
            POSTINC(8, Tag.POSTINC),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2008
            POSTDEC(10, Tag.POSTDEC),
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2009
            FIRSTASGOP(12, Tag.NO_TAG);
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2010
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2011
            public final int code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2012
            public final Tag tag;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2013
            public static final int numberOfAccessCodes = (lushrl - ishll + lxor + 2 - iadd) * 2 + FIRSTASGOP.code + 2;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2014
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2015
            AccessCode(int code, Tag tag) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2016
                this.code = code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2017
                this.tag = tag;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2018
            }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2019
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2020
            static public AccessCode getFromCode(int code) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2021
                for (AccessCode aCodes : AccessCode.values()) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2022
                    if (aCodes.code == code) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2023
                        return aCodes;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2024
                    }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2025
                }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2026
                return UNKNOWN;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2027
            }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2028
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2029
            static int from(Tag tag, int opcode) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2030
                /** Map bytecode of binary operation to access code of corresponding
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2031
                *  assignment operation. This is always an even number.
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2032
                */
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2033
                switch (tag) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2034
                    case PREINC:
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2035
                        return AccessCode.PREINC.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2036
                    case PREDEC:
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2037
                        return AccessCode.PREDEC.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2038
                    case POSTINC:
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2039
                        return AccessCode.POSTINC.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2040
                    case POSTDEC:
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2041
                        return AccessCode.POSTDEC.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2042
                }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2043
                if (iadd <= opcode && opcode <= lxor) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2044
                    return (opcode - iadd) * 2 + FIRSTASGOP.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2045
                } else if (opcode == string_add) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2046
                    return (lxor + 1 - iadd) * 2 + FIRSTASGOP.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2047
                } else if (ishll <= opcode && opcode <= lushrl) {
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2048
                    return (opcode - ishll + lxor + 2 - iadd) * 2 + FIRSTASGOP.code;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2049
                }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2050
                return -1;
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2051
            }
4923274643f2 8161708: javac, consider a different way to handle access code for operators
vromero
parents: 39372
diff changeset
  2052
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2053
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2054
06bc494ca11e Initial load
duke
parents:
diff changeset
  2055
    /** Symbol completer interface.
06bc494ca11e Initial load
duke
parents:
diff changeset
  2056
     */
06bc494ca11e Initial load
duke
parents:
diff changeset
  2057
    public static interface Completer {
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2058
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2059
        /** Dummy completer to be used when the symbol has been completed or
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2060
         * does not need completion.
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2061
         */
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2062
        public final static Completer NULL_COMPLETER = new Completer() {
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2063
            public void complete(Symbol sym) { }
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2064
            public boolean isTerminal() { return true; }
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2065
        };
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2066
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2067
        void complete(Symbol sym) throws CompletionFailure;
30066
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2068
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2069
        /** Returns true if this completer is <em>terminal</em>. A terminal
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2070
         * completer is used as a place holder when the symbol is completed.
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2071
         * Calling complete on a terminal completer will not affect the symbol.
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2072
         *
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2073
         * The dummy NULL_COMPLETER and the GraphDependencies completer are
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2074
         * examples of terminal completers.
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2075
         *
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2076
         * @return true iff this completer is terminal
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2077
         */
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2078
        default boolean isTerminal() {
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2079
            return false;
d74c06a92bd8 8078600: Infinite loop when compiling annotations with -XDcompletionDeps
alundblad
parents: 29842
diff changeset
  2080
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2081
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2082
06bc494ca11e Initial load
duke
parents:
diff changeset
  2083
    public static class CompletionFailure extends RuntimeException {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2084
        private static final long serialVersionUID = 0;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2085
        public Symbol sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2086
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2087
        /** A diagnostic object describing the failure
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2088
         */
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2089
        public JCDiagnostic diag;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2090
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2091
        /** A localized string describing the failure.
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2092
         * @deprecated Use {@code getDetail()} or {@code getMessage()}
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2093
         */
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2094
        @Deprecated
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2095
        public String errmsg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2096
06bc494ca11e Initial load
duke
parents:
diff changeset
  2097
        public CompletionFailure(Symbol sym, String errmsg) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2098
            this.sym = sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2099
            this.errmsg = errmsg;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2100
//          this.printStackTrace();//DEBUG
06bc494ca11e Initial load
duke
parents:
diff changeset
  2101
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2102
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2103
        public CompletionFailure(Symbol sym, JCDiagnostic diag) {
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2104
            this.sym = sym;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2105
            this.diag = diag;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2106
//          this.printStackTrace();//DEBUG
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2107
        }
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2108
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2109
        public JCDiagnostic getDiagnostic() {
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2110
            return diag;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2111
        }
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2112
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2113
        @Override
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2114
        public String getMessage() {
169
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2115
            if (diag != null)
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2116
                return diag.getMessage(null);
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2117
            else
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2118
                return errmsg;
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2119
        }
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2120
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2121
        public Object getDetailValue() {
ff76730e430e 6668794: javac puts localized text in raw diagnostics
jjg
parents: 10
diff changeset
  2122
            return (diag != null ? diag : errmsg);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2123
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2124
06bc494ca11e Initial load
duke
parents:
diff changeset
  2125
        @Override
06bc494ca11e Initial load
duke
parents:
diff changeset
  2126
        public CompletionFailure initCause(Throwable cause) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  2127
            super.initCause(cause);
06bc494ca11e Initial load
duke
parents:
diff changeset
  2128
            return this;
06bc494ca11e Initial load
duke
parents:
diff changeset
  2129
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  2130
06bc494ca11e Initial load
duke
parents:
diff changeset
  2131
    }
1357
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2132
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2133
    /**
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2134
     * A visitor for symbols.  A visitor is used to implement operations
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2135
     * (or relations) on symbols.  Most common operations on types are
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2136
     * binary relations and this interface is designed for binary
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2137
     * relations, that is, operations on the form
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2138
     * Symbol&nbsp;&times;&nbsp;P&nbsp;&rarr;&nbsp;R.
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2139
     * <!-- In plain text: Type x P -> R -->
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2140
     *
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2141
     * @param <R> the return type of the operation implemented by this
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2142
     * visitor; use Void if no return type is needed.
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2143
     * @param <P> the type of the second argument (the first being the
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2144
     * symbol itself) of the operation implemented by this visitor; use
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2145
     * Void if a second argument is not needed.
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2146
     */
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2147
    public interface Visitor<R,P> {
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2148
        R visitClassSymbol(ClassSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2149
        R visitMethodSymbol(MethodSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2150
        R visitPackageSymbol(PackageSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2151
        R visitOperatorSymbol(OperatorSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2152
        R visitVarSymbol(VarSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2153
        R visitTypeSymbol(TypeSymbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2154
        R visitSymbol(Symbol s, P arg);
e2d4f3e1f805 6735840: Need a type/symbol visitor printer
mcimadamore
parents: 1260
diff changeset
  2155
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  2156
}