JavaDescriptorResolver.java 78.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/*
 * Copyright 2010-2012 JetBrains s.r.o.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

17 18
package org.jetbrains.jet.lang.resolve.java;

19
import com.google.common.collect.Lists;
A
Andrey Breslav 已提交
20
import com.google.common.collect.Maps;
A
Andrey Breslav 已提交
21
import com.google.common.collect.Sets;
22
import com.intellij.openapi.project.Project;
23
import com.intellij.openapi.util.Pair;
24
import com.intellij.openapi.vfs.VirtualFile;
25
import com.intellij.psi.*;
26
import com.intellij.psi.impl.compiled.ClsClassImpl;
27
import com.intellij.psi.search.DelegatingGlobalSearchScope;
28
import com.intellij.psi.search.GlobalSearchScope;
29
import jet.typeinfo.TypeInfoVariance;
30 31
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
32
import org.jetbrains.jet.lang.descriptors.*;
A
Andrey Breslav 已提交
33
import org.jetbrains.jet.lang.descriptors.annotations.AnnotationDescriptor;
34
import org.jetbrains.jet.lang.psi.JetPsiUtil;
35
import org.jetbrains.jet.lang.resolve.BindingContext;
36
import org.jetbrains.jet.lang.resolve.DescriptorUtils;
S
Stepan Koltsov 已提交
37
import org.jetbrains.jet.lang.resolve.FqName;
38
import org.jetbrains.jet.lang.resolve.OverrideResolver;
39
import org.jetbrains.jet.lang.resolve.constants.*;
M
Maxim Shafirov 已提交
40
import org.jetbrains.jet.lang.resolve.java.alt.AltClassFinder;
41
import org.jetbrains.jet.lang.resolve.java.kt.JetClassAnnotation;
42
import org.jetbrains.jet.lang.types.*;
S
Stepan Koltsov 已提交
43
import org.jetbrains.jet.lang.types.lang.JetStandardClasses;
44
import org.jetbrains.jet.lang.types.lang.JetStandardLibrary;
45
import org.jetbrains.jet.plugin.JetFileType;
46
import org.jetbrains.jet.rt.signature.JetSignatureAdapter;
47 48 49
import org.jetbrains.jet.rt.signature.JetSignatureExceptionsAdapter;
import org.jetbrains.jet.rt.signature.JetSignatureReader;
import org.jetbrains.jet.rt.signature.JetSignatureVisitor;
50

51
import java.util.*;
52 53 54 55 56

/**
 * @author abreslav
 */
public class JavaDescriptorResolver {
57
    
S
Stepan Koltsov 已提交
58
    public static final String JAVA_ROOT = "<java_root>";
59

S
Stepan Koltsov 已提交
60 61
    public static final ModuleDescriptor FAKE_ROOT_MODULE = new ModuleDescriptor(JAVA_ROOT);

62 63
    /*package*/ static final DeclarationDescriptor JAVA_METHOD_TYPE_PARAMETER_PARENT = new DeclarationDescriptorImpl(null, Collections.<AnnotationDescriptor>emptyList(), "<java_generic_method>") {

64 65
        @Override
        public DeclarationDescriptor substitute(TypeSubstitutor substitutor) {
66
            throw new UnsupportedOperationException();
67 68
        }

69 70
        @Override
        public <R, D> R accept(DeclarationDescriptorVisitor<R, D> visitor, D data) {
71
            return visitor.visitDeclarationDescriptor(this, data);
72 73 74
        }
    };

A
Andrey Breslav 已提交
75
    /*package*/ static final DeclarationDescriptor JAVA_CLASS_OBJECT = new DeclarationDescriptorImpl(null, Collections.<AnnotationDescriptor>emptyList(), "<java_class_object_emulation>") {
A
Andrey Breslav 已提交
76 77 78
        @NotNull
        @Override
        public DeclarationDescriptor substitute(TypeSubstitutor substitutor) {
79
            throw new UnsupportedOperationException();
A
Andrey Breslav 已提交
80 81 82 83 84 85 86
        }

        @Override
        public <R, D> R accept(DeclarationDescriptorVisitor<R, D> visitor, D data) {
            return visitor.visitDeclarationDescriptor(this, data);
        }
    };
87 88 89 90 91
    
    private enum TypeParameterDescriptorOrigin {
        JAVA,
        KOTLIN,
    }
92

93 94
    public static class TypeParameterDescriptorInitialization {
        @NotNull
95
        private final TypeParameterDescriptorOrigin origin;
96 97 98
        @NotNull
        final TypeParameterDescriptor descriptor;
        final PsiTypeParameter psiTypeParameter;
99 100 101 102
        @Nullable
        private final List<JetType> upperBoundsForKotlin;
        @Nullable
        private final List<JetType> lowerBoundsForKotlin;
103

104
        private TypeParameterDescriptorInitialization(@NotNull TypeParameterDescriptor descriptor, @NotNull PsiTypeParameter psiTypeParameter) {
105
            this.origin = TypeParameterDescriptorOrigin.JAVA;
106
            this.descriptor = descriptor;
107
            this.psiTypeParameter = psiTypeParameter;
108 109 110 111
            this.upperBoundsForKotlin = null;
            this.lowerBoundsForKotlin = null;
        }

112
        private TypeParameterDescriptorInitialization(@NotNull TypeParameterDescriptor descriptor, @NotNull PsiTypeParameter psiTypeParameter,
113 114 115
                List<JetType> upperBoundsForKotlin, List<JetType> lowerBoundsForKotlin) {
            this.origin = TypeParameterDescriptorOrigin.KOTLIN;
            this.descriptor = descriptor;
116
            this.psiTypeParameter = psiTypeParameter;
117 118
            this.upperBoundsForKotlin = upperBoundsForKotlin;
            this.lowerBoundsForKotlin = lowerBoundsForKotlin;
119 120
        }
    }
121 122


123
    private static abstract class ResolverScopeData {
124
        protected boolean kotlin;
125 126
        
        private Map<String, NamedMembers> namedMembersMap;
127 128 129
        
        @NotNull
        public abstract List<TypeParameterDescriptor> getTypeParameters();
130
    }
A
Andrey Breslav 已提交
131

132 133 134 135
    static abstract class ResolverClassData extends ResolverScopeData {

        @NotNull
        public abstract ClassDescriptor getClassDescriptor();
136 137 138 139 140 141

        @NotNull
        @Override
        public List<TypeParameterDescriptor> getTypeParameters() {
            return getClassDescriptor().getTypeConstructor().getParameters();
        }
142 143
    }

144
    /** Class with instance members */
145 146 147 148 149
    static class ResolverBinaryClassData extends ResolverClassData {

        ResolverBinaryClassData() {
        }

150
        private MutableClassDescriptorLite classDescriptor;
151

152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
        List<TypeParameterDescriptorInitialization> typeParameters;

        @Override
        @NotNull
        public ClassDescriptor getClassDescriptor() {
            return classDescriptor;
        }
    }

    static class ResolverSrcClassData extends ResolverClassData {
        @NotNull
        private final ClassDescriptor classDescriptor;

        ResolverSrcClassData(@NotNull ClassDescriptor classDescriptor) {
            this.classDescriptor = classDescriptor;
        }

        @Override
170 171 172 173 174 175
        @NotNull
        public ClassDescriptor getClassDescriptor() {
            return classDescriptor;
        }
    }

176
    /** Either package or class with static members */
177
    private static class ResolverNamespaceData extends ResolverScopeData {
178 179 180 181 182 183
        private JavaNamespaceDescriptor namespaceDescriptor;

        @NotNull
        public NamespaceDescriptor getNamespaceDescriptor() {
            return namespaceDescriptor;
        }
184 185 186 187 188 189

        @NotNull
        @Override
        public List<TypeParameterDescriptor> getTypeParameters() {
            return new ArrayList<TypeParameterDescriptor>(0);
        }
190 191
    }

S
Stepan Koltsov 已提交
192 193
    protected final Map<FqName, ResolverBinaryClassData> classDescriptorCache = Maps.newHashMap();
    protected final Map<FqName, ResolverNamespaceData> namespaceDescriptorCacheByFqn = Maps.newHashMap();
194 195
    protected final Map<PsiElement, ResolverNamespaceData> namespaceDescriptorCache = Maps.newHashMap();

196 197 198
    protected final JavaPsiFacade javaFacade;
    protected final GlobalSearchScope javaSearchScope;
    protected final JavaSemanticServices semanticServices;
M
Maxim Shafirov 已提交
199
    private final AltClassFinder altClassFinder;
200 201 202

    public JavaDescriptorResolver(Project project, JavaSemanticServices semanticServices) {
        this.javaFacade = JavaPsiFacade.getInstance(project);
203 204 205 206 207 208
        this.javaSearchScope = new DelegatingGlobalSearchScope(GlobalSearchScope.allScope(project)) {
            @Override
            public boolean contains(VirtualFile file) {
                return myBaseScope.contains(file) && file.getFileType() != JetFileType.INSTANCE;
            }
        };
209
        this.semanticServices = semanticServices;
M
Maxim Shafirov 已提交
210
        altClassFinder = new AltClassFinder(project);
211
    }
212
    
213
    @Nullable
214
    ResolverClassData resolveClassData(@NotNull PsiClass psiClass, @NotNull DescriptorSearchRule searchRule) {
S
Stepan Koltsov 已提交
215
        FqName qualifiedName = new FqName(psiClass.getQualifiedName());
216

S
Stepan Koltsov 已提交
217
        if (qualifiedName.getFqName().endsWith(JvmAbi.TRAIT_IMPL_SUFFIX)) {
218 219 220
            // TODO: only if -$$TImpl class is created by Kotlin
            return null;
        }
221

222 223 224 225 226
        ClassDescriptor builtinClassDescriptor = semanticServices.getKotlinBuiltinClassDescriptor(qualifiedName);
        if (builtinClassDescriptor != null) {
            return new ResolverSrcClassData(builtinClassDescriptor);
        }

227
        // First, let's check that this is a real Java class, not a Java's view on a Kotlin class:
228 229
        ClassDescriptor kotlinClassDescriptor = semanticServices.getKotlinClassDescriptor(qualifiedName);
        if (kotlinClassDescriptor != null) {
230 231 232 233 234 235 236 237 238 239
            if (searchRule == DescriptorSearchRule.ERROR_IF_FOUND_IN_KOTLIN) {
                throw new IllegalStateException("class must not be found in kotlin: " + qualifiedName);
            } else if (searchRule == DescriptorSearchRule.IGNORE_IF_FOUND_IN_KOTLIN) {
                return null;
            } else if (searchRule == DescriptorSearchRule.INCLUDE_KOTLIN) {
                // TODO: probably this is evil
                return new ResolverSrcClassData(kotlinClassDescriptor);
            } else {
                throw new IllegalStateException("unknown searchRule: " + searchRule);
            }
240 241
        }

242 243 244
        PsiClass containingClass = psiClass.getContainingClass();
        if (containingClass != null) {
            // must resolve containing class first, because inner class must have a reference to it
245
            resolveClass(containingClass, DescriptorSearchRule.IGNORE_IF_FOUND_IN_KOTLIN);
246 247
        }

248
        // Not let's take a descriptor of a Java class
249
        ResolverBinaryClassData classData = classDescriptorCache.get(qualifiedName);
250 251 252
        if (classData == null) {
            classData = createJavaClassDescriptor(psiClass);
            classDescriptorCache.put(qualifiedName, classData);
253
        }
254 255 256 257
        return classData;
    }

