langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/code/Scope.java
author jlahoda
Wed, 01 Jul 2015 09:51:48 +0200
changeset 31506 4e07f827a794
parent 30999 f1bb0191a5a7
child 32059 ea04f56aeacd
permissions -rw-r--r--
8072480: javac should support compilation for a specific platform version Summary: Adding a new javac option for compiling for JDK N: -release N; including history data for previous version of JDK. Reviewed-by: erikj, ihse, jjg, mcimadamore, mr Contributed-by: jan.lahoda@oracle.com, erik.joelsson@oracle.com, jonathan.gibbons@oracle.com
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;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    29
import java.util.*;
14258
8d2148961366 8000663: clean up langtools imports
jjg
parents: 9593
diff changeset
    30
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    31
import com.sun.tools.javac.code.Symbol.TypeSymbol;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    32
import com.sun.tools.javac.tree.JCTree.JCImport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    33
import com.sun.tools.javac.util.*;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    34
import com.sun.tools.javac.util.List;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    35
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    36
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
    37
import static com.sun.tools.javac.code.Scope.LookupKind.RECURSIVE;
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    38
import java.util.stream.Stream;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
    39
import java.util.stream.StreamSupport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    40
06bc494ca11e Initial load
duke
parents:
diff changeset
    41
/** A scope represents an area of visibility in a Java program. The
06bc494ca11e Initial load
duke
parents:
diff changeset
    42
 *  Scope class is a container for symbols which provides
06bc494ca11e Initial load
duke
parents:
diff changeset
    43
 *  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
    44
 *  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
    45
 *  Scopes can be nested. Nested scopes can share their hash tables.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    46
 *
5847
1908176fd6e3 6944312: Potential rebranding issues in openjdk/langtools repository sources
jjg
parents: 5520
diff changeset
    47
 *  <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
    48
 *  If you write code that depends on this, you do so at your own risk.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    49
 *  This code and its internal interfaces are subject to change or
06bc494ca11e Initial load
duke
parents:
diff changeset
    50
 *  deletion without notice.</b>
06bc494ca11e Initial load
duke
parents:
diff changeset
    51
 */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    52
