JavaDescriptorResolver.java 77.9 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 532 533 534 535 536

    // cache
    protected ClassDescriptor javaLangObject;

    @NotNull
    private ClassDescriptor getJavaLangObject() {
        if (javaLangObject == null) {
537
            javaLangObject = resolveClass(new FqName("java.lang.Object"), DescriptorSearchRule.ERROR_IF_FOUND_IN_KOTLIN);
S
Stepan Koltsov 已提交
538 539 540 541 542 543 544 545 546
        }
        return javaLangObject;
    }

    private boolean isJavaLangObject(JetType type) {
        return type.getConstructor().getDeclarationDescriptor() == getJavaLangObject();
    }


547
    private abstract class JetSignatureTypeParameterVisitor extends JetSignatureExceptionsAdapter {
548 549

        @NotNull
550
        private final PsiTypeParameterListOwner psiOwner;
551
        @NotNull
552
        private final String name;
553
        @NotNull
554
        private final TypeVariableResolver typeVariableResolver;
555 556
        @NotNull
        private final TypeParameterDescriptor typeParameterDescriptor;
557

558 559
        protected JetSignatureTypeParameterVisitor(PsiTypeParameterListOwner psiOwner,
                String name, TypeVariableResolver typeVariableResolver, TypeParameterDescriptor typeParameterDescriptor)
560
        {
561 562 563
            if (name.isEmpty()) {
                throw new IllegalStateException();
            }
564

565 566
            this.psiOwner = psiOwner;
            this.name = name;
567
            this.typeVariableResolver = typeVariableResolver;
568
            this.typeParameterDescriptor = typeParameterDescriptor;
569 570 571 572
        }

        List<JetType> upperBounds = new ArrayList<JetType>();
        List<JetType> lowerBounds = new ArrayList<JetType>();
S
Stepan Koltsov 已提交
573
        
574 575
        @Override
        public JetSignatureVisitor visitClassBound() {
576
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
577 578
                @Override
                protected void done(@NotNull JetType jetType) {
S
Stepan Koltsov 已提交
579 580 581
                    if (isJavaLangObject(jetType)) {
                        return;
                    }
582 583 584 585 586 587 588
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public JetSignatureVisitor visitInterfaceBound() {
589
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
590 591 592 593 594 595 596 597 598
                @Override
                protected void done(@NotNull JetType jetType) {
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public void visitFormalTypeParameterEnd() {
599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617
            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 已提交
618
        private JetSignatureTypeParametersVisitor(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameterListOwner psiOwner, @NotNull String context) {
619 620 621
            this.containingDeclaration = containingDeclaration;
            this.psiOwner = psiOwner;

S
Stepan Koltsov 已提交
622 623 624 625
            this.typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(
                    previousTypeParameters,
                    containingDeclaration,
                    context);
626 627 628 629 630 631 632 633 634
        }

        private int formalTypeParameterIndex = 0;


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

        @Override
        public JetSignatureVisitor visitFormalTypeParameter(final String name, final TypeInfoVariance variance, boolean reified) {
635 636 637
            TypeParameterDescriptor typeParameter = TypeParameterDescriptor.createForFurtherModification(
                    containingDeclaration,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO: wrong
638
                    reified,
639 640
                    JetSignatureUtils.translateVariance(variance),
                    name,
641 642 643 644 645 646 647 648 649 650 651
                    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);
                }
            };
652
        }
653 654
    }

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

            @Override
            public JetSignatureVisitor visitInterface() {
                // TODO
                return new JetSignatureAdapter();
            }
673 674 675
        };
        new JetSignatureReader(jetSignature).accept(jetSignatureTypeParametersVisitor);
        return jetSignatureTypeParametersVisitor.r;
676 677
    }

S
Stepan Koltsov 已提交
678
    private ClassOrNamespaceDescriptor resolveParentDescriptor(PsiClass psiClass) {
679 680
        PsiClass containingClass = psiClass.getContainingClass();
        if (containingClass != null) {
681
            return resolveClass(containingClass, DescriptorSearchRule.INCLUDE_KOTLIN);
682
        }
683

684
        return resolveNamespace(new FqName(psiClass.getQualifiedName()).parent(), DescriptorSearchRule.INCLUDE_KOTLIN);
685 686
    }

687 688
    private List<TypeParameterDescriptorInitialization> makeUninitializedTypeParameters(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter[] typeParameters) {
        List<TypeParameterDescriptorInitialization> result = Lists.newArrayList();
689
        for (PsiTypeParameter typeParameter : typeParameters) {
690
            TypeParameterDescriptorInitialization typeParameterDescriptor = makeUninitializedTypeParameter(containingDeclaration, typeParameter);
A
Andrey Breslav 已提交
691
            result.add(typeParameterDescriptor);
692 693 694 695
        }
        return result;
    }

696
    @NotNull
697
    private TypeParameterDescriptorInitialization makeUninitializedTypeParameter(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter psiTypeParameter) {
698
        TypeParameterDescriptor typeParameterDescriptor = TypeParameterDescriptor.createForFurtherModification(
699
                containingDeclaration,
A
Andrey Breslav 已提交
700
                Collections.<AnnotationDescriptor>emptyList(), // TODO
A
Andrey Breslav 已提交
701
                false,
702
                Variance.INVARIANT,
703 704
                psiTypeParameter.getName(),
                psiTypeParameter.getIndex()
705
        );
706
        return new TypeParameterDescriptorInitialization(typeParameterDescriptor, psiTypeParameter);
707 708
    }

709
    private void initializeTypeParameter(TypeParameterDescriptorInitialization typeParameter, TypeVariableResolver typeVariableByPsiResolver) {
710 711 712
        TypeParameterDescriptor typeParameterDescriptor = typeParameter.descriptor;
        if (typeParameter.origin == TypeParameterDescriptorOrigin.KOTLIN) {
            List<?> upperBounds = typeParameter.upperBoundsForKotlin;
713 714 715
            if (upperBounds.size() == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            } else {
716
                for (JetType upperBound : typeParameter.upperBoundsForKotlin) {
717 718 719 720 721
                    typeParameterDescriptor.addUpperBound(upperBound);
                }
            }

            // TODO: lower bounds
722
        } else {
723
            PsiClassType[] referencedTypes = typeParameter.psiTypeParameter.getExtendsList().getReferencedTypes();
724 725 726 727
            if (referencedTypes.length == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            }
            else if (referencedTypes.length == 1) {
728
                typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedTypes[0], typeVariableByPsiResolver));
729 730 731
            }
            else {
                for (PsiClassType referencedType : referencedTypes) {
732
                    typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedType, typeVariableByPsiResolver));
733
                }