    @Nullable
258 259
    public ClassDescriptor resolveClass(@NotNull PsiClass psiClass, @NotNull DescriptorSearchRule searchRule) {
        ResolverClassData classData = resolveClassData(psiClass, searchRule);
260 261 262 263 264
        if (classData != null) {
            return classData.getClassDescriptor();
        } else {
            return null;
        }
265 266 267
    }

    @Nullable
268
    public ClassDescriptor resolveClass(@NotNull FqName qualifiedName, @NotNull DescriptorSearchRule searchRule) {
269

S
Stepan Koltsov 已提交
270
        if (qualifiedName.getFqName().endsWith(JvmAbi.TRAIT_IMPL_SUFFIX)) {
271 272 273
            // TODO: only if -$$TImpl class is created by Kotlin
            return null;
        }
274 275 276 277 278 279

        ClassDescriptor builtinClassDescriptor = semanticServices.getKotlinBuiltinClassDescriptor(qualifiedName);
        if (builtinClassDescriptor != null) {
            return builtinClassDescriptor;
        }

280
        // First, let's check that this is a real Java class, not a Java's view on a Kotlin class:
281 282
        ClassDescriptor kotlinClassDescriptor = semanticServices.getKotlinClassDescriptor(qualifiedName);
        if (kotlinClassDescriptor != null) {
283 284 285 286 287 288 289 290 291
            if (searchRule == DescriptorSearchRule.ERROR_IF_FOUND_IN_KOTLIN) {
                throw new IllegalStateException("class must not be found in kotlin: " + qualifiedName);
            } else if (searchRule == DescriptorSearchRule.IGNORE_IF_FOUND_IN_KOTLIN) {
                return null;
            } else if (searchRule == DescriptorSearchRule.INCLUDE_KOTLIN) {
                return kotlinClassDescriptor;
            } else {
                throw new IllegalStateException("unknown searchRule: " + searchRule);
            }
292 293
        }

294
        // Not let's take a descriptor of a Java class
295
        ResolverBinaryClassData classData = classDescriptorCache.get(qualifiedName);
296
        if (classData == null) {
297
            PsiClass psiClass = findClass(qualifiedName);
298 299 300
            if (psiClass == null) {
                return null;
            }
301
            classData = createJavaClassDescriptor(psiClass);
302
        }
303
        return classData.getClassDescriptor();
304 305
    }

306
    private ResolverBinaryClassData createJavaClassDescriptor(@NotNull final PsiClass psiClass) {
S
Stepan Koltsov 已提交
307
        if (classDescriptorCache.containsKey(new FqName(psiClass.getQualifiedName()))) {
308 309
            throw new IllegalStateException(psiClass.getQualifiedName());
        }
A
Andrey Breslav 已提交
310

311 312
        checkPsiClassIsNotJet(psiClass);

313
        String name = psiClass.getName();
314
        ResolverBinaryClassData classData = new ResolverBinaryClassData();
S
Stepan Koltsov 已提交
315
        classDescriptorCache.put(new FqName(psiClass.getQualifiedName()), classData);
316
        ClassKind kind = psiClass.isInterface() ? (psiClass.isAnnotationType() ? ClassKind.ANNOTATION_CLASS : ClassKind.TRAIT) : ClassKind.CLASS;
S
Stepan Koltsov 已提交
317
        ClassOrNamespaceDescriptor containingDeclaration = resolveParentDescriptor(psiClass);
318
        classData.classDescriptor = new MutableClassDescriptorLite(containingDeclaration, kind);
319
        classData.classDescriptor.setName(name);
320 321
        classData.classDescriptor.setAnnotations(resolveAnnotations(psiClass));

A
Andrey Breslav 已提交
322
        List<JetType> supertypes = new ArrayList<JetType>();
323

S
Stepan Koltsov 已提交
324 325 326
        TypeVariableResolver outerTypeVariableByNameResolver = TypeVariableResolvers.classTypeVariableResolver(
                (ClassOrNamespaceDescriptor) classData.classDescriptor.getContainingDeclaration(),
                "class " + psiClass.getQualifiedName());
327 328

        classData.typeParameters = createUninitializedClassTypeParameters(psiClass, classData, outerTypeVariableByNameResolver);
329 330 331 332 333 334
        
        List<TypeParameterDescriptor> typeParameters = new ArrayList<TypeParameterDescriptor>();
        for (TypeParameterDescriptorInitialization typeParameter : classData.typeParameters) {
            typeParameters.add(typeParameter.descriptor);
        }
        
335 336 337
        classData.classDescriptor.setTypeParameterDescriptors(typeParameters);
        classData.classDescriptor.setSupertypes(supertypes);
        classData.classDescriptor.setVisibility(resolveVisibilityFromPsiModifiers(psiClass));
338 339 340 341 342 343 344 345 346 347
        Modality modality;
        if (classData.classDescriptor.getKind() == ClassKind.ANNOTATION_CLASS) {
            modality = Modality.FINAL;
        }
        else {
            modality = Modality.convertFromFlags(
                    psiClass.hasModifierProperty(PsiModifier.ABSTRACT) || psiClass.isInterface(),
                    !psiClass.hasModifierProperty(PsiModifier.FINAL));
        }
        classData.classDescriptor.setModality(modality);
348 349
        classData.classDescriptor.createTypeConstructor();
        classData.classDescriptor.setScopeForMemberLookup(new JavaClassMembersScope(classData.classDescriptor, psiClass, semanticServices, false));
350

S
Stepan Koltsov 已提交
351
        initializeTypeParameters(classData.typeParameters, classData.classDescriptor, "class " + psiClass.getQualifiedName());
352

S
Stepan Koltsov 已提交
353 354 355
        TypeVariableResolver resolverForTypeParameters = TypeVariableResolvers.classTypeVariableResolver(
                classData.classDescriptor,
                "class " + psiClass.getQualifiedName());
356

357
        // TODO: ugly hack: tests crash if initializeTypeParameters called with class containing proper supertypes
358
        supertypes.addAll(getSupertypes(new PsiClassWrapper(psiClass), classData.classDescriptor, classData.getTypeParameters()));
359

A
Andrey Breslav 已提交
360
        PsiMethod[] psiConstructors = psiClass.getConstructors();
361

362
        boolean isStatic = psiClass.hasModifierProperty(PsiModifier.STATIC);
363
        if (psiConstructors.length == 0) {
A
Andrey Breslav 已提交
364 365 366 367
            // We need to create default constructors for classes and abstract classes.
            // Example:
            // class Kotlin() : Java() {}
            // abstract public class Java {}
368
            if (!psiClass.isInterface()) {
369
                ConstructorDescriptorImpl constructorDescriptor = new ConstructorDescriptorImpl(
370
                        classData.classDescriptor,
A
Andrey Breslav 已提交
371
                        Collections.<AnnotationDescriptor>emptyList(),
372
                        false);
373
                constructorDescriptor.initialize(typeParameters, Collections.<ValueParameterDescriptor>emptyList(), classData.classDescriptor.getVisibility(), isStatic);
374
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
375
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
376
                semanticServices.getTrace().record(BindingContext.CONSTRUCTOR, psiClass, constructorDescriptor);
377
            }
378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398
            if (psiClass.isAnnotationType()) {
                // A constructor for an annotation type takes all the "methods" in the @interface as parameters
                ConstructorDescriptorImpl constructorDescriptor = new ConstructorDescriptorImpl(
                        classData.classDescriptor,
                        Collections.<AnnotationDescriptor>emptyList(),
                        false);

                List<ValueParameterDescriptor> valueParameters = Lists.newArrayList();
                PsiMethod[] methods = psiClass.getMethods();
                for (int i = 0; i < methods.length; i++) {
                    PsiMethod method = methods[i];
                    if (method instanceof PsiAnnotationMethod) {
                        PsiAnnotationMethod annotationMethod = (PsiAnnotationMethod) method;
                        assert annotationMethod.getParameterList().getParameters().length == 0;

                        PsiType returnType = annotationMethod.getReturnType();

                        // We take the following heuristical convention:
                        // if the last method of the @interface is an array, we convert it into a vararg
                        JetType varargElementType = null;
                        if (i == methods.length - 1 && (returnType instanceof PsiArrayType)) {
399
                            varargElementType = semanticServices.getTypeTransformer().transformToType(((PsiArrayType) returnType).getComponentType(), resolverForTypeParameters);
400 401 402 403 404 405 406 407
                        }

                        valueParameters.add(new ValueParameterDescriptorImpl(
                                constructorDescriptor,
                                i,
                                Collections.<AnnotationDescriptor>emptyList(),
                                method.getName(),
                                false,
408
                                semanticServices.getTypeTransformer().transformToType(returnType, resolverForTypeParameters),
409 410 411 412 413
                                annotationMethod.getDefaultValue() != null,
                                varargElementType));
                    }
                }

414
                constructorDescriptor.initialize(typeParameters, valueParameters, classData.classDescriptor.getVisibility(), isStatic);
415 416 417 418
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
                semanticServices.getTrace().record(BindingContext.CONSTRUCTOR, psiClass, constructorDescriptor);
            }
419 420
        }
        else {
421 422 423 424 425
            for (PsiMethod psiConstructor : psiConstructors) {
                PsiMethodWrapper constructor = new PsiMethodWrapper(psiConstructor);

                if (constructor.getJetConstructor().hidden()) {
                    continue;
426 427
                }

428
                ConstructorDescriptorImpl constructorDescriptor = new ConstructorDescriptorImpl(
429
                        classData.classDescriptor,
A
Andrey Breslav 已提交
430
                        Collections.<AnnotationDescriptor>emptyList(), // TODO
431
                        false);
S
Stepan Koltsov 已提交
432
                String context = "constructor of class " + psiClass.getQualifiedName();
433
                ValueParameterDescriptors valueParameterDescriptors = resolveParameterDescriptors(constructorDescriptor,
434
                        constructor.getParameters(),
S
Stepan Koltsov 已提交
435
                        TypeVariableResolvers.classTypeVariableResolver(classData.classDescriptor, context));
436 437 438
                if (valueParameterDescriptors.receiverType != null) {
                    throw new IllegalStateException();
                }
439
                constructorDescriptor.initialize(typeParameters, valueParameterDescriptors.descriptors,
440
                        resolveVisibilityFromPsiModifiers(psiConstructor), isStatic);
441
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
442
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
443
                semanticServices.getTrace().record(BindingContext.CONSTRUCTOR, psiConstructor, constructorDescriptor);
444
            }
A
Andrey Breslav 已提交
445
        }
446

447 448 449 450
        MutableClassDescriptorLite classObject = createClassObjectDescriptor(classData.classDescriptor, psiClass);
        if (classObject != null) {
            classData.classDescriptor.setClassObjectDescriptor(classObject);
        }
451

452
        semanticServices.getTrace().record(BindingContext.CLASS, psiClass, classData.classDescriptor);
453

454
        return classData;
455 456
    }

457
    static void checkPsiClassIsNotJet(PsiClass psiClass) {
458
        if (psiClass instanceof JetJavaMirrorMarker) {
459
            throw new IllegalStateException("trying to resolve fake jet PsiClass as regular PsiClass: " + psiClass.getQualifiedName());
460 461 462
        }
    }

463 464 465 466 467 468 469 470 471 472
    @Nullable
    private PsiClass getInnerClassClassObject(@NotNull PsiClass outer) {
        for (PsiClass inner : outer.getInnerClasses()) {
            if (inner.getName().equals(JvmAbi.CLASS_OBJECT_CLASS_NAME)) {
                return inner;
            }
        }
        return null;
    }

473 474 475 476 477 478
    /**
     * TODO
     * @see #createJavaNamespaceDescriptor(com.intellij.psi.PsiClass)
     */
    @Nullable
    private MutableClassDescriptorLite createClassObjectDescriptor(@NotNull ClassDescriptor containing, @NotNull PsiClass psiClass) {
479 480 481 482 483
        PsiClass classObjectPsiClass = getInnerClassClassObject(psiClass);
        if (classObjectPsiClass == null) {
            return null;
        }

484 485
        checkPsiClassIsNotJet(psiClass);

486 487 488 489
        ResolverBinaryClassData classData = new ResolverBinaryClassData();
        classData.kotlin = true;
        classData.classDescriptor = new MutableClassDescriptorLite(containing, ClassKind.OBJECT);

S
Stepan Koltsov 已提交
490
        classDescriptorCache.put(new FqName(classObjectPsiClass.getQualifiedName()), classData);
491 492 493 494 495 496 497 498 499 500 501 502 503 504 505

        classData.classDescriptor.setSupertypes(getSupertypes(new PsiClassWrapper(classObjectPsiClass), classData.classDescriptor, new ArrayList<TypeParameterDescriptor>(0)));
        classData.classDescriptor.setName(JetPsiUtil.NO_NAME_PROVIDED); // TODO
        classData.classDescriptor.setModality(Modality.FINAL);
        classData.classDescriptor.setTypeParameterDescriptors(new ArrayList<TypeParameterDescriptor>(0));
        classData.classDescriptor.createTypeConstructor();
        classData.classDescriptor.setScopeForMemberLookup(new JavaClassMembersScope(classData.classDescriptor, classObjectPsiClass, semanticServices, false));

        // TODO: wrong: class objects do not need visible constructors
        ConstructorDescriptorImpl constructor = new ConstructorDescriptorImpl(classData.classDescriptor, new ArrayList<AnnotationDescriptor>(0), true);
        constructor.setReturnType(classData.classDescriptor.getDefaultType());
        constructor.initialize(new ArrayList<TypeParameterDescriptor>(0), new ArrayList<ValueParameterDescriptor>(0), Visibility.PUBLIC);

        classData.classDescriptor.addConstructor(constructor, null);
        return classData.classDescriptor;
506 507
    }

508
    private List<TypeParameterDescriptorInitialization> createUninitializedClassTypeParameters(PsiClass psiClass, ResolverBinaryClassData classData, TypeVariableResolver typeVariableResolver) {
509 510 511 512 513
        JetClassAnnotation jetClassAnnotation = JetClassAnnotation.get(psiClass);
        classData.kotlin = jetClassAnnotation.isDefined();
        
        if (jetClassAnnotation.signature().length() > 0) {
            return resolveClassTypeParametersFromJetSignature(
S
Stepan Koltsov 已提交
514
                    jetClassAnnotation.signature(), psiClass, classData.classDescriptor);
515
        }
516

517
        return makeUninitializedTypeParameters(classData.classDescriptor, psiClass.getTypeParameters());
518 519
    }

520
    @NotNull
521
    private PsiTypeParameter getPsiTypeParameterByName(PsiTypeParameterListOwner clazz, String name) {
522 523 524 525 526
        for (PsiTypeParameter typeParameter : clazz.getTypeParameters()) {
            if (typeParameter.getName().equals(name)) {
                return typeParameter; 
            }
        }
527 528 529
        throw new IllegalStateException("PsiTypeParameter '" + name + "' is not found");
    }

S
Stepan Koltsov 已提交
530

531
    private static final FqName JL_OBJECT = new FqName("java.lang.Object");
S
Stepan Koltsov 已提交
532 533

