langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Scope.java
author mcimadamore
Mon, 31 Aug 2015 17:33:34 +0100
changeset 32454 b0ac04e0fefe
parent 32059 ea04f56aeacd
child 40235 fe6c00618434
permissions -rw-r--r--
8129962: Investigate performance improvements in langtools combo tests Summary: New combo API that runs all combo instances in a shared javac context (whenever possible). Reviewed-by: jjg, jlahoda, vromero
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
06bc494ca11e Initial load
duke
parents:
diff changeset
     1
/*
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
     2
 * Copyright (c) 1999, 2015, 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) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   140
        return getSymbolsByName(sym.name, new Filter<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   141
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   142
            public boolean accepts(Symbol t) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   143
                return t == sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   144
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   145
        }).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   146
    }
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
    /** 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
   149
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   150
    public boolean isEmpty() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   151
        return !getSymbols(NON_RECURSIVE).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   152
    }
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
    /** 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
   155
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   156
    public abstract Scope getOrigin(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   157
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   158
    /** 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
   159
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   160
    public abstract boolean isStaticallyImported(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   161
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   162
    private static final Filter<Symbol> noFilter = null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   163
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   164
    /** 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
   165
     */
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   166
    ScopeListenerList listeners = new ScopeListenerList();
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   167
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   168
    public interface ScopeListener {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   169
        void symbolAdded(Symbol sym, Scope s);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   170
        void symbolRemoved(Symbol sym, Scope s);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   171
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   172
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   173
    /**
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   174
     * 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
   175
     * 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
   176
     * 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
   177
     */
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   178
    public static class ScopeListenerList {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   179
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   180
        List<WeakReference<ScopeListener>> listeners = List.nil();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   181
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   182
        void add(ScopeListener sl) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   183
            listeners = listeners.prepend(new WeakReference<>(sl));
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   184
        }
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
        void symbolAdded(Symbol sym, Scope scope) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   187
            walkReferences(sym, scope, false);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   188
        }
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
        void symbolRemoved(Symbol sym, Scope scope) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   191
            walkReferences(sym, scope, true);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   192
        }
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
        private void walkReferences(Symbol sym, Scope scope, boolean isRemove) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   195
            ListBuffer<WeakReference<ScopeListener>> newListeners = new ListBuffer<>();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   196
            for (WeakReference<ScopeListener> wsl : listeners) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   197
                ScopeListener sl = wsl.get();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   198
                if (sl != null) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   199
                    if (isRemove) {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   200
                        sl.symbolRemoved(sym, scope);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   201
                    } else {
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   202
                        sl.symbolAdded(sym, scope);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   203
                    }
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   204
                    newListeners.add(wsl);
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   205
                }
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
            listeners = newListeners.toList();
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   208
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   209
    }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   210
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   211
    public enum LookupKind {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   212
        RECURSIVE,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   213
        NON_RECURSIVE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   214
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   215
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   216
    /**A scope into which Symbols can be added.*/
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   217
    public abstract static class WriteableScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   218
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   219
        public WriteableScope(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   220
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   221
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   222
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   223
        /** Enter the given Symbol into this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   224
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   225
        public abstract void enter(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   226
        /** 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
   227
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   228
        public abstract void enterIfAbsent(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   229
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   230
        public abstract void remove(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   231
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   232
        /** 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
   233
         *  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
   234
         *  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
   235
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   236
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   237
        public final WriteableScope dup() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   238
            return dup(this.owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   239
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   240
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   241
        /** 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
   242
         *  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
   243
         *  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
   244
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   245
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   246
        public abstract WriteableScope dup(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   247
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   248
        /** 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
   249
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   250
        public abstract WriteableScope leave();
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   251
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   252
        /** 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
   253
         *  will not share internal structures with this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   254
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   255
        public final WriteableScope dupUnshared() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   256
            return dupUnshared(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   257
        }
18899
2557b27d1f1c 6356530: -Xlint:serial does not flag abstract classes with concrete methods/members
vromero
parents: 14258
diff changeset
   258
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   259
        /** 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
   260
         *  will not share internal structures with this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   261
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   262
        public abstract WriteableScope dupUnshared(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   263
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   264
        /** Create a new WriteableScope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   265
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   266
        public static WriteableScope create(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   267
            return new ScopeImpl(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   268
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   269
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   270
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   271
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   272
    private static class ScopeImpl extends WriteableScope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   273
        /** 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
   274
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   275
        private int shared;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   276
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   277
        /** 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
   278
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   279
        public ScopeImpl next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   280
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   281
        /** A hash table for the scope's entries.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   282
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   283
        Entry[] table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   284
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   285
        /** 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
   286
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   287
        int hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   288
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   289
        /** A linear list that also contains all entries in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   290
         *  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
   291
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   292
        public Entry elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   293
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   294
        /** The number of elements in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   295
         * This includes deleted elements, whose value is the sentinel.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   296
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   297
        int nelems = 0;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   298
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   299
        /** Use as a "not-found" result for lookup.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   300
         * Also used to mark deleted entries in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   301
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   302
        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
   303
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   304
        /** The hash table's initial size.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   305
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   306
        private static final int INITIAL_SIZE = 0x10;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   307
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   308
        /** 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
   309
         *  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
   310
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   311
        private ScopeImpl(ScopeImpl next, Symbol owner, Entry[] table) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   312
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   313
            this.next = next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   314
            Assert.check(owner != null);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   315
            this.table = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   316
            this.hashMask = table.length - 1;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   317
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   318
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   319
        /** Convenience constructor used for dup and dupUnshared. */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   320
        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
   321
            this(next, owner, table);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   322
            this.nelems = nelems;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   323
        }
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   324
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   325
        /** 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
   326
         *  using a fresh table of length INITIAL_SIZE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   327
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   328
        public ScopeImpl(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   329
            this(null, owner, new Entry[INITIAL_SIZE]);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   330
        }
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   331
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   332
        /** 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
   333
         *  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
   334
         *  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
   335
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   336
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   337
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   338
            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
   339
            shared++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   340
            // 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
   341
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   342
            return result;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   343
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   344
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   345
        /** 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
   346
         *  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
   347
         *  the table of its outer scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   348
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   349
        public WriteableScope dupUnshared(Symbol newOwner) {
27553
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   350
            if (shared > 0) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   351
                //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
   352
                //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
   353
                Set<Scope> acceptScopes = Collections.newSetFromMap(new IdentityHashMap<>());
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   354
                ScopeImpl c = this;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   355
                while (c != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   356
                    acceptScopes.add(c);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   357
                    c = c.next;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   358
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   359
                int n = 0;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   360
                Entry[] oldTable = this.table;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   361
                Entry[] newTable = new Entry[this.table.length];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   362
                for (int i = 0; i < oldTable.length; i++) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   363
                    Entry e = oldTable[i];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   364
                    while (e != null && e != sentinel && !acceptScopes.contains(e.scope)) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   365
                        e = e.shadowed;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   366
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   367
                    if (e != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   368
                        n++;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   369
                        newTable[i] = e;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   370
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   371
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   372
                return new ScopeImpl(this, newOwner, newTable, n);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   373
            } else {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   374
                return new ScopeImpl(this, newOwner, this.table.clone(), this.nelems);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   375
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   376
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   377
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   378
        /** 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
   379
         *  with next.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   380
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   381
        public WriteableScope leave() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   382
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   383
            if (table != next.table) return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   384
            while (elems != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   385
                int hash = getIndex(elems.sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   386
                Entry e = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   387
                Assert.check(e == elems, elems.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   388
                table[hash] = elems.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   389
                elems = elems.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   390
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   391
            Assert.check(next.shared > 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   392
            next.shared--;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   393
            next.nelems = nelems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   394
            // 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
   395
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   396
            return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   397
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   398
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   399
        /** Double size of hash table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   400
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   401
        private void dble() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   402
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   403
            Entry[] oldtable = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   404
            Entry[] newtable = new Entry[oldtable.length * 2];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   405
            for (ScopeImpl s = this; s != null; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   406
                if (s.table == oldtable) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   407
                    Assert.check(s == this || s.shared != 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   408
                    s.table = newtable;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   409
                    s.hashMask = newtable.length - 1;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   410
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   411
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   412
            int n = 0;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   413
            for (int i = oldtable.length; --i >= 0; ) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   414
                Entry e = oldtable[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   415
                if (e != null && e != sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   416
                    table[getIndex(e.sym.name)] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   417
                    n++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   418
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   419
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   420
            // 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
   421
            // since that gets handled by leave().
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   422
            nelems = n;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   423
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   424
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   425
        /** Enter symbol sym in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   426
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   427
        public void enter(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   428
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   429
            if (nelems * 3 >= hashMask * 2)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   430
                dble();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   431
            int hash = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   432
            Entry old = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   433
            if (old == null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   434
                old = sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   435
                nelems++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   436
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   437
            Entry e = new Entry(sym, old, elems, this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   438
            table[hash] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   439
            elems = e;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   440
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   441
            //notify listeners
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   442
            listeners.symbolAdded(sym, this);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   443
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   444
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   445
        /** Remove symbol from this scope.
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   446
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   447
        public void remove(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   448
            Assert.check(shared == 0);
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   449
            Entry e = lookup(sym.name, candidate -> candidate == sym);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   450
            if (e.scope == null) return;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   451
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   452
            // remove e from table and shadowed list;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   453
            int i = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   454
            Entry te = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   455
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   456
                table[i] = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   457
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   458
                if (te.shadowed == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   459
                    te.shadowed = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   460
                    break;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   461
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   462
                te = te.shadowed;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   463
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   464
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   465
            // remove e from elems and sibling list
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   466
            te = elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   467
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   468
                elems = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   469
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   470
                if (te.sibling == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   471
                    te.sibling = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   472
                    break;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   473
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   474
                te = te.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   475
            }
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
            //notify listeners
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   478
            listeners.symbolRemoved(sym, this);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   479
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   480
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   481
        /** 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
   482
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   483
        public void enterIfAbsent(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   484
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   485
            Entry e = lookup(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   486
            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
   487
            if (e.scope != this) enter(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   488
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   489
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   490
        /** 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
   491
         *  qualified name in this (import) scope?
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   492
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   493
        public boolean includes(Symbol c) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   494
            for (Scope.Entry e = lookup(c.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   495
                 e.scope == this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   496
                 e = e.next()) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   497
                if (e.sym == c) return true;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   498
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   499
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   500
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   501
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   502
        /** Return the entry associated with given name, starting in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   503
         *  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
   504
         *  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
   505
         *  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
   506
         *  for regular entries.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   507
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   508
        protected Entry lookup(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   509
            return lookup(name, noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   510
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   511
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   512
        protected Entry lookup(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   513
            Entry e = table[getIndex(name)];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   514
            if (e == null || e == sentinel)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   515
                return sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   516
            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
   517
                e = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   518
            return e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   519
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   520
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   521
        public Symbol findFirst(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   522
            return lookup(name, sf).sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   523
        }
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
        /*void dump (java.io.PrintStream out) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   526
            out.println(this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   527
            for (int l=0; l < table.length; l++) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   528
                Entry le = table[l];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   529
                out.print("#"+l+": ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   530
                if (le==sentinel) out.println("sentinel");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   531
                else if(le == null) out.println("null");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   532
                else out.println(""+le+" s:"+le.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   533
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   534
        }*/
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   535
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   536
        /** Look for slot in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   537
         *  We use open addressing with double hashing.
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
        int getIndex (Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   540
            int h = name.hashCode();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   541
            int i = h & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   542
            // 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
   543
            // 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
   544
            int x = hashMask - ((h + (h >> 16)) << 1);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   545
            int d = -1; // Index of a deleted item.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   546
            for (;;) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   547
                Entry e = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   548
                if (e == null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   549
                    return d >= 0 ? d : i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   550
                if (e == sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   551
                    // 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
   552
                    // 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
   553
                    if (d < 0)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   554
                        d = i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   555
                } else if (e.sym.name == name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   556
                    return i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   557
                i = (i + x) & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   558
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   559
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   560
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   561
        public boolean anyMatch(Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   562
            return getSymbols(sf, NON_RECURSIVE).iterator().hasNext();
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
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   566
                                           final LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   567
            return new Iterable<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   568
                public Iterator<Symbol> iterator() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   569
                    return new Iterator<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   570
                        private ScopeImpl currScope = ScopeImpl.this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   571
                        private Scope.Entry currEntry = elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   572
                        {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   573
                            update();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   574
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   575
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   576
                        public boolean hasNext() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   577
                            return currEntry != null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   578
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   579
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   580
                        public Symbol next() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   581
                            Symbol sym = (currEntry == null ? null : currEntry.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   582
                            if (currEntry != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   583
                                currEntry = currEntry.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   584
                            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   585
                            update();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   586
                            return sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   587
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   588
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   589
                        public void remove() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   590
                            throw new UnsupportedOperationException();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   591
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   592
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   593
                        private void update() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   594
                            skipToNextMatchingEntry();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   595
                            if (lookupKind == RECURSIVE) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   596
                                while (currEntry == null && currScope.next != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   597
                                    currScope = currScope.next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   598
                                    currEntry = currScope.elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   599
                                    skipToNextMatchingEntry();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   600
                                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   601
                            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   602
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   603
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   604
                        void skipToNextMatchingEntry() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   605
                            while (currEntry != null && sf != null && !sf.accepts(currEntry.sym)) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   606
                                currEntry = currEntry.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   607
                            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   608
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   609
                    };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   610
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   611
            };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   612
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   613
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   614
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   615
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   616
                                                 final LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   617
            return new Iterable<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   618
                public Iterator<Symbol> iterator() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   619
                     return new Iterator<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   620
                        Scope.Entry currentEntry = lookup(name, sf);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   621
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   622
                        public boolean hasNext() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   623
                            return currentEntry.scope != null &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   624
                                    (lookupKind == RECURSIVE ||
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   625
                                     currentEntry.scope == ScopeImpl.this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   626
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   627
                        public Symbol next() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   628
                            Scope.Entry prevEntry = currentEntry;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   629
                            currentEntry = currentEntry.next(sf);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   630
                            return prevEntry.sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   631
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   632
                        public void remove() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   633
                            throw new UnsupportedOperationException();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   634
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   635
                    };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   636
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   637
            };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   638
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   639
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   640
        public Scope getOrigin(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   641
            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
   642
                if (e.sym == s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   643
                    return this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   644
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   645
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   646
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   647
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   648
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   649
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   650
        public boolean isStaticallyImported(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   651
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   652
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   653
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   654
        public String toString() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   655
            StringBuilder result = new StringBuilder();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   656
            result.append("Scope[");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   657
            for (ScopeImpl s = this; s != null ; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   658
                if (s != this) result.append(" | ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   659
                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
   660
                    if (e != s.elems) result.append(", ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   661
                    result.append(e.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   662
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   663
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   664
            result.append("]");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   665
            return result.toString();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   666
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   667
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   668
06bc494ca11e Initial load
duke
parents:
diff changeset
   669
    /** A class for scope entries.
06bc494ca11e Initial load
duke
parents:
diff changeset
   670
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   671
    private static class Entry {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   672
06bc494ca11e Initial load
duke
parents:
diff changeset
   673
        /** The referenced symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   674
         *  sym == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   675
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   676
        public Symbol sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   677
06bc494ca11e Initial load
duke
parents:
diff changeset
   678
        /** An entry with the same hash code, or sentinel.
06bc494ca11e Initial load
duke
parents:
diff changeset
   679
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   680
        private Entry shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   681
06bc494ca11e Initial load
duke
parents:
diff changeset
   682
        /** Next entry in same scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   683
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   684
        public Entry sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   685
06bc494ca11e Initial load
duke
parents:
diff changeset
   686
        /** The entry's scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   687
         *  scope == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   688
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   689
        public Scope scope;
06bc494ca11e Initial load
duke
parents:
diff changeset
   690
06bc494ca11e Initial load
duke
parents:
diff changeset
   691
        public Entry(Symbol sym, Entry shadowed, Entry sibling, Scope scope) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   692
            this.sym = sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   693
            this.shadowed = shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   694
            this.sibling = sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   695
            this.scope = scope;
06bc494ca11e Initial load
duke
parents:
diff changeset
   696
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   697
06bc494ca11e Initial load
duke
parents:
diff changeset
   698
        /** Return next entry with the same name as this entry, proceeding
06bc494ca11e Initial load
duke
parents:
diff changeset
   699
         *  outwards if not found in this scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   700
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   701
        public Entry next() {
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   702
            return shadowed;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   703
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   704
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   705
        public Entry next(Filter<Symbol> sf) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   706
            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
   707
            else return shadowed.next(sf);
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   708
        }
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   709
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   710
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   711
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   712
    public static class ImportScope extends CompoundScope {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   713
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   714
        public ImportScope(Symbol owner) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   715
            super(owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   716
        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   717
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   718
        /**Finalize the content of the ImportScope to speed-up future lookups.
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   719
         * 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
   720
         */
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   721
        public void finalizeScope() {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   722
            for (List<Scope> scopes = this.subScopes; scopes.nonEmpty(); scopes = scopes.tail) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   723
                Scope impScope = scopes.head;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   724
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   725
                if (impScope instanceof FilterImportScope && impScope.owner.kind == Kind.TYP) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   726
                    WriteableScope finalized = WriteableScope.create(impScope.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   727
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   728
                    for (Symbol sym : impScope.getSymbols()) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   729
                        finalized.enter(sym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   730
                    }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   731
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   732
                    finalized.listeners.add(new ScopeListener() {
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   733
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   734
                        public void symbolAdded(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   735
                            Assert.error("The scope is sealed.");
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   736
                        }
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   737
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   738
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   739
                        public void symbolRemoved(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   740
                            Assert.error("The scope is sealed.");
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
                    });
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   743
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   744
                    scopes.head = finalized;
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
            }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   747
        }
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
    }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   750
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   751
    public static class NamedImportScope extends ImportScope {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   752
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   753
        public NamedImportScope(Symbol owner, Scope currentFileScope) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   754
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   755
            prependSubScope(currentFileScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   756
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   757
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   758
        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
   759
            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
   760
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   761
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   762
        public Scope importType(Scope delegate, Scope origin, Symbol sym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   763
            return appendScope(new SingleEntryScope(delegate.owner, sym, origin));
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   764
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   765
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   766
        private Scope appendScope(Scope newScope) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   767
            List<Scope> existingScopes = this.subScopes.reverse();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   768
            subScopes = List.of(existingScopes.head);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   769
            subScopes = subScopes.prepend(newScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   770
            for (Scope s : existingScopes.tail) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   771
                subScopes = subScopes.prepend(s);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   772
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   773
            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
   774
        }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 18899
diff changeset
   775
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   776
        private static class SingleEntryScope extends Scope {
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
            private final Symbol sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   779
            private final List<Symbol> content;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   780
            private final Scope origin;
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
            public SingleEntryScope(Symbol owner, Symbol sym, Scope origin) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   783
                super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   784
                this.sym = sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   785
                this.content = List.of(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   786
                this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   787
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   788
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   789
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   790
            public Iterable<Symbol> getSymbols(Filter<Symbol> sf, LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   791
                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
   792
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   793
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   794
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   795
            public Iterable<Symbol> getSymbolsByName(Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   796
                                                     Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   797
                                                     LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   798
                return sym.name == name &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   799
                       (sf == null || sf.accepts(sym)) ? content : Collections.<Symbol>emptyList();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   800
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   801
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   802
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   803
            public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   804
                return sym == byName ? origin : null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   805
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   806
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   807
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   808
            public boolean isStaticallyImported(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   809
                return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   810
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   811
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   812
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   813
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   814
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   815
    public static class StarImportScope extends ImportScope {
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   816
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   817
        public StarImportScope(Symbol owner) {
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   818
            super(owner);
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   819
        }
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   820
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   821
        public void importAll(Types types, Scope origin,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   822
                              ImportFilter filter,
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   823
                              JCImport imp,
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   824
                              BiConsumer<JCImport, CompletionFailure> cfHandler) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   825
            for (Scope existing : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   826
                Assert.check(existing instanceof FilterImportScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   827
                FilterImportScope fis = (FilterImportScope) existing;
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   828
                if (fis.origin == origin && fis.filter == filter &&
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   829
                    fis.imp.staticImport == imp.staticImport)
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   830
                    return ; //avoid entering the same scope twice
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   831
            }
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   832
            prependSubScope(new FilterImportScope(types, origin, null, filter, imp, cfHandler));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   833
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   834
29149
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   835
        public boolean isFilled() {
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   836
            return subScopes.nonEmpty();
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   837
        }
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   838
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   839
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   840
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   841
    public interface ImportFilter {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   842
        public boolean accepts(Scope origin, Symbol sym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   843
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   844
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   845
    private static class FilterImportScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   846
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   847
        private final Types types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   848
        private final Scope origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   849
        private final Name  filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   850
        private final ImportFilter filter;
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   851
        private final JCImport imp;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   852
        private final BiConsumer<JCImport, CompletionFailure> cfHandler;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   853
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   854
        public FilterImportScope(Types types,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   855
                                 Scope origin,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   856
                                 Name  filterName,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   857
                                 ImportFilter filter,
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   858
                                 JCImport imp,
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   859
                                 BiConsumer<JCImport, CompletionFailure> cfHandler) {
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   860
            super(origin.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   861
            this.types = types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   862
            this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   863
            this.filterName = filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   864
            this.filter = filter;
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   865
            this.imp = imp;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   866
            this.cfHandler = cfHandler;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   867
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   868
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   869
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   870
        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
   871
            if (filterName != null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   872
                return getSymbolsByName(filterName, sf, lookupKind);
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   873
            try {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   874
                SymbolImporter si = new SymbolImporter(imp.staticImport) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   875
                    @Override
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   876
                    Iterable<Symbol> doLookup(TypeSymbol tsym) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   877
                        return tsym.members().getSymbols(sf, lookupKind);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   878
                    }
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   879
                };
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   880
                return si.importFrom((TypeSymbol) origin.owner) :: iterator;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   881
            } catch (CompletionFailure cf) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   882
                cfHandler.accept(imp, cf);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   883
                return Collections.emptyList();
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   884
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   885
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   886
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   887
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   888
        public Iterable<Symbol> getSymbolsByName(final Name name,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   889
                                                 final Filter<Symbol> sf,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   890
                                                 final LookupKind lookupKind) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   891
            if (filterName != null && filterName != name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   892
                return Collections.emptyList();
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   893
            try {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   894
                SymbolImporter si = new SymbolImporter(imp.staticImport) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   895
                    @Override
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   896
                    Iterable<Symbol> doLookup(TypeSymbol tsym) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   897
                        return tsym.members().getSymbolsByName(name, sf, lookupKind);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   898
                    }
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
                return si.importFrom((TypeSymbol) origin.owner) :: iterator;
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   901
            } catch (CompletionFailure cf) {
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   902
                cfHandler.accept(imp, cf);
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   903
                return Collections.emptyList();
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   904
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   905
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   906
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   907
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   908
        public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   909
            return origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   910
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   911
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   912
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   913
        public boolean isStaticallyImported(Symbol byName) {
32059
ea04f56aeacd 8131915: CompletionFailure during import listing crashes javac
jlahoda
parents: 31506
diff changeset
   914
            return imp.staticImport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   915
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   916
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   917
        abstract class SymbolImporter {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   918
            Set<Symbol> processed = new HashSet<>();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   919
            List<Iterable<Symbol>> delegates = List.nil();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   920
            final boolean inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   921
            public SymbolImporter(boolean inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   922
                this.inspectSuperTypes = inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   923
            }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   924
            Stream<Symbol> importFrom(TypeSymbol tsym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   925
                if (tsym == null || !processed.add(tsym))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   926
                    return Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   927
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   928
                Stream<Symbol> result = Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   929
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   930
                if (inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   931
                    // also import inherited names
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   932
                    result = importFrom(types.supertype(tsym.type).tsym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   933
                    for (Type t : types.interfaces(tsym.type))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   934
                        result = Stream.concat(importFrom(t.tsym), result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   935
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   936
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   937
                return Stream.concat(StreamSupport.stream(doLookup(tsym).spliterator(), false)
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   938
                                                  .filter(s -> filter.accepts(origin, s)),
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   939
                                     result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   940
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   941
            abstract Iterable<Symbol> doLookup(TypeSymbol tsym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   942
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   943
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   944
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   945
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   946
    /** 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
   947
     *  class scopes - this allows client to realize whether a class scope
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   948
     *  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
   949
     *  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
   950
     *  added/removed into a supertype scope)
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   951
     */
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   952
    public static class CompoundScope extends Scope implements ScopeListener {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   953
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   954
        List<Scope> subScopes = List.nil();
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   955
        private int mark = 0;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   956
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   957
        public CompoundScope(Symbol owner) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   958
            super(owner);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   959
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   960
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   961
        public void prependSubScope(Scope that) {
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   962
           if (that != null) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   963
                subScopes = subScopes.prepend(that);
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   964
                that.listeners.add(this);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   965
                mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   966
                listeners.symbolAdded(null, this);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   967
           }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   968
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   969
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   970
        public void symbolAdded(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   971
            mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   972
            listeners.symbolAdded(sym, s);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   973
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   974
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   975
        public void symbolRemoved(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   976
            mark++;
32454
b0ac04e0fefe 8129962: Investigate performance improvements in langtools combo tests
mcimadamore
parents: 32059
diff changeset
   977
            listeners.symbolRemoved(sym, s);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   978
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   979
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   980
        public int getMark() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   981
            return mark;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   982
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   983
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   984
        @Override
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   985
        public String toString() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   986
            StringBuilder buf = new StringBuilder();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   987
            buf.append("CompoundScope{");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   988
            String sep = "";
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   989
            for (Scope s : subScopes) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   990
                buf.append(sep);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   991
                buf.append(s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   992
                sep = ",";
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   993
            }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   994
            buf.append("}");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   995
            return buf.toString();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   996
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   997
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   998
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   999
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1000
                                           final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1001
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1002
                                                          scope -> scope.getSymbols(sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1003
                                                                                    lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1004
                                                                        .iterator());
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1005
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1006
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1007
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1008
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1009
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1010
                                                 final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1011
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1012
                                                          scope -> scope.getSymbolsByName(name,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1013
                                                                                          sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1014
                                                                                          lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
  1015
                                                                        .iterator());
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1016
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1017
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1018
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1019
        public Scope getOrigin(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1020
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1021
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1022
                    return delegate.getOrigin(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1023
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1024
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1025
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1026
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1027
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1028
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1029
        public boolean isStaticallyImported(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1030
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1031
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1032
                    return delegate.isStaticallyImported(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1033
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1034
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1035
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1036
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1037
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1038
    }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
  1039
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1040
    /** 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
  1041
    public static class ErrorScope extends ScopeImpl {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1042
        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
  1043
            super(next, /*owner=*/errSymbol, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1044
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1045
        public ErrorScope(Symbol errSymbol) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1046
            super(errSymbol);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1047
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1048
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1049
            return new ErrorScope(this, newOwner, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1050
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1051
        public WriteableScope dupUnshared(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1052
            return new ErrorScope(this, newOwner, table.clone());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1053
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1054
        public Entry lookup(Name name) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1055
            Entry e = super.lookup(name);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1056
            if (e.scope == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1057
                return new Entry(owner, null, null, null);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1058
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1059
                return e;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1060
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1061
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1062
}