langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Scope.java
author mcimadamore
Fri, 16 Dec 2016 15:27:34 +0000
changeset 42827 36468b5fa7f4
parent 42407 f3702cff2933
child 42828 cce89649f958
permissions -rw-r--r--
8181370: Convert anonymous inner classes into lambdas/method references Reviewed-by: jjg, rfield, mchung
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
42407
f3702cff2933 8169069: Module system implementation refresh (11/2016)
alanb
parents: 41991
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: 1264
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: 1264
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: 1264
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1264
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
86e4b9a9da40 6943119: Rebrand source copyright notices
ohair
parents: 1264
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
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    28
import com.sun.tools.javac.code.Kinds.Kind;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
    29
import java.lang.ref.WeakReference;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    30
import java.util.*;
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
    31
import java.util.function.BiConsumer;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
    32
import java.util.stream.Stream;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
    33
import java.util.stream.StreamSupport;
14258
8d2148961366 8000663: clean up langtools imports
jjg
parents: 9593
diff changeset
    34
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
    35
import com.sun.tools.javac.code.Symbol.CompletionFailure;
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    36
import com.sun.tools.javac.code.Symbol.TypeSymbol;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    37
import com.sun.tools.javac.tree.JCTree.JCImport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    38
import com.sun.tools.javac.util.*;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    39
import com.sun.tools.javac.util.List;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    40
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    41
import static com.sun.tools.javac.code.Scope.LookupKind.NON_RECURSIVE;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    42
import static com.sun.tools.javac.code.Scope.LookupKind.RECURSIVE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    43
06bc494ca11e Initial load
duke
parents:
diff changeset
    44
/** A scope represents an area of visibility in a Java program. The
06bc494ca11e Initial load
duke
parents:
diff changeset
    45
 *  Scope class is a container for symbols which provides
06bc494ca11e Initial load
duke
parents:
diff changeset
    46
 *  efficient access to symbols given their names. Scopes are implemented
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
    47
 *  as hash tables with "open addressing" and "double hashing".
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    48
 *  Scopes can be nested. Nested scopes can share their hash tables.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
 *
5847
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    50
 *  <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
    51
 *  If you write code that depends on this, you do so at your own risk.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    52
 *  This code and its internal interfaces are subject to change or
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
 *  deletion without notice.</b>
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
 */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    55