    private boolean isJavaLangObject(JetType type) {
534 535 536
        ClassifierDescriptor classifierDescriptor = type.getConstructor().getDeclarationDescriptor();
        return classifierDescriptor instanceof ClassDescriptor &&
               DescriptorUtils.getFQName(classifierDescriptor).equals(JL_OBJECT.toUnsafe());
S
Stepan Koltsov 已提交
537 538 539
    }


540
    private abstract class JetSignatureTypeParameterVisitor extends JetSignatureExceptionsAdapter {
541 542

        @NotNull
543
        private final PsiTypeParameterListOwner psiOwner;
544
        @NotNull
545
        private final String name;
546
        @NotNull
547
        private final TypeVariableResolver typeVariableResolver;
548 549
        @NotNull
        private final TypeParameterDescriptor typeParameterDescriptor;
550

551 552
        protected JetSignatureTypeParameterVisitor(PsiTypeParameterListOwner psiOwner,
                String name, TypeVariableResolver typeVariableResolver, TypeParameterDescriptor typeParameterDescriptor)
553
        {
554 555 556
            if (name.isEmpty()) {
                throw new IllegalStateException();
            }
557

558 559
            this.psiOwner = psiOwner;
            this.name = name;
560
            this.typeVariableResolver = typeVariableResolver;
561
            this.typeParameterDescriptor = typeParameterDescriptor;
562 563 564 565
        }