A
Andrey Breslav 已提交
734 735
            }
        }
736
        typeParameterDescriptor.setInitialized();
737 738
    }

S
Stepan Koltsov 已提交
739
    private void initializeTypeParameters(List<TypeParameterDescriptorInitialization> typeParametersInitialization, @NotNull DeclarationDescriptor typeParametersOwner, @NotNull String context) {
740
        List<TypeParameterDescriptor> prevTypeParameters = new ArrayList<TypeParameterDescriptor>();
741
        for (TypeParameterDescriptorInitialization psiTypeParameter : typeParametersInitialization) {
742
            prevTypeParameters.add(psiTypeParameter.descriptor);
S
Stepan Koltsov 已提交
743
            initializeTypeParameter(psiTypeParameter, TypeVariableResolvers.typeVariableResolverFromTypeParameters(prevTypeParameters, typeParametersOwner, context));
S
Stepan Koltsov 已提交
744
        }
A
Andrey Breslav 已提交
745 746
    }

747
    private Collection<JetType> getSupertypes(PsiClassWrapper psiClass, ClassDescriptor classDescriptor, List<TypeParameterDescriptor> typeParameters) {
748 749
        final List<JetType> result = new ArrayList<JetType>();

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

752
        if (psiClass.getJetClass().signature().length() > 0) {
S
Stepan Koltsov 已提交
753
            final TypeVariableResolver typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(typeParameters, classDescriptor, context);
754 755 756 757 758 759 760 761 762 763
            
            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() {
764
                    return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
765 766 767 768 769 770 771 772 773 774 775
                        @Override
                        protected void done(@NotNull JetType jetType) {
                            if (!jetType.equals(JetStandardClasses.getAnyType())) {
                                result.add(jetType);
                            }
                        }
                    };
                }

                @Override
                public JetSignatureVisitor visitInterface() {
S
Stepan Koltsov 已提交
776
                    return visitSuperclass();
777 778 779
                }
            });
        } else {
S
Stepan Koltsov 已提交
780 781 782
            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);
