001 /*
002 * Copyright 2010-2015 JetBrains s.r.o.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 */
016
017 package org.jetbrains.kotlin.resolve.scopes;
018
019 import kotlin.Unit;
020 import kotlin.jvm.functions.Function1;
021 import org.jetbrains.annotations.NotNull;
022 import org.jetbrains.annotations.Nullable;
023 import org.jetbrains.annotations.TestOnly;
024 import org.jetbrains.kotlin.descriptors.*;
025 import org.jetbrains.kotlin.utils.Printer;
026
027 public final class JetScopeUtils {
028 private JetScopeUtils() {}
029
030 @NotNull
031 public static MemberScope getStaticNestedClassesScope(@NotNull ClassDescriptor descriptor) {
032 MemberScope innerClassesScope = descriptor.getUnsubstitutedInnerClassesScope();
033 return new FilteringScope(innerClassesScope, new Function1<DeclarationDescriptor, Boolean>() {
034 @Override
035 public Boolean invoke(DeclarationDescriptor descriptor) {
036 return descriptor instanceof ClassDescriptor && !((ClassDescriptor) descriptor).isInner();
037 }
038 });
039 }
040
041 public static LexicalScope makeScopeForPropertyHeader(
042 @NotNull LexicalScope parent,
043 @NotNull final PropertyDescriptor propertyDescriptor
044 ) {
045 return new LexicalScopeImpl(parent, propertyDescriptor, false, null, LexicalScopeKind.PROPERTY_HEADER,
046 // redeclaration on type parameters should be reported early, see: DescriptorResolver.resolvePropertyDescriptor()
047 RedeclarationHandler.DO_NOTHING,
048 new Function1<LexicalScopeImpl.InitializeHandler, Unit>() {
049 @Override
050 public Unit invoke(LexicalScopeImpl.InitializeHandler handler) {
051 for (TypeParameterDescriptor typeParameterDescriptor : propertyDescriptor.getTypeParameters()) {
052 handler.addClassifierDescriptor(typeParameterDescriptor);
053 }
054 return Unit.INSTANCE$;
055 }
056 });
057 }
058
059 @NotNull
060 public static LexicalScope makeScopeForPropertyInitializer(
061 @NotNull LexicalScope propertyHeader,
062 @NotNull PropertyDescriptor propertyDescriptor
063 ) {
064 return new LexicalScopeImpl(propertyHeader, propertyDescriptor, false, null, LexicalScopeKind.PROPERTY_INITIALIZER_OR_DELEGATE);
065 }
066
067 @NotNull
068 public static LexicalScope makeScopeForDelegateConventionFunctions(
069 @NotNull LexicalScope parent,
070 @NotNull PropertyDescriptor propertyDescriptor
071 ) {
072 // todo: very strange scope!
073 return new LexicalScopeImpl(parent, propertyDescriptor, true, propertyDescriptor.getExtensionReceiverParameter(),
074 LexicalScopeKind.PROPERTY_DELEGATE_METHOD
075 );
076 }
077
078 @TestOnly
079 @NotNull
080 public static String printStructure(@Nullable MemberScope scope) {
081 StringBuilder out = new StringBuilder();
082 Printer p = new Printer(out);
083 if (scope == null) {
084 p.println("null");
085 }
086 else {
087 scope.printScopeStructure(p);
088 }
089 return out.toString();
090 }
091 }