        List<JetType> upperBounds = new ArrayList<JetType>();
        List<JetType> lowerBounds = new ArrayList<JetType>();
S
Stepan Koltsov 已提交
566
        
567 568
        @Override
        public JetSignatureVisitor visitClassBound() {
569
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
570 571
                @Override
                protected void done(@NotNull JetType jetType) {
S
Stepan Koltsov 已提交
572 573 574
                    if (isJavaLangObject(jetType)) {
                        return;
                    }
575 576 577 578 579 580 581
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public JetSignatureVisitor visitInterfaceBound() {
582
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
583 584 585 586 587 588 589 590 591
                @Override
                protected void done(@NotNull JetType jetType) {
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public void visitFormalTypeParameterEnd() {
592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610
            PsiTypeParameter psiTypeParameter = getPsiTypeParameterByName(psiOwner, name);
            TypeParameterDescriptorInitialization typeParameterDescriptorInitialization = new TypeParameterDescriptorInitialization(typeParameterDescriptor, psiTypeParameter, upperBounds, lowerBounds);
            done(typeParameterDescriptorInitialization);
        }
        
        protected abstract void done(@NotNull TypeParameterDescriptorInitialization typeParameterDescriptor);
    }

    private class JetSignatureTypeParametersVisitor extends JetSignatureExceptionsAdapter {
        @NotNull
        private final DeclarationDescriptor containingDeclaration;
        @NotNull
        private final PsiTypeParameterListOwner psiOwner;

        private final List<TypeParameterDescriptor> previousTypeParameters = new ArrayList<TypeParameterDescriptor>();
        // note changes state in this method
        private final TypeVariableResolver typeVariableResolver;


S
Stepan Koltsov 已提交
611
        private JetSignatureTypeParametersVisitor(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameterListOwner psiOwner, @NotNull String context) {
612 613 614
            this.containingDeclaration = containingDeclaration;
            this.psiOwner = psiOwner;

S
Stepan Koltsov 已提交
615 616 617 618
            this.typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(
                    previousTypeParameters,
                    containingDeclaration,
                    context);
619 620 621 622 623 624 625 626 627
        }

        private int formalTypeParameterIndex = 0;


        List<TypeParameterDescriptorInitialization> r = new ArrayList<TypeParameterDescriptorInitialization>();

        @Override
        public JetSignatureVisitor visitFormalTypeParameter(final String name, final TypeInfoVariance variance, boolean reified) {
628 629 630
            TypeParameterDescriptor typeParameter = TypeParameterDescriptor.createForFurtherModification(
                    containingDeclaration,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO: wrong
631
                    reified,
632 633
                    JetSignatureUtils.translateVariance(variance),
                    name,
634 635 636 637 638 639 640 641 642 643 644
                    formalTypeParameterIndex++);

            previousTypeParameters.add(typeParameter);

            return new JetSignatureTypeParameterVisitor(psiOwner, name, typeVariableResolver, typeParameter) {
                @Override
                protected void done(@NotNull TypeParameterDescriptorInitialization typeParameterDescriptor) {
                    r.add(typeParameterDescriptor);
                    previousTypeParameters.add(typeParameterDescriptor.descriptor);
                }
            };
645
        }
646 647
    }

648
    /**
S
Stepan Koltsov 已提交
649
     * @see #resolveMethodTypeParametersFromJetSignature(String, com.intellij.psi.PsiMethod, org.jetbrains.jet.lang.descriptors.DeclarationDescriptor)
650
     */
S
Stepan Koltsov 已提交
651 652 653 654
    private List<TypeParameterDescriptorInitialization> resolveClassTypeParametersFromJetSignature(String jetSignature,
            final PsiClass clazz, final ClassDescriptor classDescriptor) {
        String context = "class " + clazz.getQualifiedName();
        JetSignatureTypeParametersVisitor jetSignatureTypeParametersVisitor = new JetSignatureTypeParametersVisitor(classDescriptor, clazz, context) {
655 656 657 658 659 660 661 662 663 664 665
            @Override
            public JetSignatureVisitor visitSuperclass() {
                // TODO
                return new JetSignatureAdapter();
            }

            @Override
            public JetSignatureVisitor visitInterface() {
                // TODO
                return new JetSignatureAdapter();
            }
666 667 668
        };
        new JetSignatureReader(jetSignature).accept(jetSignatureTypeParametersVisitor);
        return jetSignatureTypeParametersVisitor.r;
669 670
    }

S
Stepan Koltsov 已提交
671
    private ClassOrNamespaceDescriptor resolveParentDescriptor(PsiClass psiClass) {
672 673
        PsiClass containingClass = psiClass.getContainingClass();
        if (containingClass != null) {
674
            return resolveClass(containingClass, DescriptorSearchRule.INCLUDE_KOTLIN);
675
        }
676

677
        return resolveNamespace(new FqName(psiClass.getQualifiedName()).parent(), DescriptorSearchRule.INCLUDE_KOTLIN);
678 679
    }

680 681
    private List<TypeParameterDescriptorInitialization> makeUninitializedTypeParameters(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter[] typeParameters) {
        List<TypeParameterDescriptorInitialization> result = Lists.newArrayList();
682
        for (PsiTypeParameter typeParameter : typeParameters) {
683
            TypeParameterDescriptorInitialization typeParameterDescriptor = makeUninitializedTypeParameter(containingDeclaration, typeParameter);
A
Andrey Breslav 已提交
684
            result.add(typeParameterDescriptor);
685 686 687 688
        }
        return result;
    }

689
    @NotNull
690
    private TypeParameterDescriptorInitialization makeUninitializedTypeParameter(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter psiTypeParameter) {
691
        TypeParameterDescriptor typeParameterDescriptor = TypeParameterDescriptor.createForFurtherModification(
692
                containingDeclaration,
A
Andrey Breslav 已提交
693
                Collections.<AnnotationDescriptor>emptyList(), // TODO
A
Andrey Breslav 已提交
694
                false,
695
                Variance.INVARIANT,
696 697
                psiTypeParameter.getName(),
                psiTypeParameter.getIndex()
698
        );
699
        return new TypeParameterDescriptorInitialization(typeParameterDescriptor, psiTypeParameter);
700 701
    }

702
    private void initializeTypeParameter(TypeParameterDescriptorInitialization typeParameter, TypeVariableResolver typeVariableByPsiResolver) {
703 704 705
        TypeParameterDescriptor typeParameterDescriptor = typeParameter.descriptor;
        if (typeParameter.origin == TypeParameterDescriptorOrigin.KOTLIN) {
            List<?> upperBounds = typeParameter.upperBoundsForKotlin;
706 707 708
            if (upperBounds.size() == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            } else {
709
                for (JetType upperBound : typeParameter.upperBoundsForKotlin) {
710 711 712 713 714
                    typeParameterDescriptor.addUpperBound(upperBound);
                }
            }

            // TODO: lower bounds
715
        } else {
716
            PsiClassType[] referencedTypes = typeParameter.psiTypeParameter.getExtendsList().getReferencedTypes();
717 718 719 720
            if (referencedTypes.length == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            }
            else if (referencedTypes.length == 1) {
721
                typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedTypes[0], typeVariableByPsiResolver));
722 723 724
            }
            else {
                for (PsiClassType referencedType : referencedTypes) {
725
                    typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedType, typeVariableByPsiResolver));
726
                }
A
Andrey Breslav 已提交
727 728
            }
        }
729
        typeParameterDescriptor.setInitialized();
730 731
    }

S
Stepan Koltsov 已提交
732
    private void initializeTypeParameters(List<TypeParameterDescriptorInitialization> typeParametersInitialization, @NotNull DeclarationDescriptor typeParametersOwner, @NotNull String context) {
733
        List<TypeParameterDescriptor> prevTypeParameters = new ArrayList<TypeParameterDescriptor>();
734
        for (TypeParameterDescriptorInitialization psiTypeParameter : typeParametersInitialization) {
735
            prevTypeParameters.add(psiTypeParameter.descriptor);
S
Stepan Koltsov 已提交
736
            initializeTypeParameter(psiTypeParameter, TypeVariableResolvers.typeVariableResolverFromTypeParameters(prevTypeParameters, typeParametersOwner, context));
S
Stepan Koltsov 已提交
737
        }
A
Andrey Breslav 已提交
738 739
    }

740
    private Collection<JetType> getSupertypes(PsiClassWrapper psiClass, ClassDescriptor classDescriptor, List<TypeParameterDescriptor> typeParameters) {
741 742
        final List<JetType> result = new ArrayList<JetType>();

S
Stepan Koltsov 已提交
743 744
        String context = "class " + psiClass.getQualifiedName();

745
        if (psiClass.getJetClass().signature().length() > 0) {
S
Stepan Koltsov 已提交
746
            final TypeVariableResolver typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(typeParameters, classDescriptor, context);
747 748 749 750 751 752 753 754 755 756
            
            new JetSignatureReader(psiClass.getJetClass().signature()).accept(new JetSignatureExceptionsAdapter() {
                @Override
                public JetSignatureVisitor visitFormalTypeParameter(String name, TypeInfoVariance variance, boolean reified) {
                    // TODO: collect
                    return new JetSignatureAdapter();
                }

                @Override
                public JetSignatureVisitor visitSuperclass() {
757
                    return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
758 759 760 761 762 763 764 765 766 767 768
                        @Override
                        protected void done(@NotNull JetType jetType) {
                            if (!jetType.equals(JetStandardClasses.getAnyType())) {
                                result.add(jetType);
                            }
                        }
                    };
                }

                @Override
                public JetSignatureVisitor visitInterface() {
S
Stepan Koltsov 已提交
769
                    return visitSuperclass();
770 771 772
                }
            });
        } else {
S
Stepan Koltsov 已提交
773 774 775
            TypeVariableResolver typeVariableResolverForSupertypes = TypeVariableResolvers.typeVariableResolverFromTypeParameters(typeParameters, classDescriptor, context);
            transformSupertypeList(result, psiClass.getPsiClass().getExtendsListTypes(), typeVariableResolverForSupertypes, classDescriptor.getKind() == ClassKind.ANNOTATION_CLASS);
            transformSupertypeList(result, psiClass.getPsiClass().getImplementsListTypes(), typeVariableResolverForSupertypes, classDescriptor.getKind() == ClassKind.ANNOTATION_CLASS);
776
        }
777 778 779 780 781 782 783
        
        for (JetType supertype : result) {
            if (ErrorUtils.isErrorType(supertype)) {
                semanticServices.getTrace().record(BindingContext.INCOMPLETE_HIERARCHY, classDescriptor);
            }
        }
        
784 785 786
        if (result.isEmpty()) {
            result.add(JetStandardClasses.getAnyType());
        }
787 788 789
        return result;
    }

790
    private void transformSupertypeList(List<JetType> result, PsiClassType[] extendsListTypes, TypeVariableResolver typeVariableResolver, boolean annotation) {
791
        for (PsiClassType type : extendsListTypes) {
792 793 794 795
            PsiClass resolved = type.resolve();
            if (resolved != null && resolved.getQualifiedName().equals(JvmStdlibNames.JET_OBJECT.getFqName())) {
                continue;
            }
796 797 798
            if (annotation && resolved.getQualifiedName().equals("java.lang.annotation.Annotation")) {
                continue;
            }
799
            
800
            JetType transform = semanticServices.getTypeTransformer().transformToType(type, typeVariableResolver);
801 802 803 804 805

            result.add(TypeUtils.makeNotNullable(transform));
        }
    }

806
    @Nullable
807
    public NamespaceDescriptor resolveNamespace(@NotNull FqName qualifiedName, @NotNull DescriptorSearchRule searchRule) {
808 809 810
        // First, let's check that there is no Kotlin package:
        NamespaceDescriptor kotlinNamespaceDescriptor = semanticServices.getKotlinNamespaceDescriptor(qualifiedName);
        if (kotlinNamespaceDescriptor != null) {
811 812 813 814 815 816 817 818 819 820
            if (searchRule == DescriptorSearchRule.ERROR_IF_FOUND_IN_KOTLIN) {
                throw new IllegalStateException("class must not be found in kotlin: " + qualifiedName);
            } else if (searchRule == DescriptorSearchRule.IGNORE_IF_FOUND_IN_KOTLIN) {
                return null;
            } else if (searchRule == DescriptorSearchRule.INCLUDE_KOTLIN) {
                // TODO: probably this is evil
                return kotlinNamespaceDescriptor;
            } else {
                throw new IllegalStateException("unknown searchRule: " + searchRule);
            }
821 822
        }

823
        PsiPackage psiPackage = findPackage(qualifiedName);
824
        if (psiPackage == null) {
825
            PsiClass psiClass = findClass(qualifiedName);
A
Andrey Breslav 已提交
826 827
            if (psiClass == null) return null;
            return resolveNamespace(psiClass);
828 829 830 831
        }
        return resolveNamespace(psiPackage);
    }

832
    @Nullable
S
Stepan Koltsov 已提交
833 834
    public PsiClass findClass(@NotNull FqName qualifiedName) {
        PsiClass original = javaFacade.findClass(qualifiedName.getFqName(), javaSearchScope);
M
Maxim Shafirov 已提交
835
        PsiClass altClass = altClassFinder.findClass(qualifiedName);
836
        PsiClass result = original;
837 838 839 840 841
        if (altClass != null) {
            if (altClass instanceof ClsClassImpl) {
                altClass.putUserData(ClsClassImpl.DELEGATE_KEY, original);
            }

842 843 844 845
            result = altClass;
        }

        if (result != null) {
S
Stepan Koltsov 已提交
846
            FqName actualQualifiedName = new FqName(result.getQualifiedName());
847
            if (!actualQualifiedName.equals(qualifiedName)) {
848
//                throw new IllegalStateException("requested " + qualifiedName + ", got " + actualQualifiedName);
849
            }
850
        }
851 852

        return result;
853 854
    }

S
Stepan Koltsov 已提交
855 856
    /*package*/ PsiPackage findPackage(@NotNull FqName qualifiedName) {
        return javaFacade.findPackage(qualifiedName.getFqName());
857 858
    }

859
    private NamespaceDescriptor resolveNamespace(@NotNull PsiPackage psiPackage) {
860 861 862 863
        ResolverNamespaceData namespaceData = namespaceDescriptorCache.get(psiPackage);
        if (namespaceData == null) {
            namespaceData = createJavaNamespaceDescriptor(psiPackage);
            namespaceDescriptorCache.put(psiPackage, namespaceData);
S
Stepan Koltsov 已提交
864
            namespaceDescriptorCacheByFqn.put(new FqName(psiPackage.getQualifiedName()), namespaceData);
865
        }
866
        return namespaceData.namespaceDescriptor;
867 868
    }