783
        }
784 785 786 787 788 789 790
        
        for (JetType supertype : result) {
            if (ErrorUtils.isErrorType(supertype)) {
                semanticServices.getTrace().record(BindingContext.INCOMPLETE_HIERARCHY, classDescriptor);
            }
        }
        
791 792 793
        if (result.isEmpty()) {
            result.add(JetStandardClasses.getAnyType());
        }
794 795 796
        return result;
    }

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

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

813
    @Nullable
814
    public NamespaceDescriptor resolveNamespace(@NotNull FqName qualifiedName, @NotNull DescriptorSearchRule searchRule) {
815 816 817
        // First, let's check that there is no Kotlin package:
        NamespaceDescriptor kotlinNamespaceDescriptor = semanticServices.getKotlinNamespaceDescriptor(qualifiedName);
        if (kotlinNamespaceDescriptor != null) {
818 819 820 821 822 823 824 825 826 827
            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);
            }
828 829
        }

830
        PsiPackage psiPackage = findPackage(qualifiedName);
831
        if (psiPackage == null) {
832
            PsiClass psiClass = findClass(qualifiedName);
A
Andrey Breslav 已提交
833 834
            if (psiClass == null) return null;
            return resolveNamespace(psiClass);
835 836 837 838
        }
        return resolveNamespace(psiPackage);
    }

839
    @Nullable
S
Stepan Koltsov 已提交
840 841
    public PsiClass findClass(@NotNull FqName qualifiedName) {
        PsiClass original = javaFacade.findClass(qualifiedName.getFqName(), javaSearchScope);
M
Maxim Shafirov 已提交
842
        PsiClass altClass = altClassFinder.findClass(qualifiedName);
843
        PsiClass result = original;
844 845 846 847 848
        if (altClass != null) {
            if (altClass instanceof ClsClassImpl) {
                altClass.putUserData(ClsClassImpl.DELEGATE_KEY, original);
            }

849 850 851 852
            result = altClass;
        }

        if (result != null) {
S
Stepan Koltsov 已提交
853
            FqName actualQualifiedName = new FqName(result.getQualifiedName());
854
            if (!actualQualifiedName.equals(qualifiedName)) {
855
//                throw new IllegalStateException("requested " + qualifiedName + ", got " + actualQualifiedName);
856
            }
857
        }
858 859

        return result;
860 861
    }

S
Stepan Koltsov 已提交
862 863
    /*package*/ PsiPackage findPackage(@NotNull FqName qualifiedName) {
        return javaFacade.findPackage(qualifiedName.getFqName());
864 865
    }

866
    private NamespaceDescriptor resolveNamespace(@NotNull PsiPackage psiPackage) {
867 868 869 870
        ResolverNamespaceData namespaceData = namespaceDescriptorCache.get(psiPackage);
        if (namespaceData == null) {
            namespaceData = createJavaNamespaceDescriptor(psiPackage);
            namespaceDescriptorCache.put(psiPackage, namespaceData);
S
Stepan Koltsov 已提交
871
            namespaceDescriptorCacheByFqn.put(new FqName(psiPackage.getQualifiedName()), namespaceData);
872
        }
873
        return namespaceData.namespaceDescriptor;
874 875
    }

A
Andrey Breslav 已提交
876
    private NamespaceDescriptor resolveNamespace(@NotNull PsiClass psiClass) {
877 878 879 880
        ResolverNamespaceData namespaceData = namespaceDescriptorCache.get(psiClass);
        if (namespaceData == null) {
            namespaceData = createJavaNamespaceDescriptor(psiClass);
            namespaceDescriptorCache.put(psiClass, namespaceData);
S
Stepan Koltsov 已提交
881
            namespaceDescriptorCacheByFqn.put(new FqName(psiClass.getQualifiedName()), namespaceData);
A
Andrey Breslav 已提交
882
        }
883
        return namespaceData.namespaceDescriptor;
A
Andrey Breslav 已提交
884 885
    }