public abstract class Scope {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    56
06bc494ca11e Initial load
duke
parents:
diff changeset
    57
    /** The scope's owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
    58
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    59
    public final Symbol owner;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    60
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    61
    protected Scope(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    62
        this.owner = owner;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    63
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    64
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    65
    /**Returns all Symbols in this Scope. Symbols from outward Scopes are included.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    66
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    67
    public final Iterable<Symbol> getSymbols() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    68
        return getSymbols(noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    69
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    70
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    71
    /**Returns Symbols that match the given filter. Symbols from outward Scopes are included.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    72
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    73
    public final Iterable<Symbol> getSymbols(Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    74
        return getSymbols(sf, RECURSIVE);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    75
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    76
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    77
    /**Returns all Symbols in this Scope. Symbols from outward Scopes are included
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    78
     * iff lookupKind == RECURSIVE.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    79
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    80
    public final Iterable<Symbol> getSymbols(LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    81
        return getSymbols(noFilter, lookupKind);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    82
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    83
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    84
    /**Returns Symbols that match the given filter. Symbols from outward Scopes are included
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    85
     * iff lookupKind == RECURSIVE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    86
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    87
    public abstract Iterable<Symbol> getSymbols(Filter<Symbol> sf, LookupKind lookupKind);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    88
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    89
    /**Returns Symbols with the given name. Symbols from outward Scopes are included.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    90
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    91
    public final Iterable<Symbol> getSymbolsByName(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    92
        return getSymbolsByName(name, RECURSIVE);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    93
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    94
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    95
    /**Returns Symbols with the given name that match the given filter.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    96
     * Symbols from outward Scopes are included.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    97
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    98
    public final Iterable<Symbol> getSymbolsByName(final Name name, final Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    99
        return getSymbolsByName(name, sf, RECURSIVE);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   100
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   101
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   102
    /**Returns Symbols with the given name. Symbols from outward Scopes are included
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   103
     * iff lookupKind == RECURSIVE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   104
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   105
    public final Iterable<Symbol> getSymbolsByName(Name name, LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   106
        return getSymbolsByName(name, noFilter, lookupKind);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   107
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   108
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   109
    /**Returns Symbols with the given name that match the given filter.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   110
     * Symbols from outward Scopes are included iff lookupKind == RECURSIVE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   111
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   112
    public abstract Iterable<Symbol> getSymbolsByName(final Name name, final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   113
            final LookupKind lookupKind);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   114
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   115
    /** Return the first Symbol from this or outward scopes with the given name.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   116
     * Returns null if none.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   117
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   118
    public final Symbol findFirst(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   119
        return findFirst(name, noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   120
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   121
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   122
    /** Return the first Symbol from this or outward scopes with the given name that matches the
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   123
     *  given filter. Returns null if none.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   124
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   125
    public Symbol findFirst(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   126
        Iterator<Symbol> it = getSymbolsByName(name, sf).iterator();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   127
        return it.hasNext() ? it.next() : null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   128
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   129
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   130
    /** Returns true iff there are is at least one Symbol in this scope matching the given filter.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   131
     *  Does not inspect outward scopes.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   132
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   133
    public boolean anyMatch(Filter<Symbol> filter) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   134
        return getSymbols(filter, NON_RECURSIVE).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   135
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   136
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   137
    /** Returns true iff the given Symbol is in this scope or any outward scope.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   138
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   139
    public boolean includes(final Symbol sym) {
41991
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   140
        return includes(sym, RECURSIVE);
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   141
    }
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   142
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   143
    /** Returns true iff the given Symbol is in this scope, optionally checking outward scopes.
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   144
     */
cc8a2784dd4c 8166700: NPE during invoking getEnclosedElements() on javax.lang.model.element.Element instance representing a package
jlahoda
parents: 40235
diff changeset
   145
    public boolean includes(final Symbol sym, LookupKind lookupKind) {
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   146
        return getSymbolsByName(sym.name, t -> t == sym, lookupKind).iterator().hasNext();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   147
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   148
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   149
    /** Returns true iff this scope does not contain any Symbol. Does not inspect outward scopes.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   150
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   151
    public boolean isEmpty() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   152
        return !getSymbols(NON_RECURSIVE).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   153
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   154
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   155
    /** Returns the Scope from which the givins Symbol originates in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   156
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   157
    public abstract Scope getOrigin(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   158
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   159
    /** Returns true iff the given Symbol is part of this scope due to a static import.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   160
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   161
    public abstract boolean isStaticallyImported(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   162
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   163
    private static final Filter<Symbol> noFilter = null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   164
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   165
    /** A list of scopes to be notified if items are to be removed from this scope.
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   166
     */
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   167
    ScopeListenerList listeners = new ScopeListenerList();
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   168
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   169
    public interface ScopeListener {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   170
        void symbolAdded(Symbol sym, Scope s);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   171
        void symbolRemoved(Symbol sym, Scope s);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   172
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   173
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   174
    /**
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   175
     * A list of scope listeners; listeners are stored in weak references, to avoid memory leaks.
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   176
     * When the listener list is scanned (upon notification), elements corresponding to GC-ed
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   177
     * listeners are removed so that the listener list size is kept in check.
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   178
     */
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   179
    public static class ScopeListenerList {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   180
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   181
        List<WeakReference<ScopeListener>> listeners = List.nil();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   182
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   183
        void add(ScopeListener sl) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   184
            listeners = listeners.prepend(new WeakReference<>(sl));
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   185
        }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   186
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   187
        void symbolAdded(Symbol sym, Scope scope) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   188
            walkReferences(sym, scope, false);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   189
        }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   190
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   191
        void symbolRemoved(Symbol sym, Scope scope) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   192
            walkReferences(sym, scope, true);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   193
        }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   194
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   195
        private void walkReferences(Symbol sym, Scope scope, boolean isRemove) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   196
            ListBuffer<WeakReference<ScopeListener>> newListeners = new ListBuffer<>();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   197
            for (WeakReference<ScopeListener> wsl : listeners) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   198
                ScopeListener sl = wsl.get();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   199
                if (sl != null) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   200
                    if (isRemove) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   201
                        sl.symbolRemoved(sym, scope);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   202
                    } else {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   203
                        sl.symbolAdded(sym, scope);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   204
                    }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   205
                    newListeners.add(wsl);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   206
                }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   207
            }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   208
            listeners = newListeners.toList();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   209
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   210
    }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   211
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   212
    public enum LookupKind {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   213
        RECURSIVE,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   214
        NON_RECURSIVE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   215
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   216
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   217
    /**A scope into which Symbols can be added.*/
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   218
    public abstract static class WriteableScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   219
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   220
        public WriteableScope(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   221
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   222
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   223
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   224
        /** Enter the given Symbol into this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   225
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   226
        public abstract void enter(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   227
        /** Enter symbol sym in this scope if not already there.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   228
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   229
        public abstract void enterIfAbsent(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   230
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   231
        public abstract void remove(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   232
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   233
        /** Construct a fresh scope within this scope, with same owner. The new scope may
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   234
         *  shares internal structures with the this scope. Used in connection with
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   235
         *  method leave if scope access is stack-like in order to avoid allocation
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   236
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   237
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   238
        public final WriteableScope dup() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   239
            return dup(this.owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   240
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   241
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   242
        /** Construct a fresh scope within this scope, with new owner. The new scope may
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   243
         *  shares internal structures with the this scope. Used in connection with
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   244
         *  method leave if scope access is stack-like in order to avoid allocation
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   245
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   246
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   247
        public abstract WriteableScope dup(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   248
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   249
        /** Must be called on dup-ed scopes to be able to work with the outward scope again.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   250
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   251
        public abstract WriteableScope leave();
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   252
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   253
        /** Construct a fresh scope within this scope, with same owner. The new scope
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   254
         *  will not share internal structures with this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   255
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   256
        public final WriteableScope dupUnshared() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   257
            return dupUnshared(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   258
        }
18899
2557b27d1f1c 6356530: -Xlint:serial does not flag abstract classes with concrete methods/members
vromero
parents: 14258
diff changeset
   259
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   260
        /** Construct a fresh scope within this scope, with new owner. The new scope
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   261
         *  will not share internal structures with this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   262
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   263
        public abstract WriteableScope dupUnshared(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   264
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   265
        /** Create a new WriteableScope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   266
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   267
        public static WriteableScope create(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   268
            return new ScopeImpl(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   269
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   270
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   271
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   272
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   273
    private static class ScopeImpl extends WriteableScope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   274
        /** The number of scopes that share this scope's hash table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   275
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   276
        private int shared;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   277
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   278
        /** Next enclosing scope (with whom this scope may share a hashtable)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   279
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   280
        public ScopeImpl next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   281
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   282
        /** A hash table for the scope's entries.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   283
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   284
        Entry[] table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   285
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   286
        /** Mask for hash codes, always equal to (table.length - 1).
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   287
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   288
        int hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   289
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   290
        /** A linear list that also contains all entries in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   291
         *  reverse order of appearance (i.e later entries are pushed on top).
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   292
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   293
        public Entry elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   294
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   295
        /** The number of elements in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   296
         * This includes deleted elements, whose value is the sentinel.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   297
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   298
        int nelems = 0;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   299
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   300
        int removeCount = 0;
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   301
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   302
        /** Use as a "not-found" result for lookup.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   303
         * Also used to mark deleted entries in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   304
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   305
        private static final Entry sentinel = new Entry(null, null, null, null);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   306
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   307
        /** The hash table's initial size.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   308
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   309
        private static final int INITIAL_SIZE = 0x10;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   310
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   311
        /** Construct a new scope, within scope next, with given owner, using
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   312
         *  given table. The table's length must be an exponent of 2.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   313
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   314
        private ScopeImpl(ScopeImpl next, Symbol owner, Entry[] table) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   315
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   316
            this.next = next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   317
            Assert.check(owner != null);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   318
            this.table = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   319
            this.hashMask = table.length - 1;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   320
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   321
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   322
        /** Convenience constructor used for dup and dupUnshared. */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   323
        private ScopeImpl(ScopeImpl next, Symbol owner, Entry[] table, int nelems) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   324
            this(next, owner, table);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   325
            this.nelems = nelems;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   326
        }
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   327
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   328
        /** Construct a new scope, within scope next, with given owner,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   329
         *  using a fresh table of length INITIAL_SIZE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   330
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   331
        public ScopeImpl(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   332
            this(null, owner, new Entry[INITIAL_SIZE]);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   333
        }
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   334
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   335
        /** Construct a fresh scope within this scope, with new owner,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   336
         *  which shares its table with the outer scope. Used in connection with
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   337
         *  method leave if scope access is stack-like in order to avoid allocation
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   338
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   339
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   340
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   341
            ScopeImpl result = new ScopeImpl(this, newOwner, this.table, this.nelems);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   342
            shared++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   343
            // System.out.println("====> duping scope " + this.hashCode() + " owned by " + newOwner + " to " + result.hashCode());
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   344
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   345
            return result;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   346
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   347
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   348
        /** Construct a fresh scope within this scope, with new owner,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   349
         *  with a new hash table, whose contents initially are those of
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   350
         *  the table of its outer scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   351
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   352
        public WriteableScope dupUnshared(Symbol newOwner) {
27553
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   353
            if (shared > 0) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   354
                //The nested Scopes might have already added something to the table, so all items
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   355
                //that don't originate in this Scope or any of its outer Scopes need to be cleared:
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   356
                Set<Scope> acceptScopes = Collections.newSetFromMap(new IdentityHashMap<>());
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   357
                ScopeImpl c = this;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   358
                while (c != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   359
                    acceptScopes.add(c);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   360
                    c = c.next;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   361
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   362
                int n = 0;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   363
                Entry[] oldTable = this.table;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   364
                Entry[] newTable = new Entry[this.table.length];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   365
                for (int i = 0; i < oldTable.length; i++) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   366
                    Entry e = oldTable[i];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   367
                    while (e != null && e != sentinel && !acceptScopes.contains(e.scope)) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   368
                        e = e.shadowed;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   369
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   370
                    if (e != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   371
                        n++;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   372
                        newTable[i] = e;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   373
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   374
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   375
                return new ScopeImpl(this, newOwner, newTable, n);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   376
            } else {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   377
                return new ScopeImpl(this, newOwner, this.table.clone(), this.nelems);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   378
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   379
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   380
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   381
        /** Remove all entries of this scope from its table, if shared
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   382
         *  with next.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   383
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   384
        public WriteableScope leave() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   385
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   386
            if (table != next.table) return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   387
            while (elems != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   388
                int hash = getIndex(elems.sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   389
                Entry e = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   390
                Assert.check(e == elems, elems.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   391
                table[hash] = elems.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   392
                elems = elems.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   393
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   394
            Assert.check(next.shared > 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   395
            next.shared--;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   396
            next.nelems = nelems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   397
            // System.out.println("====> leaving scope " + this.hashCode() + " owned by " + this.owner + " to " + next.hashCode());
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   398
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   399
            return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   400
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   401
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   402
        /** Double size of hash table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   403
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   404
        private void dble() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   405
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   406
            Entry[] oldtable = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   407
            Entry[] newtable = new Entry[oldtable.length * 2];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   408
            for (ScopeImpl s = this; s != null; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   409
                if (s.table == oldtable) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   410
                    Assert.check(s == this || s.shared != 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   411
                    s.table = newtable;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   412
                    s.hashMask = newtable.length - 1;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   413
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   414
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   415
            int n = 0;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   416
            for (int i = oldtable.length; --i >= 0; ) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   417
                Entry e = oldtable[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   418
                if (e != null && e != sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   419
                    table[getIndex(e.sym.name)] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   420
                    n++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   421
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   422
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   423
            // We don't need to update nelems for shared inherited scopes,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   424
            // since that gets handled by leave().
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   425
            nelems = n;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   426
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   427
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   428
        /** Enter symbol sym in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   429
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   430
        public void enter(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   431
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   432
            if (nelems * 3 >= hashMask * 2)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   433
                dble();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   434
            int hash = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   435
            Entry old = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   436
            if (old == null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   437
                old = sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   438
                nelems++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   439
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   440
            Entry e = new Entry(sym, old, elems, this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   441
            table[hash] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   442
            elems = e;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   443
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   444
            //notify listeners
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   445
            listeners.symbolAdded(sym, this);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   446
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   447
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   448
        /** Remove symbol from this scope.
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   449
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   450
        public void remove(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   451
            Assert.check(shared == 0);
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   452
            Entry e = lookup(sym.name, candidate -> candidate == sym);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   453
            if (e.scope == null) return;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   454
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   455
            // remove e from table and shadowed list;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   456
            int i = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   457
            Entry te = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   458
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   459
                table[i] = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   460
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   461
                if (te.shadowed == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   462
                    te.shadowed = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   463
                    break;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   464
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   465
                te = te.shadowed;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   466
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   467
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   468
            // remove e from elems and sibling list
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   469
            te = elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   470
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   471
                elems = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   472
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   473
                if (te.sibling == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   474
                    te.sibling = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   475
                    break;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   476
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   477
                te = te.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   478
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   479
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   480
            removeCount++;
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   481
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   482
            //notify listeners
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   483
            listeners.symbolRemoved(sym, this);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   484
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   485
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   486
        /** Enter symbol sym in this scope if not already there.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   487
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   488
        public void enterIfAbsent(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   489
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   490
            Entry e = lookup(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   491
            while (e.scope == this && e.sym.kind != sym.kind) e = e.next();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   492
            if (e.scope != this) enter(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   493
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   494
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   495
        /** Given a class, is there already a class with same fully
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   496
         *  qualified name in this (import) scope?
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   497
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   498
        public boolean includes(Symbol c) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   499
            for (Scope.Entry e = lookup(c.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   500
                 e.scope == this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   501
                 e = e.next()) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   502
                if (e.sym == c) return true;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   503
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   504
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   505
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   506
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   507
        /** Return the entry associated with given name, starting in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   508
         *  this scope and proceeding outwards. If no entry was found,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   509
         *  return the sentinel, which is characterized by having a null in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   510
         *  both its scope and sym fields, whereas both fields are non-null
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   511
         *  for regular entries.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   512
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   513
        protected Entry lookup(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   514
            return lookup(name, noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   515
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   516
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   517
        protected Entry lookup(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   518
            Entry e = table[getIndex(name)];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   519
            if (e == null || e == sentinel)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   520
                return sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   521
            while (e.scope != null && (e.sym.name != name || (sf != null && !sf.accepts(e.sym))))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   522
                e = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   523
            return e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   524
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   525
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   526
        public Symbol findFirst(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   527
            return lookup(name, sf).sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   528
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   529
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   530
        /*void dump (java.io.PrintStream out) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   531
            out.println(this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   532
            for (int l=0; l < table.length; l++) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   533
                Entry le = table[l];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   534
                out.print("#"+l+": ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   535
                if (le==sentinel) out.println("sentinel");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   536
                else if(le == null) out.println("null");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   537
                else out.println(""+le+" s:"+le.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   538
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   539
        }*/
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   540
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   541
        /** Look for slot in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   542
         *  We use open addressing with double hashing.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   543
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   544
        int getIndex (Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   545
            int h = name.hashCode();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   546
            int i = h & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   547
            // The expression below is always odd, so it is guaranteed
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   548
            // to be mutually prime with table.length, a power of 2.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   549
            int x = hashMask - ((h + (h >> 16)) << 1);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   550
            int d = -1; // Index of a deleted item.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   551
            for (;;) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   552
                Entry e = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   553
                if (e == null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   554
                    return d >= 0 ? d : i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   555
                if (e == sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   556
                    // We have to keep searching even if we see a deleted item.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   557
                    // However, remember the index in case we fail to find the name.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   558
                    if (d < 0)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   559
                        d = i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   560
                } else if (e.sym.name == name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   561
                    return i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   562
                i = (i + x) & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   563
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   564
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   565
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   566
        public boolean anyMatch(Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   567
            return getSymbols(sf, NON_RECURSIVE).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   568
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   569
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   570
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   571
                                           final LookupKind lookupKind) {
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   572
            return () -> new Iterator<Symbol>() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   573
                private ScopeImpl currScope = ScopeImpl.this;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   574
                private Entry currEntry = elems;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   575
                private int seenRemoveCount = currScope.removeCount;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   576
                {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   577
                    update();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   578
                }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   579
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   580
                public boolean hasNext() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   581
                    if (seenRemoveCount != currScope.removeCount &&
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   582
                        currEntry != null &&
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   583
                        !currEntry.scope.includes(currEntry.sym)) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   584
                        doNext(); //skip entry that is no longer in the Scope
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   585
                        seenRemoveCount = currScope.removeCount;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   586
                    }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   587
                    return currEntry != null;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   588
                }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   589
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   590
                public Symbol next() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   591
                    if (!hasNext()) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   592
                        throw new NoSuchElementException();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   593
                    }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   594
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   595
                    return doNext();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   596
                }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   597
                private Symbol doNext() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   598
                    Symbol sym = (currEntry == null ? null : currEntry.sym);
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   599
                    if (currEntry != null) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   600
                        currEntry = currEntry.sibling;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   601
                    }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   602
                    update();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   603
                    return sym;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   604
                }
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   605
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   606
                private void update() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   607
                    skipToNextMatchingEntry();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   608
                    if (lookupKind == RECURSIVE) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   609
                        while (currEntry == null && currScope.next != null) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   610
                            currScope = currScope.next;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   611
                            currEntry = currScope.elems;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   612
                            seenRemoveCount = currScope.removeCount;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   613
                            skipToNextMatchingEntry();
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   614
                        }
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   615
                    }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   616
                }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   617
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   618
                void skipToNextMatchingEntry() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   619
                    while (currEntry != null && sf != null && !sf.accepts(currEntry.sym)) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   620
                        currEntry = currEntry.sibling;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   621
                    }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   622
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   623
            };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   624
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   625
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   626
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   627
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   628
                                                 final LookupKind lookupKind) {
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   629
            return () -> new Iterator<Symbol>() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   630
               Entry currentEntry = lookup(name, sf);
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   631
               int seenRemoveCount = currentEntry.scope != null ?
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   632
                       currentEntry.scope.removeCount : -1;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   633
42827
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   634
               public boolean hasNext() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   635
                   if (currentEntry.scope != null &&
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   636
                       seenRemoveCount != currentEntry.scope.removeCount &&
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   637
                       !currentEntry.scope.includes(currentEntry.sym)) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   638
                       doNext(); //skip entry that is no longer in the Scope
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   639
                   }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   640
                   return currentEntry.scope != null &&
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   641
                           (lookupKind == RECURSIVE ||
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   642
                            currentEntry.scope == ScopeImpl.this);
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   643
               }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   644
               public Symbol next() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   645
                   if (!hasNext()) {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   646
                       throw new NoSuchElementException();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   647
                   }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   648
                   return doNext();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   649
               }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   650
               private Symbol doNext() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   651
                   Entry prevEntry = currentEntry;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   652
                   currentEntry = currentEntry.next(sf);
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   653
                   return prevEntry.sym;
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   654
               }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   655
               public void remove() {
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   656
                   throw new UnsupportedOperationException();
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   657
               }
36468b5fa7f4 8181370: Convert anonymous inner classes into lambdas/method references
mcimadamore
parents: 42407
diff changeset
   658
           };
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   659
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   660
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   661
        public Scope getOrigin(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   662
            for (Scope.Entry e = lookup(s.name); e.scope != null ; e = e.next()) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   663
                if (e.sym == s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   664
                    return this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   665
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   666
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   667
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   668
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   669
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   670
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   671
        public boolean isStaticallyImported(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   672
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   673
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   674
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   675
        public String toString() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   676
            StringBuilder result = new StringBuilder();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   677
            result.append("Scope[");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   678
            for (ScopeImpl s = this; s != null ; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   679
                if (s != this) result.append(" | ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   680
                for (Entry e = s.elems; e != null; e = e.sibling) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   681
                    if (e != s.elems) result.append(", ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   682
                    result.append(e.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   683
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   684
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   685
            result.append("]");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   686
            return result.toString();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   687
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
06bc494ca11e Initial load
duke
parents:
diff changeset
   690
    /** A class for scope entries.
06bc494ca11e Initial load
duke
parents:
diff changeset
   691
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   692
    private static class Entry {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   693
06bc494ca11e Initial load
duke
parents:
diff changeset
   694
        /** The referenced symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   695
         *  sym == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   697
        public Symbol sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
06bc494ca11e Initial load
duke
parents:
diff changeset
   699
        /** An entry with the same hash code, or sentinel.
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
        private Entry shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   702
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
        /** Next entry in same scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   704
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   705
        public Entry sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   706
06bc494ca11e Initial load
duke
parents:
diff changeset
   707
        /** The entry's scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   708
         *  scope == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   709
         */
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   710
        public ScopeImpl scope;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   711
40235
fe6c00618434 8144733: Iterating over elements of a Scope can return spurious inner class elements
jlahoda
parents: 32454
diff changeset
   712
        public Entry(Symbol sym, Entry shadowed, Entry sibling, ScopeImpl scope) {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   713
            this.sym = sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   714
            this.shadowed = shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   715
            this.sibling = sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   716
            this.scope = scope;
06bc494ca11e Initial load
duke
parents:
diff changeset
   717
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   718
06bc494ca11e Initial load
duke
parents:
diff changeset
   719
        /** Return next entry with the same name as this entry, proceeding
06bc494ca11e Initial load
duke
parents:
diff changeset
   720
         *  outwards if not found in this scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   721
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   722
        public Entry next() {
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   723
            return shadowed;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   724
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   725
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   726
        public Entry next(Filter<Symbol> sf) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   727
            if (shadowed.sym == null || sf == null || sf.accepts(shadowed.sym)) return shadowed;
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   728
            else return shadowed.next(sf);
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   729
        }
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   730
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   731
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   732
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   733
    public static class ImportScope extends CompoundScope {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   734
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   735
        public ImportScope(Symbol owner) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   736
            super(owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   737
        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   738
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   739
        /**Finalize the content of the ImportScope to speed-up future lookups.
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   740
         * No further changes to class hierarchy or class content will be reflected.
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   741
         */
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   742
        public void finalizeScope() {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   743
            for (List<Scope> scopes = this.subScopes; scopes.nonEmpty(); scopes = scopes.tail) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   744
                Scope impScope = scopes.head;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   745
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   746
                if (impScope instanceof FilterImportScope && impScope.owner.kind == Kind.TYP) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   747
                    WriteableScope finalized = WriteableScope.create(impScope.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   748
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   749
                    for (Symbol sym : impScope.getSymbols()) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   750
                        finalized.enter(sym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   751
                    }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   752
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   753
                    finalized.listeners.add(new ScopeListener() {
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   754
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   755
                        public void symbolAdded(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   756
                            Assert.error("The scope is sealed.");
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   757
                        }
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   758
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   759
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   760
                        public void symbolRemoved(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   761
                            Assert.error("The scope is sealed.");
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   762
                        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   763
                    });
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   764
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   765
                    scopes.head = finalized;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   766
                }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   767
            }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   768
        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   769
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   770
    }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   771
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   772
    public static class NamedImportScope extends ImportScope {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   773
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   774
        public NamedImportScope(Symbol owner, Scope currentFileScope) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   775
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   776
            prependSubScope(currentFileScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   777
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   778
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   779
        public Scope importByName(Types types, Scope origin, Name name, ImportFilter filter, JCImport imp, BiConsumer<JCImport, CompletionFailure> cfHandler) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   780
            return appendScope(new FilterImportScope(types, origin, name, filter, imp, cfHandler));
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   781
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   782
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   783
        public Scope importType(Scope delegate, Scope origin, Symbol sym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   784
            return appendScope(new SingleEntryScope(delegate.owner, sym, origin));
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   785
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   786
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   787
        private Scope appendScope(Scope newScope) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   788
            List<Scope> existingScopes = this.subScopes.reverse();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   789
            subScopes = List.of(existingScopes.head);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   790
            subScopes = subScopes.prepend(newScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   791
            for (Scope s : existingScopes.tail) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   792
                subScopes = subScopes.prepend(s);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   793
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   794
            return newScope;
19492
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 18899
diff changeset
   795
        }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 18899
diff changeset
   796
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   797
        private static class SingleEntryScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   798
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   799
            private final Symbol sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   800
            private final List<Symbol> content;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   801
            private final Scope origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   802
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   803
            public SingleEntryScope(Symbol owner, Symbol sym, Scope origin) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   804
                super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   805
                this.sym = sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   806
                this.content = List.of(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   807
                this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   808
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   809
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   810
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   811
            public Iterable<Symbol> getSymbols(Filter<Symbol> sf, LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   812
                return sf == null || sf.accepts(sym) ? content : Collections.<Symbol>emptyList();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   813
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   814
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   815
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   816
            public Iterable<Symbol> getSymbolsByName(Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   817
                                                     Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   818
                                                     LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   819
                return sym.name == name &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   820
                       (sf == null || sf.accepts(sym)) ? content : Collections.<Symbol>emptyList();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   821
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   822
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   823
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   824
            public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   825
                return sym == byName ? origin : null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   826
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   827
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   828
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   829
            public boolean isStaticallyImported(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   830
                return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   831
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   832
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   833
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   834
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   835
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   836
    public static class StarImportScope extends ImportScope {
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   837
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   838
        public StarImportScope(Symbol owner) {
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   839
            super(owner);
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   840
        }
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   841
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   842
        public void importAll(Types types, Scope origin,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   843
                              ImportFilter filter,
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   844
                              JCImport imp,
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   845
                              BiConsumer<JCImport, CompletionFailure> cfHandler) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   846
            for (Scope existing : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   847
                Assert.check(existing instanceof FilterImportScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   848
                FilterImportScope fis = (FilterImportScope) existing;
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   849
                if (fis.origin == origin && fis.filter == filter &&
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   850
                    fis.imp.staticImport == imp.staticImport)
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   851
                    return ; //avoid entering the same scope twice
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   852
            }
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   853
            prependSubScope(new FilterImportScope(types, origin, null, filter, imp, cfHandler));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   854
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   855
29149
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   856
        public boolean isFilled() {
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   857
            return subScopes.nonEmpty();
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   858
        }
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   859
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   860
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   861
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   862
    public interface ImportFilter {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   863
        public boolean accepts(Scope origin, Symbol sym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   864
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   865
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   866
    private static class FilterImportScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   867
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   868
        private final Types types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   869
        private final Scope origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   870
        private final Name  filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   871
        private final ImportFilter filter;
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   872
        private final JCImport imp;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   873
        private final BiConsumer<JCImport, CompletionFailure> cfHandler;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   874
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   875
        public FilterImportScope(Types types,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   876
                                 Scope origin,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   877
                                 Name  filterName,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   878
                                 ImportFilter filter,
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   879
                                 JCImport imp,
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   880
                                 BiConsumer<JCImport, CompletionFailure> cfHandler) {
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   881
            super(origin.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   882
            this.types = types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   883
            this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   884
            this.filterName = filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   885
            this.filter = filter;
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   886
            this.imp = imp;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   887
            this.cfHandler = cfHandler;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   888
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   889
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   890
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   891
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf, final LookupKind lookupKind) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   892
            if (filterName != null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   893
                return getSymbolsByName(filterName, sf, lookupKind);
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   894
            try {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   895
                SymbolImporter si = new SymbolImporter(imp.staticImport) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   896
                    @Override
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   897
                    Iterable<Symbol> doLookup(TypeSymbol tsym) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   898
                        return tsym.members().getSymbols(sf, lookupKind);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   899
                    }
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   900
                };
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   901
                return si.importFrom((TypeSymbol) origin.owner) :: iterator;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   902
            } catch (CompletionFailure cf) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   903
                cfHandler.accept(imp, cf);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   904
                return Collections.emptyList();
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   905
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   906
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   907
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   908
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   909
        public Iterable<Symbol> getSymbolsByName(final Name name,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   910
                                                 final Filter<Symbol> sf,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   911
                                                 final LookupKind lookupKind) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   912
            if (filterName != null && filterName != name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   913
                return Collections.emptyList();
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   914
            try {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   915
                SymbolImporter si = new SymbolImporter(imp.staticImport) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   916
                    @Override
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   917
                    Iterable<Symbol> doLookup(TypeSymbol tsym) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   918
                        return tsym.members().getSymbolsByName(name, sf, lookupKind);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   919
                    }
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   920
                };
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   921
                return si.importFrom((TypeSymbol) origin.owner) :: iterator;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   922
            } catch (CompletionFailure cf) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   923
                cfHandler.accept(imp, cf);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   924
                return Collections.emptyList();
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   925
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   926
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   927
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   928
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   929
        public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   930
            return origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   931
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   932
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   933
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   934
        public boolean isStaticallyImported(Symbol byName) {
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   935
            return imp.staticImport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   936
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   937
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   938
        abstract class SymbolImporter {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   939
            Set<Symbol> processed = new HashSet<>();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   940
            List<Iterable<Symbol>> delegates = List.nil();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   941
            final boolean inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   942
            public SymbolImporter(boolean inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   943
                this.inspectSuperTypes = inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   944
            }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   945
            Stream<Symbol> importFrom(TypeSymbol tsym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   946
                if (tsym == null || !processed.add(tsym))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   947
                    return Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   948
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   949
                Stream<Symbol> result = Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   950
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   951
                if (inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   952
                    // also import inherited names
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   953
                    result = importFrom(types.supertype(tsym.type).tsym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   954
                    for (Type t : types.interfaces(tsym.type))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   955
                        result = Stream.concat(importFrom(t.tsym), result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   956
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   957
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   958
                return Stream.concat(StreamSupport.stream(doLookup(tsym).spliterator(), false)
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   959
                                                  .filter(s -> filter.accepts(origin, s)),
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   960
                                     result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   961
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   962
            abstract Iterable<Symbol> doLookup(TypeSymbol tsym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   963
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   964
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   965
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   966
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   967
    /** A class scope adds capabilities to keep track of changes in related
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   968
     *  class scopes - this allows client to realize whether a class scope
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   969
     *  has changed, either directly (because a new member has been added/removed
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   970
     *  to this scope) or indirectly (i.e. because a new member has been
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   971
     *  added/removed into a supertype scope)
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   972
     */
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   973
    public static class CompoundScope extends Scope implements ScopeListener {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   974
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   975
        List<Scope> subScopes = List.nil();
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   976
        private int mark = 0;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   977
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   978
        public CompoundScope(Symbol owner) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   979
            super(owner);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   980
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   981
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   982
        public void prependSubScope(Scope that) {
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   983
           if (that != null) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   984
                subScopes = subScopes.prepend(that);
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   985
                that.listeners.add(this);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   986
                mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   987
                listeners.symbolAdded(null, this);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   988
           }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   989
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   990
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   991
        public void symbolAdded(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   992
            mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   993
            listeners.symbolAdded(sym, s);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   994
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   995
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   996
        public void symbolRemoved(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   997
            mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   998
            listeners.symbolRemoved(sym, s);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   999
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1000
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1001
        public int getMark() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1002
            return mark;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1003
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1004
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1005
        @Override
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1006
        public String toString() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1007
            StringBuilder buf = new StringBuilder();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1008
            buf.append("CompoundScope{");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1009
            String sep = "";
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1010
            for (Scope s : subScopes) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1011
                buf.append(sep);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1012
                buf.append(s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1013
                sep = ",";
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1014
            }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1015
            buf.append("}");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1016
            return buf.toString();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1017
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1018
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1019
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1020
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1021
                                           final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1022
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1023
                                                          scope -> scope.getSymbols(sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1024
                                                                                    lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1025
                                                                        .iterator());
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1026
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1027
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1028
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1029
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1030
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1031
                                                 final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1032
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1033
                                                          scope -> scope.getSymbolsByName(name,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1034
                                                                                          sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1035
                                                                                          lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1036
                                                                        .iterator());
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1037
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1038
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1039
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1040
        public Scope getOrigin(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1041
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1042
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1043
                    return delegate.getOrigin(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1044
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1045
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1046
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1047
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1048
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1049
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1050
        public boolean isStaticallyImported(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1051
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1052
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1053
                    return delegate.isStaticallyImported(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1054
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1055
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1056
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1057
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1058
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1059
    }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1060
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1061
    /** An error scope, for which the owner should be an error symbol. */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1062
    public static class ErrorScope extends ScopeImpl {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1063
        ErrorScope(ScopeImpl next, Symbol errSymbol, Entry[] table) {
8242
3873b4aaf4a8 7007615: java_util/generics/phase2/NameClashTest02 fails since jdk7/pit/b123.
mcimadamore
parents: 8032
diff changeset
  1064
            super(next, /*owner=*/errSymbol, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1065
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1066
        public ErrorScope(Symbol errSymbol) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1067
            super(errSymbol);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1068
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1069
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1070
            return new ErrorScope(this, newOwner, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1071
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1072
        public WriteableScope dupUnshared(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1073
            return new ErrorScope(this, newOwner, table.clone());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1074
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1075
        public Entry lookup(Name name) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1076
            Entry e = super.lookup(name);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1077
            if (e.scope == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1078
                return new Entry(owner, null, null, null);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1079
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1080
                return e;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1081
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1082
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1083
}