A
Andrey Breslav 已提交
869
    private NamespaceDescriptor resolveNamespace(@NotNull PsiClass psiClass) {
870 871 872 873
        ResolverNamespaceData namespaceData = namespaceDescriptorCache.get(psiClass);
        if (namespaceData == null) {
            namespaceData = createJavaNamespaceDescriptor(psiClass);
            namespaceDescriptorCache.put(psiClass, namespaceData);
S
Stepan Koltsov 已提交
874
            namespaceDescriptorCacheByFqn.put(new FqName(psiClass.getQualifiedName()), namespaceData);
A
Andrey Breslav 已提交
875
        }
876
        return namespaceData.namespaceDescriptor;
A
Andrey Breslav 已提交
877 878
    }

879 880
    private ResolverNamespaceData createJavaNamespaceDescriptor(@NotNull PsiPackage psiPackage) {
        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
881
        String name = psiPackage.getName();
882
        namespaceData.namespaceDescriptor = new JavaNamespaceDescriptor(
S
Stepan Koltsov 已提交
883
                (NamespaceDescriptorParent) resolveParentDescriptor(psiPackage),
A
Andrey Breslav 已提交
884
                Collections.<AnnotationDescriptor>emptyList(), // TODO
885
                name == null ? JAVA_ROOT : name,
S
Stepan Koltsov 已提交
886
                name == null ? FqName.ROOT : new FqName(psiPackage.getQualifiedName()),
887
                true
888
        );
889

S
Stepan Koltsov 已提交
890
        namespaceData.namespaceDescriptor.setMemberScope(createJavaPackageScope(new FqName(psiPackage.getQualifiedName()), namespaceData.namespaceDescriptor));
891 892 893 894
        semanticServices.getTrace().record(BindingContext.NAMESPACE, psiPackage, namespaceData.namespaceDescriptor);
        // TODO: hack
        namespaceData.kotlin = true;
        return namespaceData;
895 896
    }

S
Stepan Koltsov 已提交
897 898 899 900
    public JavaPackageScope createJavaPackageScope(@NotNull FqName fqName, @NotNull NamespaceDescriptor ns) {
        return new JavaPackageScope(fqName, ns, semanticServices);
    }

S
Stepan Koltsov 已提交
901
    @NotNull
902 903 904
    private DeclarationDescriptor resolveParentDescriptor(@NotNull PsiPackage psiPackage) {
        PsiPackage parentPackage = psiPackage.getParentPackage();
        if (parentPackage == null) {
S
Stepan Koltsov 已提交
905
            return FAKE_ROOT_MODULE;
906 907 908 909
        }
        return resolveNamespace(parentPackage);
    }

910 911 912 913
    /**
     * TODO
     * @see #createClassObjectDescriptor(org.jetbrains.jet.lang.descriptors.ClassDescriptor, com.intellij.psi.PsiClass)
     */
914
    private ResolverNamespaceData createJavaNamespaceDescriptor(@NotNull final PsiClass psiClass) {
915 916 917

        checkPsiClassIsNotJet(psiClass);

918 919
        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
        namespaceData.namespaceDescriptor = new JavaNamespaceDescriptor(
S
Stepan Koltsov 已提交
920
                (NamespaceDescriptorParent) resolveParentDescriptor(psiClass),
A
Andrey Breslav 已提交
921
                Collections.<AnnotationDescriptor>emptyList(), // TODO
922
                psiClass.getName(),
S
Stepan Koltsov 已提交
923
                new FqName(psiClass.getQualifiedName()),
924
                false
925
        );
926 927 928
        namespaceData.namespaceDescriptor.setMemberScope(new JavaClassMembersScope(namespaceData.namespaceDescriptor, psiClass, semanticServices, true));
        semanticServices.getTrace().record(BindingContext.NAMESPACE, psiClass, namespaceData.namespaceDescriptor);
        return namespaceData;
929
    }
930 931 932 933 934 935 936 937 938 939
    
    private static class ValueParameterDescriptors {
        private final JetType receiverType;
        private final List<ValueParameterDescriptor> descriptors;

        private ValueParameterDescriptors(@Nullable JetType receiverType, List<ValueParameterDescriptor> descriptors) {
            this.receiverType = receiverType;
            this.descriptors = descriptors;
        }
    }
940

941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967 968 969 970 971 972 973
    private enum JvmMethodParameterKind {
        REGULAR,
        RECEIVER,
        TYPE_INFO,
    }
    
    private static class JvmMethodParameterMeaning {
        private final JvmMethodParameterKind kind;
        private final JetType receiverType;
        private final ValueParameterDescriptor valueParameterDescriptor;
        private final Object typeInfo;

        private JvmMethodParameterMeaning(JvmMethodParameterKind kind, JetType receiverType, ValueParameterDescriptor valueParameterDescriptor, Object typeInfo) {
            this.kind = kind;
            this.receiverType = receiverType;
            this.valueParameterDescriptor = valueParameterDescriptor;
            this.typeInfo = typeInfo;
        }
        
        public static JvmMethodParameterMeaning receiver(@NotNull JetType receiverType) {
            return new JvmMethodParameterMeaning(JvmMethodParameterKind.RECEIVER, receiverType, null, null);
        }
        
        public static JvmMethodParameterMeaning regular(@NotNull ValueParameterDescriptor valueParameterDescriptor) {
            return new JvmMethodParameterMeaning(JvmMethodParameterKind.REGULAR, null, valueParameterDescriptor, null);
        }
        
        public static JvmMethodParameterMeaning typeInfo(@NotNull Object typeInfo) {
            return new JvmMethodParameterMeaning(JvmMethodParameterKind.TYPE_INFO, null, null, typeInfo);
        }
    }

    @NotNull
974
    private JvmMethodParameterMeaning resolveParameterDescriptor(DeclarationDescriptor containingDeclaration, int i,
975 976 977 978 979 980 981
            PsiParameterWrapper parameter, TypeVariableResolver typeVariableResolver) {

        if (parameter.getJetTypeParameter().isDefined()) {
            return JvmMethodParameterMeaning.typeInfo(new Object());
        }

        PsiType psiType = parameter.getPsiParameter().getType();
982

983 984
        // TODO: must be very slow, make it lazy?
        String name = parameter.getPsiParameter().getName() != null ? parameter.getPsiParameter().getName() : "p" + i;
985

986 987
        if (parameter.getJetValueParameter().name().length() > 0) {
            name = parameter.getJetValueParameter().name();
988 989
        }
        
990 991 992 993
        String typeFromAnnotation = parameter.getJetValueParameter().type();
        boolean receiver = parameter.getJetValueParameter().receiver();
        boolean hasDefaultValue = parameter.getJetValueParameter().hasDefaultValue();

S
Stepan Koltsov 已提交
994
        JetType outType;
995
        if (typeFromAnnotation.length() > 0) {
996
            outType = semanticServices.getTypeTransformer().transformToType(typeFromAnnotation, typeVariableResolver);
S
Stepan Koltsov 已提交
997
        } else {
998
            outType = semanticServices.getTypeTransformer().transformToType(psiType, typeVariableResolver);
S
Stepan Koltsov 已提交
999
        }
1000 1001 1002

        JetType varargElementType;
        if (psiType instanceof PsiEllipsisType) {
1003
            varargElementType = JetStandardLibrary.getInstance().getArrayElementType(outType);
1004 1005 1006 1007
        } else {
            varargElementType = null;
        }

1008 1009 1010
        if (receiver) {
            return JvmMethodParameterMeaning.receiver(outType);
        } else {
S
Stepan Koltsov 已提交
1011 1012 1013 1014 1015 1016 1017 1018 1019

            JetType transformedType;
            if (parameter.getJetValueParameter().nullable()) {
                transformedType = TypeUtils.makeNullableAsSpecified(outType, parameter.getJetValueParameter().nullable());
            } else if (parameter.getPsiParameter().getModifierList().findAnnotation(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName()) != null) {
                transformedType = TypeUtils.makeNullableAsSpecified(outType, false);
            } else {
                transformedType = outType;
            }
1020 1021 1022 1023 1024
            return JvmMethodParameterMeaning.regular(new ValueParameterDescriptorImpl(
                    containingDeclaration,
                    i,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO
                    name,
S
Stepan Koltsov 已提交
1025
                    false,
S
Stepan Koltsov 已提交
1026
                    transformedType,
1027
                    hasDefaultValue,
1028 1029 1030
                    varargElementType
            ));
        }
1031 1032
    }

S
Stepan Koltsov 已提交
1033
    public Set<VariableDescriptor> resolveFieldGroupByName(@NotNull ClassOrNamespaceDescriptor owner, @NotNull PsiClass psiClass, String fieldName, boolean staticMembers) {
1034
        ResolverScopeData scopeData = getResolverScopeData(owner, new PsiClassWrapper(psiClass));
1035

1036 1037 1038
        NamedMembers namedMembers = scopeData.namedMembersMap.get(fieldName);
        if (namedMembers == null) {
            return Collections.emptySet();
1039
        }
1040
        Set<VariableDescriptor> r = new HashSet<VariableDescriptor>();
1041

S
Stepan Koltsov 已提交
1042
        resolveNamedGroupProperties(owner, scopeData, staticMembers, namedMembers, fieldName, "class or namespace " + psiClass.getQualifiedName());
1043

1044 1045 1046 1047 1048 1049 1050
        r.addAll(namedMembers.propertyDescriptors);

        for (JetType supertype : getSupertypes(scopeData)) {
            r.addAll(supertype.getMemberScope().getProperties(fieldName));
        }

        return r;
1051 1052 1053
    }
    
    @NotNull
S
Stepan Koltsov 已提交
1054
    public Set<VariableDescriptor> resolveFieldGroup(@NotNull ClassOrNamespaceDescriptor owner, @NotNull PsiClass psiClass, boolean staticMembers) {
1055

1056 1057
        ResolverScopeData scopeData = getResolverScopeData(owner, new PsiClassWrapper(psiClass));
        
1058
        Set<VariableDescriptor> descriptors = Sets.newHashSet();
1059 1060 1061
        Map<String, NamedMembers> membersForProperties = scopeData.namedMembersMap;
        for (Map.Entry<String, NamedMembers> entry : membersForProperties.entrySet()) {
            NamedMembers namedMembers = entry.getValue();
1062
            if (namedMembers.propertyAccessors == null) {
1063 1064 1065 1066
                continue;
            }
            
            String propertyName = entry.getKey();
1067

S
Stepan Koltsov 已提交
1068
            resolveNamedGroupProperties(owner, scopeData, staticMembers, namedMembers, propertyName, "class or namespace " + psiClass.getQualifiedName());
1069
            descriptors.addAll(namedMembers.propertyDescriptors);
1070
        }
1071 1072 1073 1074 1075 1076 1077 1078 1079 1080

        for (JetType supertype : getSupertypes(scopeData)) {
            for (DeclarationDescriptor descriptor : supertype.getMemberScope().getAllDescriptors()) {
                // TODO: ugly
                if (descriptor instanceof VariableDescriptor) {
                    descriptors.add((VariableDescriptor) descriptor);
                }
            }
        }
        
1081
        return descriptors;
1082
    }