886 887
    private ResolverNamespaceData createJavaNamespaceDescriptor(@NotNull PsiPackage psiPackage) {
        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
888
        String name = psiPackage.getName();
889
        namespaceData.namespaceDescriptor = new JavaNamespaceDescriptor(
S
Stepan Koltsov 已提交
890
                (NamespaceDescriptorParent) resolveParentDescriptor(psiPackage),
A
Andrey Breslav 已提交
891
                Collections.<AnnotationDescriptor>emptyList(), // TODO
892
                name == null ? JAVA_ROOT : name,
S
Stepan Koltsov 已提交
893
                name == null ? FqName.ROOT : new FqName(psiPackage.getQualifiedName()),
894
                true
895
        );
896

S
Stepan Koltsov 已提交
897
        namespaceData.namespaceDescriptor.setMemberScope(new JavaPackageScope(new FqName(psiPackage.getQualifiedName()), namespaceData.namespaceDescriptor, semanticServices));
898 899 900 901
        semanticServices.getTrace().record(BindingContext.NAMESPACE, psiPackage, namespaceData.namespaceDescriptor);
        // TODO: hack
        namespaceData.kotlin = true;
        return namespaceData;
902 903
    }

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

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

        checkPsiClassIsNotJet(psiClass);

921 922
        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
        namespaceData.namespaceDescriptor = new JavaNamespaceDescriptor(
S
Stepan Koltsov 已提交
923
                (NamespaceDescriptorParent) resolveParentDescriptor(psiClass),
A
Andrey Breslav 已提交
924
                Collections.<AnnotationDescriptor>emptyList(), // TODO
925
                psiClass.getName(),
S
Stepan Koltsov 已提交
926
                new FqName(psiClass.getQualifiedName()),
927
                false
928
        );
929 930 931
        namespaceData.namespaceDescriptor.setMemberScope(new JavaClassMembersScope(namespaceData.namespaceDescriptor, psiClass, semanticServices, true));
        semanticServices.getTrace().record(BindingContext.NAMESPACE, psiClass, namespaceData.namespaceDescriptor);
        return namespaceData;
932
    }
933 934 935 936 937 938 939 940 941 942
    
    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;
        }
    }
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 974 975 976
    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
977
    private JvmMethodParameterMeaning resolveParameterDescriptor(DeclarationDescriptor containingDeclaration, int i,
978 979 980 981 982 983 984
            PsiParameterWrapper parameter, TypeVariableResolver typeVariableResolver) {

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

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

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

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

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

        JetType varargElementType;
        if (psiType instanceof PsiEllipsisType) {
1006
            varargElementType = JetStandardLibrary.getInstance().getArrayElementType(outType);
1007 1008 1009 1010
        } else {
            varargElementType = null;
        }

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

            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;
            }
1023 1024 1025 1026 1027
            return JvmMethodParameterMeaning.regular(new ValueParameterDescriptorImpl(
                    containingDeclaration,
                    i,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO
                    name,
S
Stepan Koltsov 已提交
1028
                    false,
S
Stepan Koltsov 已提交
1029
                    transformedType,
1030
                    hasDefaultValue,
1031 1032 1033
                    varargElementType
            ));
        }
1034 1035
    }

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

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

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

1047 1048 1049 1050 1051 1052 1053
        r.addAll(namedMembers.propertyDescriptors);

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

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

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

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

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

    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());
        }
    }

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

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

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

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

1141
        for (PropertyAccessorData propertyAccessor : namedMembers.propertyAccessors) {
1142

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

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

1156 1157 1158 1159 1160 1161 1162 1163 1164 1165 1166 1167 1168 1169 1170 1171 1172 1173
            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();
            }
1174
        }
1175

1176
        
1177 1178
        Set<VariableDescriptor> r = new HashSet<VariableDescriptor>(1);

1179 1180 1181 1182 1183 1184 1185 1186 1187 1188 1189 1190 1191 1192
        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;
            }
1193

1194
            boolean isFinal;
1195 1196 1197
            if (!scopeData.kotlin) {
                isFinal = true;
            } else if (members.setter == null && members.getter == null) {
1198 1199 1200 1201 1202 1203 1204 1205
                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;
            }
1206

1207 1208 1209 1210 1211 1212 1213 1214 1215 1216
            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();
            }
1217

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

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


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

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

1253
            propertyDescriptor.initialize(getterDescriptor, setterDescriptor);
1254

S
Stepan Koltsov 已提交
1255
            List<TypeParameterDescriptor> typeParameters = new ArrayList<TypeParameterDescriptor>(0);