public abstract class Scope {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    53
06bc494ca11e Initial load
duke
parents:
diff changeset
    54
    /** The scope's owner.
06bc494ca11e Initial load
duke
parents:
diff changeset
    55
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    56
    public final Symbol owner;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    57
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    58
    protected Scope(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    59
        this.owner = owner;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    60
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    61
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    62
    /**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
    63
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    64
    public final Iterable<Symbol> getSymbols() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    65
        return getSymbols(noFilter);
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    68
    /**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
    69
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    70
    public final Iterable<Symbol> getSymbols(Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    71
        return getSymbols(sf, RECURSIVE);
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    74
    /**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
    75
     * iff lookupKind == RECURSIVE.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    76
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    77
    public final Iterable<Symbol> getSymbols(LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    78
        return getSymbols(noFilter, lookupKind);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    79
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    80
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    81
    /**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
    82
     * iff lookupKind == RECURSIVE.
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
    public abstract Iterable<Symbol> getSymbols(Filter<Symbol> sf, LookupKind lookupKind);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    85
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    86
    /**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
    87
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    88
    public final Iterable<Symbol> getSymbolsByName(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    89
        return getSymbolsByName(name, RECURSIVE);
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    92
    /**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
    93
     * Symbols from outward Scopes are included.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
    94
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    95
    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
    96
        return getSymbolsByName(name, sf, RECURSIVE);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    97
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    98
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
    99
    /**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
   100
     * iff lookupKind == RECURSIVE.
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
    public final Iterable<Symbol> getSymbolsByName(Name name, LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   103
        return getSymbolsByName(name, noFilter, lookupKind);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   104
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   105
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   106
    /**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
   107
     * Symbols from outward Scopes are included iff lookupKind == RECURSIVE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   108
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   109
    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
   110
            final LookupKind lookupKind);
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
    /** 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
   113
     * Returns null if none.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   114
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   115
    public final Symbol findFirst(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   116
        return findFirst(name, noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   117
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   118
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   119
    /** 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
   120
     *  given filter. Returns null if none.
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
    public Symbol findFirst(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   123
        Iterator<Symbol> it = getSymbolsByName(name, sf).iterator();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   124
        return it.hasNext() ? it.next() : null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   125
    }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   126
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   127
    /** 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
   128
     *  Does not inspect outward scopes.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   129
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   130
    public boolean anyMatch(Filter<Symbol> filter) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   131
        return getSymbols(filter, NON_RECURSIVE).iterator().hasNext();
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   134
    /** Returns true iff the given Symbol is in this scope or any outward scope.
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   135
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   136
    public boolean includes(final Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   137
        return getSymbolsByName(sym.name, new Filter<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   138
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   139
            public boolean accepts(Symbol t) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   140
                return t == sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   141
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   142
        }).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   143
    }
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
    /** 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
   146
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   147
    public boolean isEmpty() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   148
        return !getSymbols(NON_RECURSIVE).iterator().hasNext();
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   151
    /** 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
   152
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   153
    public abstract Scope getOrigin(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   154
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   155
    /** Returns 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
   156
     */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   157
    public abstract boolean isStaticallyImported(Symbol byName);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   158
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   159
    private static final Filter<Symbol> noFilter = null;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   160
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   161
    /** 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
   162
     */
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   163
    List<ScopeListener> listeners = List.nil();
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   164
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   165
    public void addScopeListener(ScopeListener sl) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   166
        listeners = listeners.prepend(sl);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   167
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   168
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   169
    public interface ScopeListener {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   170
        public void symbolAdded(Symbol sym, Scope s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   171
        public void symbolRemoved(Symbol sym, Scope s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   172
    }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   173
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   174
    public enum LookupKind {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   175
        RECURSIVE,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   176
        NON_RECURSIVE;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   177
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   178
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   179
    /**A scope into which Symbols can be added.*/
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   180
    public abstract static class WriteableScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   181
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   182
        public WriteableScope(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   183
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   184
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   185
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   186
        /** Enter the given Symbol into this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   187
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   188
        public abstract void enter(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   189
        /** 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
   190
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   191
        public abstract void enterIfAbsent(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   192
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   193
        public abstract void remove(Symbol c);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   194
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   195
        /** 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
   196
         *  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
   197
         *  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
   198
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   199
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   200
        public final WriteableScope dup() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   201
            return dup(this.owner);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   202
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   203
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   204
        /** 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
   205
         *  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
   206
         *  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
   207
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   208
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   209
        public abstract WriteableScope dup(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   210
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   211
        /** 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
   212
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   213
        public abstract WriteableScope leave();
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   214
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   215
        /** 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
   216
         *  will not share internal structures with this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   217
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   218
        public final WriteableScope dupUnshared() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   219
            return dupUnshared(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   220
        }
18899
2557b27d1f1c 6356530: -Xlint:serial does not flag abstract classes with concrete methods/members
vromero
parents: 14258
diff changeset
   221
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   222
        /** 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
   223
         *  will not share internal structures with 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 WriteableScope dupUnshared(Symbol newOwner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   226
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   227
        /** Create a new WriteableScope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   228
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   229
        public static WriteableScope create(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   230
            return new ScopeImpl(owner);
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
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   233
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   234
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   235
    private static class ScopeImpl extends WriteableScope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   236
        /** 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
   237
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   238
        private int shared;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   239
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   240
        /** 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
   241
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   242
        public ScopeImpl next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   243
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   244
        /** A hash table for the scope's entries.
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
        Entry[] table;
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
        /** 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
   249
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   250
        int hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   251
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   252
        /** A linear list that also contains all entries in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   253
         *  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
   254
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   255
        public Entry elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   256
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   257
        /** The number of elements in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   258
         * This includes deleted elements, whose value is the sentinel.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   259
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   260
        int nelems = 0;
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
        /** Use as a "not-found" result for lookup.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   263
         * Also used to mark deleted entries in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   264
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   265
        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
   266
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   267
        /** The hash table's initial size.
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
        private static final int INITIAL_SIZE = 0x10;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   270
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   271
        /** 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
   272
         *  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
   273
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   274
        private ScopeImpl(ScopeImpl next, Symbol owner, Entry[] table) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   275
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   276
            this.next = next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   277
            Assert.check(owner != null);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   278
            this.table = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   279
            this.hashMask = table.length - 1;
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   282
        /** Convenience constructor used for dup and dupUnshared. */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   283
        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
   284
            this(next, owner, table);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   285
            this.nelems = nelems;
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   286
        }
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   287
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   288
        /** 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
   289
         *  using a fresh table of length INITIAL_SIZE.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   290
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   291
        public ScopeImpl(Symbol owner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   292
            this(null, owner, new Entry[INITIAL_SIZE]);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   293
        }
6591
a953c8c6b85e 6337171: javac should create bridge methods when type variable bounds restricted
mcimadamore
parents: 5847
diff changeset
   294
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   295
        /** 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
   296
         *  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
   297
         *  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
   298
         *  of fresh tables.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   299
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   300
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   301
            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
   302
            shared++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   303
            // 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
   304
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   305
            return result;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   306
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   307
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   308
        /** 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
   309
         *  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
   310
         *  the table of its outer scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   311
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   312
        public WriteableScope dupUnshared(Symbol newOwner) {
27553
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   313
            if (shared > 0) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   314
                //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
   315
                //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
   316
                Set<Scope> acceptScopes = Collections.newSetFromMap(new IdentityHashMap<>());
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   317
                ScopeImpl c = this;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   318
                while (c != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   319
                    acceptScopes.add(c);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   320
                    c = c.next;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   321
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   322
                int n = 0;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   323
                Entry[] oldTable = this.table;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   324
                Entry[] newTable = new Entry[this.table.length];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   325
                for (int i = 0; i < oldTable.length; i++) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   326
                    Entry e = oldTable[i];
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   327
                    while (e != null && e != sentinel && !acceptScopes.contains(e.scope)) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   328
                        e = e.shadowed;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   329
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   330
                    if (e != null) {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   331
                        n++;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   332
                        newTable[i] = e;
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   333
                    }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   334
                }
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   335
                return new ScopeImpl(this, newOwner, newTable, n);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   336
            } else {
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   337
                return new ScopeImpl(this, newOwner, this.table.clone(), this.nelems);
75321debd020 8064362: WriteableScope.dupUnshared misbehaves on shared Scopes
jlahoda
parents: 25874
diff changeset
   338
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   339
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   340
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   341
        /** 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
   342
         *  with next.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   343
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   344
        public WriteableScope leave() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   345
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   346
            if (table != next.table) return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   347
            while (elems != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   348
                int hash = getIndex(elems.sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   349
                Entry e = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   350
                Assert.check(e == elems, elems.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   351
                table[hash] = elems.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   352
                elems = elems.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   353
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   354
            Assert.check(next.shared > 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   355
            next.shared--;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   356
            next.nelems = nelems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   357
            // 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
   358
            // new Error().printStackTrace(System.out);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   359
            return next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   360
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   361
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   362
        /** Double size of hash table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   363
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   364
        private void dble() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   365
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   366
            Entry[] oldtable = table;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   367
            Entry[] newtable = new Entry[oldtable.length * 2];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   368
            for (ScopeImpl s = this; s != null; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   369
                if (s.table == oldtable) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   370
                    Assert.check(s == this || s.shared != 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   371
                    s.table = newtable;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   372
                    s.hashMask = newtable.length - 1;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   373
                }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   374
            }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   375
            int n = 0;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   376
            for (int i = oldtable.length; --i >= 0; ) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   377
                Entry e = oldtable[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   378
                if (e != null && e != sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   379
                    table[getIndex(e.sym.name)] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   380
                    n++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   381
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   382
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   383
            // 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
   384
            // since that gets handled by leave().
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   385
            nelems = n;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   386
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   387
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   388
        /** Enter symbol sym in this scope.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   389
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   390
        public void enter(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   391
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   392
            if (nelems * 3 >= hashMask * 2)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   393
                dble();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   394
            int hash = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   395
            Entry old = table[hash];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   396
            if (old == null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   397
                old = sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   398
                nelems++;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   399
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   400
            Entry e = new Entry(sym, old, elems, this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   401
            table[hash] = e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   402
            elems = e;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   403
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   404
            //notify listeners
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   405
            for (List<ScopeListener> l = listeners; l.nonEmpty(); l = l.tail) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   406
                l.head.symbolAdded(sym, this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   407
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   408
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   409
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   410
        /** Remove symbol from this scope.
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   411
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   412
        public void remove(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   413
            Assert.check(shared == 0);
30999
f1bb0191a5a7 8080842: Using Lambda Expression with name clash results in ClassFormatError
sadayapalam
parents: 29149
diff changeset
   414
            Entry e = lookup(sym.name, candidate -> candidate == sym);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   415
            if (e.scope == null) return;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   416
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   417
            // remove e from table and shadowed list;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   418
            int i = getIndex(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   419
            Entry te = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   420
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   421
                table[i] = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   422
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   423
                if (te.shadowed == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   424
                    te.shadowed = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   425
                    break;
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
                te = te.shadowed;
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   428
            }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   429
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   430
            // remove e from elems and sibling list
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   431
            te = elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   432
            if (te == e)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   433
                elems = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   434
            else while (true) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   435
                if (te.sibling == e) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   436
                    te.sibling = e.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   437
                    break;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   438
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   439
                te = te.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   440
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   441
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   442
            //notify listeners
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   443
            for (List<ScopeListener> l = listeners; l.nonEmpty(); l = l.tail) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   444
                l.head.symbolRemoved(sym, this);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   445
            }
06bc494ca11e Initial load
duke
parents:
diff changeset
   446
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   447
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   448
        /** 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
   449
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   450
        public void enterIfAbsent(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   451
            Assert.check(shared == 0);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   452
            Entry e = lookup(sym.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   453
            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
   454
            if (e.scope != this) enter(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   455
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   456
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   457
        /** 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
   458
         *  qualified name in this (import) scope?
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   459
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   460
        public boolean includes(Symbol c) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   461
            for (Scope.Entry e = lookup(c.name);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   462
                 e.scope == this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   463
                 e = e.next()) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   464
                if (e.sym == c) return true;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   465
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   466
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   467
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   468
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   469
        /** Return the entry associated with given name, starting in
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   470
         *  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
   471
         *  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
   472
         *  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
   473
         *  for regular entries.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   474
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   475
        protected Entry lookup(Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   476
            return lookup(name, noFilter);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   477
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   478
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   479
        protected Entry lookup(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   480
            Entry e = table[getIndex(name)];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   481
            if (e == null || e == sentinel)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   482
                return sentinel;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   483
            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
   484
                e = e.shadowed;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   485
            return e;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   486
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   487
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   488
        public Symbol findFirst(Name name, Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   489
            return lookup(name, sf).sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   490
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   491
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   492
        /*void dump (java.io.PrintStream out) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   493
            out.println(this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   494
            for (int l=0; l < table.length; l++) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   495
                Entry le = table[l];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   496
                out.print("#"+l+": ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   497
                if (le==sentinel) out.println("sentinel");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   498
                else if(le == null) out.println("null");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   499
                else out.println(""+le+" s:"+le.sym);
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   503
        /** Look for slot in the table.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   504
         *  We use open addressing with double hashing.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   505
         */
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   506
        int getIndex (Name name) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   507
            int h = name.hashCode();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   508
            int i = h & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   509
            // 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
   510
            // 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
   511
            int x = hashMask - ((h + (h >> 16)) << 1);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   512
            int d = -1; // Index of a deleted item.
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   513
            for (;;) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   514
                Entry e = table[i];
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   515
                if (e == null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   516
                    return d >= 0 ? d : i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   517
                if (e == sentinel) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   518
                    // 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
   519
                    // 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
   520
                    if (d < 0)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   521
                        d = i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   522
                } else if (e.sym.name == name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   523
                    return i;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   524
                i = (i + x) & hashMask;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   525
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   526
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   527
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   528
        public boolean anyMatch(Filter<Symbol> sf) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   529
            return getSymbols(sf, NON_RECURSIVE).iterator().hasNext();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   530
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   531
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   532
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   533
                                           final LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   534
            return new Iterable<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   535
                public Iterator<Symbol> iterator() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   536
                    return new Iterator<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   537
                        private ScopeImpl currScope = ScopeImpl.this;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   538
                        private Scope.Entry currEntry = elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   539
                        {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   540
                            update();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   541
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   542
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   543
                        public boolean hasNext() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   544
                            return currEntry != null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   545
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   546
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   547
                        public Symbol next() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   548
                            Symbol sym = (currEntry == null ? null : currEntry.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   549
                            if (currEntry != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   550
                                currEntry = currEntry.sibling;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   551
                            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   552
                            update();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   553
                            return sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   554
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   555
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   556
                        public void remove() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   557
                            throw new UnsupportedOperationException();
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
                        private void update() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   561
                            skipToNextMatchingEntry();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   562
                            if (lookupKind == RECURSIVE) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   563
                                while (currEntry == null && currScope.next != null) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   564
                                    currScope = currScope.next;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   565
                                    currEntry = currScope.elems;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   566
                                    skipToNextMatchingEntry();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   567
                                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   568
                            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   569
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   570
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   571
                        void skipToNextMatchingEntry() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   572
                            while (currEntry != null && sf != null && !sf.accepts(currEntry.sym)) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   573
                                currEntry = currEntry.sibling;
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
                    };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   577
                }
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
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   581
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   582
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   583
                                                 final LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   584
            return new Iterable<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   585
                public Iterator<Symbol> iterator() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   586
                     return new Iterator<Symbol>() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   587
                        Scope.Entry currentEntry = lookup(name, sf);
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 boolean hasNext() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   590
                            return currentEntry.scope != null &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   591
                                    (lookupKind == RECURSIVE ||
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   592
                                     currentEntry.scope == ScopeImpl.this);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   593
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   594
                        public Symbol next() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   595
                            Scope.Entry prevEntry = currentEntry;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   596
                            currentEntry = currentEntry.next(sf);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   597
                            return prevEntry.sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   598
                        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   599
                        public void remove() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   600
                            throw new UnsupportedOperationException();
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
            };
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   605
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   606
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   607
        public Scope getOrigin(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   608
            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
   609
                if (e.sym == s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   610
                    return this;
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
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   614
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   615
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   616
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   617
        public boolean isStaticallyImported(Symbol s) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   618
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   619
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   620
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   621
        public String toString() {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   622
            StringBuilder result = new StringBuilder();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   623
            result.append("Scope[");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   624
            for (ScopeImpl s = this; s != null ; s = s.next) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   625
                if (s != this) result.append(" | ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   626
                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
   627
                    if (e != s.elems) result.append(", ");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   628
                    result.append(e.sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   629
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   630
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   631
            result.append("]");
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   632
            return result.toString();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   633
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   634
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   635
06bc494ca11e Initial load
duke
parents:
diff changeset
   636
    /** A class for scope entries.
06bc494ca11e Initial load
duke
parents:
diff changeset
   637
     */
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   638
    private static class Entry {
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   639
06bc494ca11e Initial load
duke
parents:
diff changeset
   640
        /** The referenced symbol.
06bc494ca11e Initial load
duke
parents:
diff changeset
   641
         *  sym == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   642
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   643
        public Symbol sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   644
06bc494ca11e Initial load
duke
parents:
diff changeset
   645
        /** An entry with the same hash code, or sentinel.
06bc494ca11e Initial load
duke
parents:
diff changeset
   646
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   647
        private Entry shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   648
06bc494ca11e Initial load
duke
parents:
diff changeset
   649
        /** Next entry in same scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   650
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   651
        public Entry sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   652
06bc494ca11e Initial load
duke
parents:
diff changeset
   653
        /** The entry's scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   654
         *  scope == null   iff   this == sentinel
06bc494ca11e Initial load
duke
parents:
diff changeset
   655
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   656
        public Scope scope;
06bc494ca11e Initial load
duke
parents:
diff changeset
   657
06bc494ca11e Initial load
duke
parents:
diff changeset
   658
        public Entry(Symbol sym, Entry shadowed, Entry sibling, Scope scope) {
06bc494ca11e Initial load
duke
parents:
diff changeset
   659
            this.sym = sym;
06bc494ca11e Initial load
duke
parents:
diff changeset
   660
            this.shadowed = shadowed;
06bc494ca11e Initial load
duke
parents:
diff changeset
   661
            this.sibling = sibling;
06bc494ca11e Initial load
duke
parents:
diff changeset
   662
            this.scope = scope;
06bc494ca11e Initial load
duke
parents:
diff changeset
   663
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   664
06bc494ca11e Initial load
duke
parents:
diff changeset
   665
        /** Return next entry with the same name as this entry, proceeding
06bc494ca11e Initial load
duke
parents:
diff changeset
   666
         *  outwards if not found in this scope.
06bc494ca11e Initial load
duke
parents:
diff changeset
   667
         */
06bc494ca11e Initial load
duke
parents:
diff changeset
   668
        public Entry next() {
7206
02edd110358f 6998063: new Scope impl to fix Scope performance issues
jjg
parents: 7079
diff changeset
   669
            return shadowed;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   670
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   671
7628
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   672
        public Entry next(Filter<Symbol> sf) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   673
            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
   674
            else return shadowed.next(sf);
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   675
        }
e7baeb97d164 6476118: compiler bug causes runtime ClassCastException for generics overloading
mcimadamore
parents: 7615
diff changeset
   676
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   677
    }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   678
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   679
    public static class ImportScope extends CompoundScope {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   680
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   681
        public ImportScope(Symbol owner) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   682
            super(owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   683
        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   684
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   685
        /**Finalize the content of the ImportScope to speed-up future lookups.
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   686
         * 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
   687
         */
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   688
        public void finalizeScope() {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   689
            for (List<Scope> scopes = this.subScopes; scopes.nonEmpty(); scopes = scopes.tail) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   690
                Scope impScope = scopes.head;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   691
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   692
                if (impScope instanceof FilterImportScope && impScope.owner.kind == Kind.TYP) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   693
                    WriteableScope finalized = WriteableScope.create(impScope.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   694
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   695
                    for (Symbol sym : impScope.getSymbols()) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   696
                        finalized.enter(sym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   697
                    }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   698
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   699
                    finalized.addScopeListener(new ScopeListener() {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   700
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   701
                        public void symbolAdded(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   702
                            Assert.error("The scope is sealed.");
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   703
                        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   704
                        @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   705
                        public void symbolRemoved(Symbol sym, Scope s) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   706
                            Assert.error("The scope is sealed.");
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   707
                        }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   708
                    });
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   709
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   710
                    scopes.head = finalized;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   711
                }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   712
            }
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
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   715
    }
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
    public static class NamedImportScope extends ImportScope {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   718
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   719
        public NamedImportScope(Symbol owner, Scope currentFileScope) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   720
            super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   721
            prependSubScope(currentFileScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   722
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   723
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   724
        public Scope importByName(Types types, Scope origin, Name name, ImportFilter filter) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   725
            return appendScope(new FilterImportScope(types, origin, name, filter, true));
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   726
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   727
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   728
        public Scope importType(Scope delegate, Scope origin, Symbol sym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   729
            return appendScope(new SingleEntryScope(delegate.owner, sym, origin));
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   730
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   731
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   732
        private Scope appendScope(Scope newScope) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   733
            List<Scope> existingScopes = this.subScopes.reverse();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   734
            subScopes = List.of(existingScopes.head);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   735
            subScopes = subScopes.prepend(newScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   736
            for (Scope s : existingScopes.tail) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   737
                subScopes = subScopes.prepend(s);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   738
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   739
            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
   740
        }
767d7330011f 6537020: JCK tests: a compile-time error should be given in case of ambiguously imported fields (types, methods)
mcimadamore
parents: 18899
diff changeset
   741
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   742
        private static class SingleEntryScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   743
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   744
            private final Symbol sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   745
            private final List<Symbol> content;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   746
            private final Scope origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   747
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   748
            public SingleEntryScope(Symbol owner, Symbol sym, Scope origin) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   749
                super(owner);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   750
                this.sym = sym;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   751
                this.content = List.of(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   752
                this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   753
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   754
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   755
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   756
            public Iterable<Symbol> getSymbols(Filter<Symbol> sf, LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   757
                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
   758
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   759
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   760
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   761
            public Iterable<Symbol> getSymbolsByName(Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   762
                                                     Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   763
                                                     LookupKind lookupKind) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   764
                return sym.name == name &&
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   765
                       (sf == null || sf.accepts(sym)) ? content : Collections.<Symbol>emptyList();
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   766
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   767
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   768
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   769
            public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   770
                return sym == byName ? origin : null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   771
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   772
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   773
            @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   774
            public boolean isStaticallyImported(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   775
                return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   776
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   777
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   778
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
   779
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   780
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   781
    public static class StarImportScope extends ImportScope {
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   782
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   783
        public StarImportScope(Symbol owner) {
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   784
            super(owner);
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   785
        }
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   786
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   787
        public void importAll(Types types, Scope origin,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   788
                              ImportFilter filter,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   789
                              boolean staticImport) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   790
            for (Scope existing : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   791
                Assert.check(existing instanceof FilterImportScope);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   792
                FilterImportScope fis = (FilterImportScope) existing;
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   793
                if (fis.origin == origin && fis.filter == filter &&
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   794
                    fis.staticImport == staticImport)
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   795
                    return ; //avoid entering the same scope twice
7615
8bc078486f2b 7004029: intermittent failures compiling pack200
jjg
parents: 7329
diff changeset
   796
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   797
            prependSubScope(new FilterImportScope(types, origin, null, filter, staticImport));
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   798
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   799
29149
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   800
        public boolean isFilled() {
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   801
            return subScopes.nonEmpty();
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   802
        }
3fa94aad0264 8067886: Inaccessible nested classes can be incorrectly imported
jlahoda
parents: 27857
diff changeset
   803
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   804
    }
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
    public interface ImportFilter {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   807
        public boolean accepts(Scope origin, Symbol sym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   808
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   809
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   810
    private static class FilterImportScope extends Scope {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   811
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   812
        private final Types types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   813
        private final Scope origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   814
        private final Name  filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   815
        private final ImportFilter filter;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   816
        private final boolean staticImport;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   817
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   818
        public FilterImportScope(Types types,
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   819
                                 Scope origin,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   820
                                 Name  filterName,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   821
                                 ImportFilter filter,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   822
                                 boolean staticImport) {
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   823
            super(origin.owner);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   824
            this.types = types;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   825
            this.origin = origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   826
            this.filterName = filterName;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   827
            this.filter = filter;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   828
            this.staticImport = staticImport;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   829
        }
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   830
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   831
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   832
        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
   833
            if (filterName != null)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   834
                return getSymbolsByName(filterName, sf, lookupKind);
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   835
            SymbolImporter si = new SymbolImporter(staticImport) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   836
                @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   837
                Iterable<Symbol> doLookup(TypeSymbol tsym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   838
                    return tsym.members().getSymbols(sf, lookupKind);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   839
                }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   840
            };
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   841
            return si.importFrom((TypeSymbol) origin.owner) :: iterator;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   842
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   843
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   844
        @Override
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   845
        public Iterable<Symbol> getSymbolsByName(final Name name,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   846
                                                 final Filter<Symbol> sf,
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   847
                                                 final LookupKind lookupKind) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   848
            if (filterName != null && filterName != name)
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   849
                return Collections.emptyList();
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   850
            SymbolImporter si = new SymbolImporter(staticImport) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   851
                @Override
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   852
                Iterable<Symbol> doLookup(TypeSymbol tsym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   853
                    return tsym.members().getSymbolsByName(name, sf, lookupKind);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   854
                }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   855
            };
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   856
            return si.importFrom((TypeSymbol) origin.owner) :: iterator;
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   857
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   858
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   859
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   860
        public Scope getOrigin(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   861
            return origin;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   862
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   863
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   864
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   865
        public boolean isStaticallyImported(Symbol byName) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   866
            return staticImport;
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   867
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   868
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   869
        abstract class SymbolImporter {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   870
            Set<Symbol> processed = new HashSet<>();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   871
            List<Iterable<Symbol>> delegates = List.nil();
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   872
            final boolean inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   873
            public SymbolImporter(boolean inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   874
                this.inspectSuperTypes = inspectSuperTypes;
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   875
            }
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   876
            Stream<Symbol> importFrom(TypeSymbol tsym) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   877
                if (tsym == null || !processed.add(tsym))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   878
                    return Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   879
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   880
                Stream<Symbol> result = Stream.empty();
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   881
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   882
                if (inspectSuperTypes) {
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   883
                    // also import inherited names
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   884
                    result = importFrom(types.supertype(tsym.type).tsym);
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   885
                    for (Type t : types.interfaces(tsym.type))
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   886
                        result = Stream.concat(importFrom(t.tsym), result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   887
                }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   888
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   889
                return Stream.concat(StreamSupport.stream(doLookup(tsym).spliterator(), false)
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   890
                                                  .filter(s -> filter.accepts(origin, s)),
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   891
                                     result);
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   892
            }
27857
7e913a535736 7101822: Compiling depends on order of imports
jlahoda
parents: 27553
diff changeset
   893
            abstract Iterable<Symbol> doLookup(TypeSymbol tsym);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   894
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   895
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   896
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
   897
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   898
    /** 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
   899
     *  class scopes - this allows client to realize whether a class scope
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   900
     *  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
   901
     *  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
   902
     *  added/removed into a supertype scope)
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   903
     */
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   904
    public static class CompoundScope extends Scope implements ScopeListener {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   905
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   906
        List<Scope> subScopes = List.nil();
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   907
        private int mark = 0;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   908
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   909
        public CompoundScope(Symbol owner) {
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   910
            super(owner);
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   911
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   912
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   913
        public void prependSubScope(Scope that) {
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   914
           if (that != null) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   915
                subScopes = subScopes.prepend(that);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   916
                that.addScopeListener(this);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   917
                mark++;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   918
                for (ScopeListener sl : listeners) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   919
                    sl.symbolAdded(null, this); //propagate upwards in case of nested CompoundScopes
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   920
                }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   921
           }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   922
        }
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   923
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   924
        public void symbolAdded(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   925
            mark++;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   926
            for (ScopeListener sl : listeners) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   927
                sl.symbolAdded(sym, s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   928
            }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   929
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   930
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   931
        public void symbolRemoved(Symbol sym, Scope s) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   932
            mark++;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   933
            for (ScopeListener sl : listeners) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   934
                sl.symbolRemoved(sym, s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   935
            }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   936
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   937
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   938
        public int getMark() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   939
            return mark;
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   940
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   941
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   942
        @Override
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   943
        public String toString() {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   944
            StringBuilder buf = new StringBuilder();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   945
            buf.append("CompoundScope{");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   946
            String sep = "";
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   947
            for (Scope s : subScopes) {
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   948
                buf.append(sep);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   949
                buf.append(s);
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   950
                sep = ",";
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
            buf.append("}");
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   953
            return buf.toString();
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   954
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   955
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   956
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   957
        public Iterable<Symbol> getSymbols(final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   958
                                           final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   959
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   960
                                                          scope -> scope.getSymbols(sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   961
                                                                                    lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   962
                                                                        .iterator());
8427
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   963
        }
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   964
703181b01773 7017664: Add listeners infrastracture to javac scopes
mcimadamore
parents: 8242
diff changeset
   965
        @Override
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   966
        public Iterable<Symbol> getSymbolsByName(final Name name,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   967
                                                 final Filter<Symbol> sf,
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   968
                                                 final LookupKind lookupKind) {
31506
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   969
            return () -> Iterators.createCompoundIterator(subScopes,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   970
                                                          scope -> scope.getSymbolsByName(name,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   971
                                                                                          sf,
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   972
                                                                                          lookupKind)
4e07f827a794 8072480: javac should support compilation for a specific platform version
jlahoda
parents: 30999
diff changeset
   973
                                                                        .iterator());
8427
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
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   976
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   977
        public Scope getOrigin(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   978
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   979
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   980
                    return delegate.getOrigin(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   981
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   982
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   983
            return null;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   984
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   985
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   986
        @Override
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   987
        public boolean isStaticallyImported(Symbol sym) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   988
            for (Scope delegate : subScopes) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   989
                if (delegate.includes(sym))
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   990
                    return delegate.isStaticallyImported(sym);
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   991
            }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   992
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   993
            return false;
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   994
        }
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
   995
8427
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
10
06bc494ca11e Initial load
duke
parents:
diff changeset
   998
    /** 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
   999
    public static class ErrorScope extends ScopeImpl {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1000
        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
  1001
            super(next, /*owner=*/errSymbol, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1002
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1003
        public ErrorScope(Symbol errSymbol) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1004
            super(errSymbol);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1005
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1006
        public WriteableScope dup(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1007
            return new ErrorScope(this, newOwner, table);
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1008
        }
25443
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1009
        public WriteableScope dupUnshared(Symbol newOwner) {
9187d77f2c64 8031569: Refactor javac scope implementation to enable lazy imports
jlahoda
parents: 19492
diff changeset
  1010
            return new ErrorScope(this, newOwner, table.clone());
10
06bc494ca11e Initial load
duke
parents:
diff changeset
  1011
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1012
        public Entry lookup(Name name) {
06bc494ca11e Initial load
duke
parents:
diff changeset
  1013
            Entry e = super.lookup(name);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1014
            if (e.scope == null)
06bc494ca11e Initial load
duke
parents:
diff changeset
  1015
                return new Entry(owner, null, null, null);
06bc494ca11e Initial load
duke
parents:
diff changeset
  1016
            else
06bc494ca11e Initial load
duke
parents:
diff changeset
  1017
                return e;
06bc494ca11e Initial load
duke
parents:
diff changeset
  1018
        }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1019
    }
06bc494ca11e Initial load
duke
parents:
diff changeset
  1020
}