1083 1084 1085 1086 1087 1088 1089
    
    private Object key(TypeSource typeSource) {
        if (typeSource == null) {
            return "";
        } else if (typeSource.getTypeString().length() > 0) {
            return typeSource.getTypeString();
        } else {
1090
            return psiTypeToKey(typeSource.getPsiType());
1091 1092
        }
    }
1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105

    private Object psiTypeToKey(PsiType psiType) {
        if (psiType instanceof PsiClassType) {
            return ((PsiClassType) psiType).getClassName();
        } else if (psiType instanceof PsiPrimitiveType) {
            return psiType.getPresentableText();
        } else if (psiType instanceof PsiArrayType) {
            return Pair.create("[", psiTypeToKey(((PsiArrayType) psiType).getComponentType()));
        } else {
            throw new IllegalStateException("" + psiType.getClass());
        }
    }

1106 1107 1108 1109 1110
    private Object propertyKeyForGrouping(PropertyAccessorData propertyAccessor) {
        Object type = key(propertyAccessor.getType());
        Object receiverType = key(propertyAccessor.getReceiverType());
        return Pair.create(type, receiverType);
    }
1111

1112 1113 1114
    private void resolveNamedGroupProperties(
            @NotNull ClassOrNamespaceDescriptor owner,
            @NotNull ResolverScopeData scopeData,
S
Stepan Koltsov 已提交
1115 1116 1117
            boolean staticMembers, @NotNull NamedMembers namedMembers, @NotNull String propertyName,
            @NotNull String context
            ) {
1118 1119 1120 1121
        if (namedMembers.propertyDescriptors != null) {
            return;
        }
        
1122
        if (namedMembers.propertyAccessors == null) {
1123 1124 1125
            namedMembers.propertyDescriptors = Collections.emptySet();
            return;
        }
1126

S
Stepan Koltsov 已提交
1127
        TypeVariableResolver typeVariableResolver = TypeVariableResolvers.classTypeVariableResolver(owner, context);
1128

1129 1130 1131 1132
        class GroupingValue {
            PropertyAccessorData getter;
            PropertyAccessorData setter;
            PropertyAccessorData field;
1133
            boolean ext;
1134
        }
1135 1136
        
        Map<Object, GroupingValue> map = new HashMap<Object, GroupingValue>();
1137

1138
        for (PropertyAccessorData propertyAccessor : namedMembers.propertyAccessors) {
1139

1140 1141 1142 1143 1144
            Object key = propertyKeyForGrouping(propertyAccessor);
            
            GroupingValue value = map.get(key);
            if (value == null) {
                value = new GroupingValue();
1145
                value.ext = propertyAccessor.getReceiverType() != null;
1146 1147
                map.put(key, value);
            }
1148

1149 1150 1151 1152
            if (value.ext != (propertyAccessor.getReceiverType() != null)) {
                throw new IllegalStateException("internal error, incorrect key");
            }

1153 1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170
            if (propertyAccessor.isGetter()) {
                if (value.getter != null) {
                    throw new IllegalStateException("oops, duplicate key");
                }
                value.getter = propertyAccessor;
            } else if (propertyAccessor.isSetter()) {
                if (value.setter != null) {
                    throw new IllegalStateException("oops, duplicate key");
                }
                value.setter = propertyAccessor;
            } else if (propertyAccessor.isField()) {
                if (value.field != null) {
                    throw new IllegalStateException("oops, duplicate key");
                }
                value.field = propertyAccessor;
            } else {
                throw new IllegalStateException();
            }
1171
        }
1172

1173
        
1174 1175
        Set<VariableDescriptor> r = new HashSet<VariableDescriptor>(1);

1176 1177 1178 1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189
        int regularProperitesCount = 0;
        for (GroupingValue members : map.values()) {
            if (!members.ext) {
                ++regularProperitesCount;
            }
        }

        for (GroupingValue members : map.values()) {

            // we cannot have more then one property with given name even if java code
            // has several fields, getters and setter of different types
            if (!members.ext && regularProperitesCount > 1) {
                continue;
            }
1190

1191
            boolean isFinal;
1192 1193 1194
            if (!scopeData.kotlin) {
                isFinal = true;
            } else if (members.setter == null && members.getter == null) {
1195 1196 1197 1198 1199 1200 1201 1202
                isFinal = false;
            } else if (members.getter != null) {
                isFinal = members.getter.getMember().isFinal();
            } else if (members.setter != null) {
                isFinal = members.setter.getMember().isFinal();
            } else {
                isFinal = false;
            }
1203

1204 1205 1206 1207 1208 1209 1210 1211 1212 1213
            PropertyAccessorData anyMember;
            if (members.getter != null) {
                anyMember = members.getter;
            } else if (members.field != null) {
                anyMember = members.field;
            } else if (members.setter != null) {
                anyMember = members.setter;
            } else {
                throw new IllegalStateException();
            }
1214

1215 1216 1217 1218 1219 1220
            boolean isVar;
            if (members.getter == null && members.setter == null) {
                isVar = !members.field.getMember().isFinal();
            } else {
                isVar = members.setter != null;
            }
1221 1222 1223 1224 1225 1226 1227 1228 1229 1230

            Modality modality;
            if (isFinal) {
                modality = Modality.FINAL;
            }
            else {
                modality = anyMember.getMember().isAbstract() ? Modality.ABSTRACT : Modality.OPEN;
            }


1231 1232
            PropertyDescriptor propertyDescriptor = new PropertyDescriptor(
                    owner,
A
Alex Tkachman 已提交
1233
                    resolveAnnotations(anyMember.getMember().psiMember),
1234
                    modality,
1235 1236 1237
                    resolveVisibilityFromPsiModifiers(anyMember.getMember().psiMember),
                    isVar,
                    false,
1238 1239
                    propertyName,
                    CallableMemberDescriptor.Kind.DECLARATION);
1240

1241 1242 1243
            PropertyGetterDescriptor getterDescriptor = null;
            PropertySetterDescriptor setterDescriptor = null;
            if (members.getter != null) {
A
Alex Tkachman 已提交
1244
                getterDescriptor = new PropertyGetterDescriptor(propertyDescriptor, resolveAnnotations(members.getter.getMember().psiMember), Modality.OPEN, Visibility.PUBLIC, true, false, CallableMemberDescriptor.Kind.DECLARATION);
1245 1246
            }
            if (members.setter != null) {
A
Alex Tkachman 已提交
1247
                setterDescriptor = new PropertySetterDescriptor(propertyDescriptor, resolveAnnotations(members.setter.getMember().psiMember), Modality.OPEN, Visibility.PUBLIC, true, false, CallableMemberDescriptor.Kind.DECLARATION);
1248
            }
1249

1250
            propertyDescriptor.initialize(getterDescriptor, setterDescriptor);
1251

S
Stepan Koltsov 已提交
1252
            List<TypeParameterDescriptor> typeParameters = new ArrayList<TypeParameterDescriptor>(0);
1253 1254 1255

            if (members.setter != null) {
                PsiMethodWrapper method = (PsiMethodWrapper) members.setter.getMember();
1256

1257
                if (anyMember == members.setter) {
S
Stepan Koltsov 已提交
1258
                    typeParameters = resolveMethodTypeParameters(method, propertyDescriptor, typeVariableResolver);
1259 1260 1261 1262 1263 1264
                }
            }
            if (members.getter != null) {
                PsiMethodWrapper method = (PsiMethodWrapper) members.getter.getMember();

                if (anyMember == members.getter) {
S
Stepan Koltsov 已提交
1265
                    typeParameters = resolveMethodTypeParameters(method, propertyDescriptor, typeVariableResolver);
1266 1267 1268
                }
            }

S
Stepan Koltsov 已提交
1269
            TypeVariableResolver typeVariableResolverForPropertyInternals = TypeVariableResolvers.typeVariableResolverFromTypeParameters(typeParameters, propertyDescriptor, "property " + propertyName + " in " + context);
1270

1271 1272 1273 1274
            JetType propertyType;
            if (anyMember.getType().getTypeString().length() > 0) {
                propertyType = semanticServices.getTypeTransformer().transformToType(anyMember.getType().getTypeString(), typeVariableResolverForPropertyInternals);
            } else {
1275
                propertyType = semanticServices.getTypeTransformer().transformToType(anyMember.getType().getPsiType(), typeVariableResolverForPropertyInternals);
S
Stepan Koltsov 已提交
1276 1277 1278
                if (anyMember.getType().getPsiNotNullOwner().getModifierList().findAnnotation(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName()) != null) {
                    propertyType = TypeUtils.makeNullableAsSpecified(propertyType, false);
                }
1279 1280 1281 1282 1283 1284 1285 1286
            }
            
            JetType receiverType;
            if (anyMember.getReceiverType() == null) {
                receiverType = null;
            } else if (anyMember.getReceiverType().getTypeString().length() > 0) {
                receiverType = semanticServices.getTypeTransformer().transformToType(anyMember.getReceiverType().getTypeString(), typeVariableResolverForPropertyInternals);
            } else {
1287
                receiverType = semanticServices.getTypeTransformer().transformToType(anyMember.getReceiverType().getPsiType(), typeVariableResolverForPropertyInternals);
1288 1289 1290 1291 1292 1293 1294
            }

            propertyDescriptor.setType(
                    propertyType,
                    typeParameters,
                    DescriptorUtils.getExpectedThisObjectIfNeeded(owner),
                    receiverType
1295
            );
1296 1297 1298 1299
            if (getterDescriptor != null) {
                getterDescriptor.initialize(propertyType);
            }
            if (setterDescriptor != null) {
1300
                setterDescriptor.initialize(new ValueParameterDescriptorImpl(setterDescriptor, 0, Collections.<AnnotationDescriptor>emptyList(), "p0"/*TODO*/, false, propertyDescriptor.getType(), false, null));
1301 1302 1303 1304 1305
            }

            semanticServices.getTrace().record(BindingContext.VARIABLE, anyMember.getMember().psiMember, propertyDescriptor);
            
            r.add(propertyDescriptor);
1306
        }
1307

1308
        namedMembers.propertyDescriptors = r;
1309
    }
1310