1256 1257 1258

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

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

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

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

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

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

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

1311
        namedMembers.propertyDescriptors = r;
1312
    }
1313

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

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

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

1333
            Set<SimpleFunctionDescriptor> functionsFromSupertypes = getFunctionsFromSupertypes(scopeData, methodName);
1334

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

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

        }

        functions.addAll(functionsFromCurrent);

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

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

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

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

1393 1394 1395
        Map<String, NamedMembers> namedMembersMap = resolverScopeData.namedMembersMap;

        NamedMembers namedMembers = namedMembersMap.get(methodName);
1396 1397
        if (namedMembers != null && namedMembers.methods != null) {
            TypeSubstitutor typeSubstitutor = typeSubstitutorForGenericSupertypes(resolverScopeData);
1398

1399 1400 1401
            resolveNamedGroupFunctions(descriptor, psiClass, typeSubstitutor, namedMembers, methodName, resolverScopeData);

            return namedMembers.functionDescriptors;
1402
        } else {
1403
            return Collections.emptySet();
1404
        }
1405 1406
    }

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

1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435 1436 1437 1438 1439 1440 1441
    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 已提交
1442
    @Nullable
S
Stepan Koltsov 已提交
1443
    private FunctionDescriptorImpl resolveMethodToFunctionDescriptor(ClassOrNamespaceDescriptor owner, final PsiClass psiClass, final PsiMethodWrapper method) {
1444

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

1451 1452 1453 1454 1455 1456 1457 1458 1459
        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 已提交
1460
            ResolverBinaryClassData classData = classDescriptorCache.get(new FqName(psiClass.getQualifiedName()));
1461 1462 1463 1464 1465 1466
            if (classData == null) {
                throw new IllegalStateException("classData not found by name " + psiClass.getQualifiedName());
            }
            kotlin = classData.kotlin;
        }

1467
        // TODO: ugly
1468
        if (method.getJetMethod().kind() == JvmStdlibNames.JET_METHOD_KIND_PROPERTY) {
1469
            return null;
1470
        }
1471

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

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

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

S
Stepan Koltsov 已提交
1499 1500 1501
        String context = "method " + method.getName() + " in class " + psiClass.getQualifiedName();

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

1503
        final List<TypeParameterDescriptor> methodTypeParameters = resolveMethodTypeParameters(method, functionDescriptorImpl, typeVariableResolverForParameters);
1504

S
Stepan Koltsov 已提交
1505
        TypeVariableResolver methodTypeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(methodTypeParameters, functionDescriptorImpl, context);
1506 1507


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

1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547
    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;
        }

1548
        ClassDescriptor clazz = resolveClass(new FqName(psiAnnotation.getQualifiedName()), DescriptorSearchRule.INCLUDE_KOTLIN);
1549 1550 1551 1552
        if (clazz == null) {
            return null;
        }
        annotation.setAnnotationType(clazz.getDefaultType());
1553
        ArrayList<CompileTimeConstant<?>> valueArguments = new ArrayList<CompileTimeConstant<?>>();
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 1579 1580 1581

        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
1582 1583 1584
        return annotation;
    }

1585
    public List<FunctionDescriptor> resolveMethods(@NotNull PsiClass psiClass, @NotNull ClassOrNamespaceDescriptor containingDeclaration) {
1586 1587
        ResolverScopeData scopeData = getResolverScopeData(containingDeclaration, new PsiClassWrapper(psiClass));

1588
        TypeSubstitutor substitutorForGenericSupertypes = typeSubstitutorForGenericSupertypes(scopeData);
1589

1590
        List<FunctionDescriptor> functions = new ArrayList<FunctionDescriptor>();
1591 1592 1593 1594 1595

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

1599 1600
        return functions;
    }
1601

1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619
    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;
        }
    }

1620
    private List<TypeParameterDescriptor> resolveMethodTypeParameters(
1621
            @NotNull PsiMethodWrapper method,
1622
            @NotNull DeclarationDescriptor functionDescriptor,
1623 1624
            @NotNull TypeVariableResolver classTypeVariableResolver) {

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

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

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

1657 1658
    private JetType makeReturnType(PsiType returnType, PsiMethodWrapper method,
            @NotNull TypeVariableResolver typeVariableResolver) {
1659 1660 1661

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

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

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

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

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