1311
    private void resolveNamedGroupFunctions(ClassOrNamespaceDescriptor owner, PsiClass psiClass, TypeSubstitutor typeSubstitutorForGenericSuperclasses, NamedMembers namedMembers, String methodName, ResolverScopeData scopeData) {
1312 1313 1314
        if (namedMembers.functionDescriptors != null) {
            return;
        }
1315 1316
        
        final Set<FunctionDescriptor> functions = new HashSet<FunctionDescriptor>();
1317

1318
        Set<SimpleFunctionDescriptor> functionsFromCurrent = Sets.newHashSet();
1319
        for (PsiMethodWrapper method : namedMembers.methods) {
1320 1321
            FunctionDescriptorImpl function = resolveMethodToFunctionDescriptor(owner, psiClass,
                    method);
1322
            if (function != null) {
1323
                functionsFromCurrent.add((SimpleFunctionDescriptor) function);
1324 1325 1326 1327 1328 1329
            }
        }

        if (owner instanceof ClassDescriptor) {
            ClassDescriptor classDescriptor = (ClassDescriptor) owner;

1330
            Set<SimpleFunctionDescriptor> functionsFromSupertypes = getFunctionsFromSupertypes(scopeData, methodName);
1331

S
Stepan Koltsov 已提交
1332
            OverrideResolver.generateOverridesInFunctionGroup(methodName, functionsFromSupertypes, functionsFromCurrent, classDescriptor, new OverrideResolver.DescriptorSink() {
1333
                @Override
S
Stepan Koltsov 已提交
1334 1335
                public void addToScope(@NotNull CallableMemberDescriptor fakeOverride) {
                    functions.add((FunctionDescriptor) fakeOverride);
1336
                }
1337 1338

                @Override
S
Stepan Koltsov 已提交
1339
                public void conflict(@NotNull CallableMemberDescriptor fromSuper, @NotNull CallableMemberDescriptor fromCurrent) {
1340 1341
                    // nop
                }
1342 1343 1344 1345 1346 1347 1348 1349 1350
            });

        }

        functions.addAll(functionsFromCurrent);

        namedMembers.functionDescriptors = functions;
    }
    
1351 1352
    private Set<SimpleFunctionDescriptor> getFunctionsFromSupertypes(ResolverScopeData scopeData, String methodName) {
        Set<SimpleFunctionDescriptor> r = new HashSet<SimpleFunctionDescriptor>();
1353 1354
        for (JetType supertype : getSupertypes(scopeData)) {
            for (FunctionDescriptor function : supertype.getMemberScope().getFunctions(methodName)) {
1355
                r.add((SimpleFunctionDescriptor) function);
1356
            }
1357
        }
1358
        return r;
1359 1360
    }

1361
    private ResolverScopeData getResolverScopeData(@NotNull ClassOrNamespaceDescriptor owner, PsiClassWrapper psiClass) {
1362
        // TODO: store scopeData in Java*Scope
1363
        ResolverScopeData scopeData;
1364
        boolean staticMembers;
1365 1366
        if (owner instanceof JavaNamespaceDescriptor) {
            scopeData = namespaceDescriptorCacheByFqn.get(((JavaNamespaceDescriptor) owner).getQualifiedName());
1367
            staticMembers = true;
1368
        } else if (owner instanceof ClassDescriptor) {
S
Stepan Koltsov 已提交
1369
            scopeData = classDescriptorCache.get(new FqName(psiClass.getQualifiedName()));
1370
            staticMembers = false;
1371
        } else {
1372
            throw new IllegalStateException("unknown owner: " + owner.getClass().getName());
1373 1374 1375 1376 1377
        }
        if (scopeData == null) {
            throw new IllegalStateException();
        }
        
1378 1379
        if (scopeData.namedMembersMap == null) {
            scopeData.namedMembersMap = JavaDescriptorResolverHelper.getNamedMembers(psiClass, staticMembers, scopeData.kotlin);
1380 1381
        }
        
1382
        return scopeData;
1383
    }
A
Andrey Breslav 已提交
1384

A
Andrey Breslav 已提交
1385
    @NotNull
1386
    public Set<FunctionDescriptor> resolveFunctionGroup(@NotNull ClassOrNamespaceDescriptor descriptor, @NotNull PsiClass psiClass, @NotNull String methodName, boolean staticMembers) {
A
Andrey Breslav 已提交
1387

1388
        ResolverScopeData resolverScopeData = getResolverScopeData(descriptor, new PsiClassWrapper(psiClass));
A
Andrey Breslav 已提交
1389

1390 1391 1392
        Map<String, NamedMembers> namedMembersMap = resolverScopeData.namedMembersMap;

        NamedMembers namedMembers = namedMembersMap.get(methodName);
1393 1394
        if (namedMembers != null && namedMembers.methods != null) {
            TypeSubstitutor typeSubstitutor = typeSubstitutorForGenericSupertypes(resolverScopeData);
1395

1396 1397 1398
            resolveNamedGroupFunctions(descriptor, psiClass, typeSubstitutor, namedMembers, methodName, resolverScopeData);

            return namedMembers.functionDescriptors;
1399
        } else {
1400
            return Collections.emptySet();
1401
        }
1402 1403
    }

1404
    private TypeSubstitutor createSubstitutorForGenericSupertypes(@Nullable ClassDescriptor classDescriptor) {
A
Andrey Breslav 已提交
1405 1406 1407 1408 1409 1410 1411 1412 1413
        TypeSubstitutor typeSubstitutor;
        if (classDescriptor != null) {
            typeSubstitutor = TypeUtils.buildDeepSubstitutor(classDescriptor.getDefaultType());
        }
        else {
            typeSubstitutor = TypeSubstitutor.EMPTY;
        }
        return typeSubstitutor;
    }
1414

1415 1416 1417 1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438
    private ValueParameterDescriptors resolveParameterDescriptors(DeclarationDescriptor containingDeclaration,
            List<PsiParameterWrapper> parameters, TypeVariableResolver typeVariableResolver) {
        List<ValueParameterDescriptor> result = new ArrayList<ValueParameterDescriptor>();
        JetType receiverType = null;
        int indexDelta = 0;
        for (int i = 0, parametersLength = parameters.size(); i < parametersLength; i++) {
            PsiParameterWrapper parameter = parameters.get(i);
            JvmMethodParameterMeaning meaning = resolveParameterDescriptor(containingDeclaration, i + indexDelta, parameter, typeVariableResolver);
            if (meaning.kind == JvmMethodParameterKind.TYPE_INFO) {
                // TODO
                --indexDelta;
            } else if (meaning.kind == JvmMethodParameterKind.REGULAR) {
                result.add(meaning.valueParameterDescriptor);
            } else if (meaning.kind == JvmMethodParameterKind.RECEIVER) {
                if (receiverType != null) {
                    throw new IllegalStateException("more then one receiver");
                }
                --indexDelta;
                receiverType = meaning.receiverType;
            }
        }
        return new ValueParameterDescriptors(receiverType, result);
    }

A
Andrey Breslav 已提交
1439
    @Nullable
S
Stepan Koltsov 已提交
1440
    private FunctionDescriptorImpl resolveMethodToFunctionDescriptor(ClassOrNamespaceDescriptor owner, final PsiClass psiClass, final PsiMethodWrapper method) {
1441

1442
        PsiType returnType = method.getReturnType();
A
Andrey Breslav 已提交
1443 1444 1445
        if (returnType == null) {
            return null;
        }
1446 1447
        ResolverScopeData scopeData = getResolverScopeData(owner, new PsiClassWrapper(psiClass));

1448 1449 1450 1451 1452 1453 1454 1455 1456
        boolean kotlin;
        if (owner instanceof JavaNamespaceDescriptor) {
            JavaNamespaceDescriptor javaNamespaceDescriptor = (JavaNamespaceDescriptor) owner;
            ResolverNamespaceData namespaceData = namespaceDescriptorCacheByFqn.get(javaNamespaceDescriptor.getQualifiedName());
            if (namespaceData == null) {
                throw new IllegalStateException("namespaceData not found by name " + javaNamespaceDescriptor.getQualifiedName());
            }
            kotlin = namespaceData.kotlin;
        } else {
S
Stepan Koltsov 已提交
1457
            ResolverBinaryClassData classData = classDescriptorCache.get(new FqName(psiClass.getQualifiedName()));
1458 1459 1460 1461 1462 1463
            if (classData == null) {
                throw new IllegalStateException("classData not found by name " + psiClass.getQualifiedName());
            }
            kotlin = classData.kotlin;
        }

1464
        // TODO: ugly
1465
        if (method.getJetMethod().kind() == JvmStdlibNames.JET_METHOD_KIND_PROPERTY) {
1466
            return null;
1467
        }
1468

S
Stepan Koltsov 已提交
1469 1470 1471 1472 1473 1474 1475 1476
        if (kotlin) {
            // TODO: unless maybe class explicitly extends Object
            String ownerClassName = method.getPsiMethod().getContainingClass().getQualifiedName();
            if (ownerClassName.equals("java.lang.Object")) {
                return null;
            }
        }

1477
        ClassOrNamespaceDescriptor classDescriptor;
1478
        if (scopeData instanceof ResolverBinaryClassData) {
1479
            ClassDescriptor classClassDescriptor = resolveClass(method.getPsiMethod().getContainingClass(), DescriptorSearchRule.INCLUDE_KOTLIN);
1480
            classDescriptor = classClassDescriptor;
1481 1482 1483
        }
        else {
            classDescriptor = resolveNamespace(method.getPsiMethod().getContainingClass());
1484
        }
1485 1486 1487
        if (classDescriptor == null) {
            return null;
        }
1488

1489
        SimpleFunctionDescriptorImpl functionDescriptorImpl = new SimpleFunctionDescriptorImpl(
A
Andrey Breslav 已提交
1490
                owner,
1491
                resolveAnnotations(method.getPsiMethod()),
1492 1493
                method.getName(),
                CallableMemberDescriptor.Kind.DECLARATION
A
Andrey Breslav 已提交
1494
        );
1495

S
Stepan Koltsov 已提交
1496 1497 1498
        String context = "method " + method.getName() + " in class " + psiClass.getQualifiedName();

        final TypeVariableResolver typeVariableResolverForParameters = TypeVariableResolvers.classTypeVariableResolver(classDescriptor, context);
1499

1500
        final List<TypeParameterDescriptor> methodTypeParameters = resolveMethodTypeParameters(method, functionDescriptorImpl, typeVariableResolverForParameters);
1501

S
Stepan Koltsov 已提交
1502
        TypeVariableResolver methodTypeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(methodTypeParameters, functionDescriptorImpl, context);
1503 1504


1505
        ValueParameterDescriptors valueParameterDescriptors = resolveParameterDescriptors(functionDescriptorImpl, method.getParameters(), methodTypeVariableResolver);
A
Andrey Breslav 已提交
1506
        functionDescriptorImpl.initialize(
1507
                valueParameterDescriptors.receiverType,
A
Andrey Breslav 已提交
1508
                DescriptorUtils.getExpectedThisObjectIfNeeded(classDescriptor),
1509
                methodTypeParameters,
1510
                valueParameterDescriptors.descriptors,
1511
                makeReturnType(returnType, method, methodTypeVariableResolver),
1512 1513
                Modality.convertFromFlags(method.getPsiMethod().hasModifierProperty(PsiModifier.ABSTRACT), !method.isFinal()),
                resolveVisibilityFromPsiModifiers(method.getPsiMethod())
A
Andrey Breslav 已提交
1514
        );
1515
        semanticServices.getTrace().record(BindingContext.FUNCTION, method.getPsiMethod(), functionDescriptorImpl);
A
Andrey Breslav 已提交
1516
        FunctionDescriptor substitutedFunctionDescriptor = functionDescriptorImpl;
S
Stepan Koltsov 已提交
1517 1518
        if (method.getPsiMethod().getContainingClass() != psiClass && !method.isStatic()) {
            throw new IllegalStateException("non-static method in subclass");
A
Andrey Breslav 已提交
1519
        }
1520
        return (FunctionDescriptorImpl) substitutedFunctionDescriptor;
A
Andrey Breslav 已提交
1521
    }
1522

1523 1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544
    private List<AnnotationDescriptor> resolveAnnotations(PsiModifierListOwner owner) {
        PsiAnnotation[] psiAnnotations = owner.getModifierList().getAnnotations();
        List<AnnotationDescriptor> r = Lists.newArrayListWithCapacity(psiAnnotations.length);
        for (PsiAnnotation psiAnnotation : psiAnnotations) {
            AnnotationDescriptor annotation = resolveAnnotation(psiAnnotation);
            if (annotation != null) {
                r.add(annotation);
            }
        }
        return r;
    }

    @Nullable
    private AnnotationDescriptor resolveAnnotation(PsiAnnotation psiAnnotation) {
        AnnotationDescriptor annotation = new AnnotationDescriptor();

        String qname = psiAnnotation.getQualifiedName();
        if (qname.startsWith("java.lang.annotation.") || qname.startsWith("jet.runtime.typeinfo.") || qname.equals(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName())) {
            // TODO
            return null;
        }

1545
        ClassDescriptor clazz = resolveClass(new FqName(psiAnnotation.getQualifiedName()), DescriptorSearchRule.INCLUDE_KOTLIN);
1546 1547 1548 1549
        if (clazz == null) {
            return null;
        }
        annotation.setAnnotationType(clazz.getDefaultType());
1550
        ArrayList<CompileTimeConstant<?>> valueArguments = new ArrayList<CompileTimeConstant<?>>();
1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577 1578

        PsiAnnotationParameterList parameterList = psiAnnotation.getParameterList();
        for (PsiNameValuePair psiNameValuePair : parameterList.getAttributes()) {
            PsiAnnotationMemberValue value = psiNameValuePair.getValue();
            // todo
            assert value instanceof PsiLiteralExpression;
            Object literalValue = ((PsiLiteralExpression) value).getValue();
            if(literalValue instanceof String)
                valueArguments.add(new StringValue((String) literalValue));
            else if(literalValue instanceof Byte)
                valueArguments.add(new ByteValue((Byte) literalValue));
            else if(literalValue instanceof Short)
                valueArguments.add(new ShortValue((Short) literalValue));
            else if(literalValue instanceof Character)
                valueArguments.add(new CharValue((Character) literalValue));
            else if(literalValue instanceof Integer)
                valueArguments.add(new IntValue((Integer) literalValue));
            else if(literalValue instanceof Long)
                valueArguments.add(new LongValue((Long) literalValue));
            else if(literalValue instanceof Float)
                valueArguments.add(new FloatValue((Float) literalValue));
            else if(literalValue instanceof Double)
                valueArguments.add(new DoubleValue((Double) literalValue));
            else if(literalValue == null)
                valueArguments.add(NullValue.NULL);
        }

        annotation.setValueArguments(valueArguments); // TODO
1579 1580 1581
        return annotation;
    }

1582
    public List<FunctionDescriptor> resolveMethods(@NotNull PsiClass psiClass, @NotNull ClassOrNamespaceDescriptor containingDeclaration) {
1583 1584
        ResolverScopeData scopeData = getResolverScopeData(containingDeclaration, new PsiClassWrapper(psiClass));

1585
        TypeSubstitutor substitutorForGenericSupertypes = typeSubstitutorForGenericSupertypes(scopeData);
1586

1587
        List<FunctionDescriptor> functions = new ArrayList<FunctionDescriptor>();
1588 1589 1590 1591 1592

        for (Map.Entry<String, NamedMembers> entry : scopeData.namedMembersMap.entrySet()) {
            String methodName = entry.getKey();
            NamedMembers namedMembers = entry.getValue();
            resolveNamedGroupFunctions(containingDeclaration, psiClass, substitutorForGenericSupertypes, namedMembers, methodName, scopeData);
1593
            functions.addAll(namedMembers.functionDescriptors);
1594
        }
1595

1596 1597
        return functions;
    }
1598

1599 1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616
    private Collection<JetType> getSupertypes(ResolverScopeData scope) {
        if (scope instanceof ResolverBinaryClassData) {
            return ((ResolverBinaryClassData) scope).classDescriptor.getSupertypes();
        } else if (scope instanceof ResolverNamespaceData) {
            return Collections.emptyList();
        } else {
            throw new IllegalStateException();
        }
    }

    private TypeSubstitutor typeSubstitutorForGenericSupertypes(ResolverScopeData scopeData) {
        if (scopeData instanceof ResolverClassData) {
            return createSubstitutorForGenericSupertypes(((ResolverClassData) scopeData).getClassDescriptor());
        } else {
            return TypeSubstitutor.EMPTY;
        }
    }

1617
    private List<TypeParameterDescriptor> resolveMethodTypeParameters(
1618
            @NotNull PsiMethodWrapper method,
1619
            @NotNull DeclarationDescriptor functionDescriptor,
1620 1621
            @NotNull TypeVariableResolver classTypeVariableResolver) {

1622
        List<TypeParameterDescriptorInitialization> typeParametersIntialization;
1623
        if (method.getJetMethod().typeParameters().length() > 0) {
1624
            typeParametersIntialization = resolveMethodTypeParametersFromJetSignature(
S
Stepan Koltsov 已提交
1625
                    method.getJetMethod().typeParameters(), method.getPsiMethod(), functionDescriptor);
1626
        } else {
1627
            typeParametersIntialization = makeUninitializedTypeParameters(functionDescriptor, method.getPsiMethod().getTypeParameters());
1628
        }
1629

S
Stepan Koltsov 已提交
1630 1631
        String context = "method " + method.getName() + " in class " + method.getPsiMethod().getContainingClass().getQualifiedName();
        initializeTypeParameters(typeParametersIntialization, functionDescriptor, context);
1632 1633 1634 1635 1636 1637 1638
        
        List<TypeParameterDescriptor> typeParameters = Lists.newArrayListWithCapacity(typeParametersIntialization.size());
        
        for (TypeParameterDescriptorInitialization tpdi : typeParametersIntialization) {
            typeParameters.add(tpdi.descriptor);
        }
        
1639 1640
        return typeParameters;
    }
1641 1642

    /**
S
Stepan Koltsov 已提交
1643
     * @see #resolveClassTypeParametersFromJetSignature(String, com.intellij.psi.PsiClass, org.jetbrains.jet.lang.descriptors.ClassDescriptor)
1644
     */
S
Stepan Koltsov 已提交
1645 1646
    private List<TypeParameterDescriptorInitialization> resolveMethodTypeParametersFromJetSignature(String jetSignature,
            final PsiMethod method, final DeclarationDescriptor functionDescriptor)
1647
    {
S
Stepan Koltsov 已提交
1648 1649
        String context = "method " + method.getName() + " in class " + method.getContainingClass().getQualifiedName();
        JetSignatureTypeParametersVisitor jetSignatureTypeParametersVisitor = new JetSignatureTypeParametersVisitor(functionDescriptor, method, context);
1650 1651
        new JetSignatureReader(jetSignature).acceptFormalTypeParametersOnly(jetSignatureTypeParametersVisitor);
        return jetSignatureTypeParametersVisitor.r;
1652 1653
    }

1654 1655
    private JetType makeReturnType(PsiType returnType, PsiMethodWrapper method,
            @NotNull TypeVariableResolver typeVariableResolver) {
1656 1657 1658

        String returnTypeFromAnnotation = method.getJetMethod().returnType();

S
Stepan Koltsov 已提交
1659
        JetType transformedType;
1660
        if (returnTypeFromAnnotation.length() > 0) {
1661
            transformedType = semanticServices.getTypeTransformer().transformToType(returnTypeFromAnnotation, typeVariableResolver);
S
Stepan Koltsov 已提交
1662
        } else {
1663
            transformedType = semanticServices.getTypeTransformer().transformToType(returnType, typeVariableResolver);
S
Stepan Koltsov 已提交
1664
        }
1665 1666
        if (method.getJetMethod().returnTypeNullable()) {
            return TypeUtils.makeNullableAsSpecified(transformedType, true);
S
Stepan Koltsov 已提交
1667 1668
        } else if (method.getPsiMethod().getModifierList().findAnnotation(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName()) != null) {
            return TypeUtils.makeNullableAsSpecified(transformedType, false);
1669 1670 1671 1672 1673
        } else {
            return transformedType;
        }
    }

1674
    private static Visibility resolveVisibilityFromPsiModifiers(PsiModifierListOwner modifierListOwner) {
1675 1676 1677 1678 1679 1680
        //TODO report error
        return modifierListOwner.hasModifierProperty(PsiModifier.PUBLIC) ? Visibility.PUBLIC :
                                        (modifierListOwner.hasModifierProperty(PsiModifier.PRIVATE) ? Visibility.PRIVATE :
                                        (modifierListOwner.hasModifierProperty(PsiModifier.PROTECTED) ? Visibility.PROTECTED : Visibility.INTERNAL));
    }

1681
    public List<ClassDescriptor> resolveInnerClasses(DeclarationDescriptor owner, PsiClass psiClass, boolean staticMembers) {
1682 1683 1684 1685
        if (staticMembers) {
            return new ArrayList<ClassDescriptor>(0);
        }

1686 1687 1688
        PsiClass[] innerPsiClasses = psiClass.getInnerClasses();
        List<ClassDescriptor> r = new ArrayList<ClassDescriptor>(innerPsiClasses.length);
        for (PsiClass innerPsiClass : innerPsiClasses) {
1689 1690 1691 1692
            if (innerPsiClass.hasModifierProperty(PsiModifier.PRIVATE)) {
                // TODO: hack against inner classes
                continue;
            }
1693 1694 1695
            if (innerPsiClass.getName().equals(JvmAbi.CLASS_OBJECT_CLASS_NAME)) {
                continue;
            }
1696
            r.add(resolveClass(innerPsiClass, DescriptorSearchRule.IGNORE_IF_FOUND_IN_KOTLIN));
1697 1698 1699
        }
        return r;
    }
1700
}