JavaDescriptorResolver.java 77.6 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.psi.*;
25
import jet.typeinfo.TypeInfoVariance;
26 27
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
28
import org.jetbrains.jet.lang.descriptors.*;
A
Andrey Breslav 已提交
29
import org.jetbrains.jet.lang.descriptors.annotations.AnnotationDescriptor;
30
import org.jetbrains.jet.lang.psi.JetPsiUtil;
31
import org.jetbrains.jet.lang.resolve.*;
32
import org.jetbrains.jet.lang.resolve.constants.*;
33
import org.jetbrains.jet.lang.resolve.java.kt.JetClassAnnotation;
34
import org.jetbrains.jet.lang.types.*;
S
Stepan Koltsov 已提交
35
import org.jetbrains.jet.lang.types.lang.JetStandardClasses;
36
import org.jetbrains.jet.lang.types.lang.JetStandardLibrary;
37
import org.jetbrains.jet.rt.signature.JetSignatureAdapter;
38 39 40
import org.jetbrains.jet.rt.signature.JetSignatureExceptionsAdapter;
import org.jetbrains.jet.rt.signature.JetSignatureReader;
import org.jetbrains.jet.rt.signature.JetSignatureVisitor;
41

42
import javax.inject.Inject;
43
import java.util.*;
44 45 46 47 48

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

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

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

56 57
        @Override
        public DeclarationDescriptor substitute(TypeSubstitutor substitutor) {
58
            throw new UnsupportedOperationException();
59 60
        }

61 62
        @Override
        public <R, D> R accept(DeclarationDescriptorVisitor<R, D> visitor, D data) {
63
            return visitor.visitDeclarationDescriptor(this, data);
64 65 66
        }
    };

A
Andrey Breslav 已提交
67
    /*package*/ static final DeclarationDescriptor JAVA_CLASS_OBJECT = new DeclarationDescriptorImpl(null, Collections.<AnnotationDescriptor>emptyList(), "<java_class_object_emulation>") {
A
Andrey Breslav 已提交
68 69 70
        @NotNull
        @Override
        public DeclarationDescriptor substitute(TypeSubstitutor substitutor) {
71
            throw new UnsupportedOperationException();
A
Andrey Breslav 已提交
72 73 74 75 76 77 78
        }

        @Override
        public <R, D> R accept(DeclarationDescriptorVisitor<R, D> visitor, D data) {
            return visitor.visitDeclarationDescriptor(this, data);
        }
    };
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96

    private static Visibility PACKAGE_VISIBILITY = new Visibility("package", false) {
        @Override
        protected boolean isVisible(@NotNull DeclarationDescriptorWithVisibility what, @NotNull DeclarationDescriptor from) {
            NamespaceDescriptor parentPackage = DescriptorUtils.getParentOfType(what, NamespaceDescriptor.class);
            NamespaceDescriptor fromPackage = DescriptorUtils.getParentOfType(from, NamespaceDescriptor.class, false);
            assert parentPackage != null;
            return parentPackage.equals(fromPackage);
        }

        @Override
        protected Integer compareTo(@NotNull Visibility visibility) {
            if (this == visibility) return 0;
            if (visibility == Visibilities.PRIVATE) return 1;
            return -1;
        }
    };

97 98 99 100
    private enum TypeParameterDescriptorOrigin {
        JAVA,
        KOTLIN,
    }
101

102 103
    public static class TypeParameterDescriptorInitialization {
        @NotNull
104
        private final TypeParameterDescriptorOrigin origin;
105 106 107
        @NotNull
        final TypeParameterDescriptor descriptor;
        final PsiTypeParameter psiTypeParameter;
108 109 110 111
        @Nullable
        private final List<JetType> upperBoundsForKotlin;
        @Nullable
        private final List<JetType> lowerBoundsForKotlin;
112

113
        private TypeParameterDescriptorInitialization(@NotNull TypeParameterDescriptor descriptor, @NotNull PsiTypeParameter psiTypeParameter) {
114
            this.origin = TypeParameterDescriptorOrigin.JAVA;
115
            this.descriptor = descriptor;
116
            this.psiTypeParameter = psiTypeParameter;
117 118 119 120
            this.upperBoundsForKotlin = null;
            this.lowerBoundsForKotlin = null;
        }

121
        private TypeParameterDescriptorInitialization(@NotNull TypeParameterDescriptor descriptor, @NotNull PsiTypeParameter psiTypeParameter,
122 123 124
                List<JetType> upperBoundsForKotlin, List<JetType> lowerBoundsForKotlin) {
            this.origin = TypeParameterDescriptorOrigin.KOTLIN;
            this.descriptor = descriptor;
125
            this.psiTypeParameter = psiTypeParameter;
126 127
            this.upperBoundsForKotlin = upperBoundsForKotlin;
            this.lowerBoundsForKotlin = lowerBoundsForKotlin;
128 129
        }
    }
130 131


132
    private static abstract class ResolverScopeData {
133
        protected boolean kotlin;
134 135
        
        private Map<String, NamedMembers> namedMembersMap;
136 137 138
        
        @NotNull
        public abstract List<TypeParameterDescriptor> getTypeParameters();
139
    }
A
Andrey Breslav 已提交
140

141
    /** Class with instance members */
S
Stepan Koltsov 已提交
142
    static class ResolverBinaryClassData extends ResolverScopeData {
143 144 145 146

        ResolverBinaryClassData() {
        }

147
        private MutableClassDescriptorLite classDescriptor;
148

149 150 151 152 153 154 155 156 157
        List<TypeParameterDescriptorInitialization> typeParameters;

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

        @NotNull
        @Override
S
Stepan Koltsov 已提交
158 159
        public List<TypeParameterDescriptor> getTypeParameters() {
            return getClassDescriptor().getTypeConstructor().getParameters();
160
        }
S
Stepan Koltsov 已提交
161

162 163
    }

164
    /** Either package or class with static members */
165
    private static class ResolverNamespaceData extends ResolverScopeData {
S
Stepan Koltsov 已提交
166 167
        private NamespaceDescriptor namespaceDescriptor;
        private JavaPackageScope memberScope;
168 169 170 171 172

        @NotNull
        public NamespaceDescriptor getNamespaceDescriptor() {
            return namespaceDescriptor;
        }
173 174 175 176 177 178

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

S
Stepan Koltsov 已提交
181 182
    protected final Map<FqName, ResolverBinaryClassData> classDescriptorCache = Maps.newHashMap();
    protected final Map<FqName, ResolverNamespaceData> namespaceDescriptorCacheByFqn = Maps.newHashMap();
183

184 185
    protected Project project;
    protected JavaSemanticServices semanticServices;
186
    private NamespaceFactory namespaceFactory;
187
    private BindingTrace trace;
S
Stepan Koltsov 已提交
188
    private PsiClassFinder psiClassFinder;
189

190 191 192 193 194
    @Inject
    public void setProject(Project project) {
        this.project = project;
    }

195 196 197 198 199
    @Inject
    public void setNamespaceFactory(NamespaceFactoryImpl namespaceFactory) {
        this.namespaceFactory = namespaceFactory;
    }

200 201
    @Inject
    public void setSemanticServices(JavaSemanticServices semanticServices) {
202 203
        this.semanticServices = semanticServices;
    }
204

205 206 207 208 209
    @Inject
    public void setTrace(BindingTrace trace) {
        this.trace = trace;
    }

S
Stepan Koltsov 已提交
210 211 212 213
    @Inject
    public void setPsiClassFinder(PsiClassFinder psiClassFinder) {
        this.psiClassFinder = psiClassFinder;
    }
214

215

216 217

    @Nullable
218
    public ClassDescriptor resolveClass(@NotNull FqName qualifiedName, @NotNull DescriptorSearchRule searchRule) {
219

S
Stepan Koltsov 已提交
220
        if (qualifiedName.getFqName().endsWith(JvmAbi.TRAIT_IMPL_SUFFIX)) {
221 222 223
            // TODO: only if -$$TImpl class is created by Kotlin
            return null;
        }
224 225 226 227 228 229

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

230
        // First, let's check that this is a real Java class, not a Java's view on a Kotlin class:
231 232
        ClassDescriptor kotlinClassDescriptor = semanticServices.getKotlinClassDescriptor(qualifiedName);
        if (kotlinClassDescriptor != null) {
233 234 235 236 237 238 239 240 241
            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);
            }
242 243
        }

244
        // Not let's take a descriptor of a Java class
245
        ResolverBinaryClassData classData = classDescriptorCache.get(qualifiedName);
246
        if (classData == null) {
S
Stepan Koltsov 已提交
247
            PsiClass psiClass = psiClassFinder.findPsiClass(qualifiedName);
248 249 250
            if (psiClass == null) {
                return null;
            }
251
            classData = createJavaClassDescriptor(psiClass);
252
        }
253
        return classData.getClassDescriptor();
254 255
    }

256
    private ResolverBinaryClassData createJavaClassDescriptor(@NotNull final PsiClass psiClass) {
S
Stepan Koltsov 已提交
257
        if (classDescriptorCache.containsKey(new FqName(psiClass.getQualifiedName()))) {
258 259
            throw new IllegalStateException(psiClass.getQualifiedName());
        }
A
Andrey Breslav 已提交
260

261 262
        checkPsiClassIsNotJet(psiClass);

263
        String name = psiClass.getName();
264
        ResolverBinaryClassData classData = new ResolverBinaryClassData();
S
Stepan Koltsov 已提交
265
        classDescriptorCache.put(new FqName(psiClass.getQualifiedName()), classData);
266
        ClassKind kind = psiClass.isInterface() ? (psiClass.isAnnotationType() ? ClassKind.ANNOTATION_CLASS : ClassKind.TRAIT) : ClassKind.CLASS;
S
Stepan Koltsov 已提交
267
        ClassOrNamespaceDescriptor containingDeclaration = resolveParentDescriptor(psiClass);
268
        classData.classDescriptor = new MutableClassDescriptorLite(containingDeclaration, kind);
269
        classData.classDescriptor.setName(name);
270 271
        classData.classDescriptor.setAnnotations(resolveAnnotations(psiClass));

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

S
Stepan Koltsov 已提交
274 275 276
        TypeVariableResolver outerTypeVariableByNameResolver = TypeVariableResolvers.classTypeVariableResolver(
                (ClassOrNamespaceDescriptor) classData.classDescriptor.getContainingDeclaration(),
                "class " + psiClass.getQualifiedName());
277 278

        classData.typeParameters = createUninitializedClassTypeParameters(psiClass, classData, outerTypeVariableByNameResolver);
279 280 281 282 283 284
        
        List<TypeParameterDescriptor> typeParameters = new ArrayList<TypeParameterDescriptor>();
        for (TypeParameterDescriptorInitialization typeParameter : classData.typeParameters) {
            typeParameters.add(typeParameter.descriptor);
        }
        
285 286 287
        classData.classDescriptor.setTypeParameterDescriptors(typeParameters);
        classData.classDescriptor.setSupertypes(supertypes);
        classData.classDescriptor.setVisibility(resolveVisibilityFromPsiModifiers(psiClass));
288 289 290 291 292 293 294 295 296 297
        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);
298
        classData.classDescriptor.createTypeConstructor();
299
        classData.classDescriptor.setScopeForMemberLookup(new JavaClassMembersScope(classData.classDescriptor, psiClass, semanticServices, false));
300

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

S
Stepan Koltsov 已提交
303 304 305
        TypeVariableResolver resolverForTypeParameters = TypeVariableResolvers.classTypeVariableResolver(
                classData.classDescriptor,
                "class " + psiClass.getQualifiedName());
306

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

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

312
        boolean isStatic = psiClass.hasModifierProperty(PsiModifier.STATIC);
313
        if (psiConstructors.length == 0) {
A
Andrey Breslav 已提交
314 315 316 317
            // We need to create default constructors for classes and abstract classes.
            // Example:
            // class Kotlin() : Java() {}
            // abstract public class Java {}
318
            if (!psiClass.isInterface()) {
319
                ConstructorDescriptorImpl constructorDescriptor = new ConstructorDescriptorImpl(
320
                        classData.classDescriptor,
A
Andrey Breslav 已提交
321
                        Collections.<AnnotationDescriptor>emptyList(),
322
                        false);
323
                constructorDescriptor.initialize(typeParameters, Collections.<ValueParameterDescriptor>emptyList(), classData.classDescriptor.getVisibility(), isStatic);
324
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
325
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
326
                trace.record(BindingContext.CONSTRUCTOR, psiClass, constructorDescriptor);
327
            }
328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348
            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)) {
349
                            varargElementType = semanticServices.getTypeTransformer().transformToType(((PsiArrayType) returnType).getComponentType(), resolverForTypeParameters);
350 351 352 353 354 355 356 357
                        }

                        valueParameters.add(new ValueParameterDescriptorImpl(
                                constructorDescriptor,
                                i,
                                Collections.<AnnotationDescriptor>emptyList(),
                                method.getName(),
                                false,
358
                                semanticServices.getTypeTransformer().transformToType(returnType, resolverForTypeParameters),
359 360 361 362 363
                                annotationMethod.getDefaultValue() != null,
                                varargElementType));
                    }
                }

364
                constructorDescriptor.initialize(typeParameters, valueParameters, classData.classDescriptor.getVisibility(), isStatic);
365 366
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
367
                trace.record(BindingContext.CONSTRUCTOR, psiClass, constructorDescriptor);
368
            }
369 370
        }
        else {
371 372 373 374 375
            for (PsiMethod psiConstructor : psiConstructors) {
                PsiMethodWrapper constructor = new PsiMethodWrapper(psiConstructor);

                if (constructor.getJetConstructor().hidden()) {
                    continue;
376 377
                }

378
                ConstructorDescriptorImpl constructorDescriptor = new ConstructorDescriptorImpl(
379
                        classData.classDescriptor,
A
Andrey Breslav 已提交
380
                        Collections.<AnnotationDescriptor>emptyList(), // TODO
381
                        false);
S
Stepan Koltsov 已提交
382
                String context = "constructor of class " + psiClass.getQualifiedName();
383
                ValueParameterDescriptors valueParameterDescriptors = resolveParameterDescriptors(constructorDescriptor,
384
                        constructor.getParameters(),
S
Stepan Koltsov 已提交
385
                        TypeVariableResolvers.classTypeVariableResolver(classData.classDescriptor, context));
386 387 388
                if (valueParameterDescriptors.receiverType != null) {
                    throw new IllegalStateException();
                }
389
                constructorDescriptor.initialize(typeParameters, valueParameterDescriptors.descriptors,
390
                        resolveVisibilityFromPsiModifiers(psiConstructor), isStatic);
391
                constructorDescriptor.setReturnType(classData.classDescriptor.getDefaultType());
392
                classData.classDescriptor.addConstructor(constructorDescriptor, null);
393
                trace.record(BindingContext.CONSTRUCTOR, psiConstructor, constructorDescriptor);
394
            }
A
Andrey Breslav 已提交
395
        }
396

397 398 399 400
        MutableClassDescriptorLite classObject = createClassObjectDescriptor(classData.classDescriptor, psiClass);
        if (classObject != null) {
            classData.classDescriptor.setClassObjectDescriptor(classObject);
        }
401

402
        trace.record(BindingContext.CLASS, psiClass, classData.classDescriptor);
403

404
        return classData;
405 406
    }

407
    static void checkPsiClassIsNotJet(PsiClass psiClass) {
408
        if (psiClass instanceof JetJavaMirrorMarker) {
409
            throw new IllegalStateException("trying to resolve fake jet PsiClass as regular PsiClass: " + psiClass.getQualifiedName());
410 411 412
        }
    }

413 414 415 416 417 418 419 420 421 422
    @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;
    }

423 424 425 426 427 428
    /**
     * TODO
     * @see #createJavaNamespaceDescriptor(com.intellij.psi.PsiClass)
     */
    @Nullable
    private MutableClassDescriptorLite createClassObjectDescriptor(@NotNull ClassDescriptor containing, @NotNull PsiClass psiClass) {
429 430 431 432 433
        PsiClass classObjectPsiClass = getInnerClassClassObject(psiClass);
        if (classObjectPsiClass == null) {
            return null;
        }

434 435
        checkPsiClassIsNotJet(psiClass);

436 437 438 439
        ResolverBinaryClassData classData = new ResolverBinaryClassData();
        classData.kotlin = true;
        classData.classDescriptor = new MutableClassDescriptorLite(containing, ClassKind.OBJECT);

S
Stepan Koltsov 已提交
440
        classDescriptorCache.put(new FqName(classObjectPsiClass.getQualifiedName()), classData);
441 442 443 444

        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);
445
        classData.classDescriptor.setVisibility(containing.getVisibility());
446 447
        classData.classDescriptor.setTypeParameterDescriptors(new ArrayList<TypeParameterDescriptor>(0));
        classData.classDescriptor.createTypeConstructor();
448
        classData.classDescriptor.setScopeForMemberLookup(new JavaClassMembersScope(classData.classDescriptor, classObjectPsiClass, semanticServices, false));
449 450 451 452

        // 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());
453
        constructor.initialize(new ArrayList<TypeParameterDescriptor>(0), new ArrayList<ValueParameterDescriptor>(0), Visibilities.PUBLIC);
454 455 456

        classData.classDescriptor.addConstructor(constructor, null);
        return classData.classDescriptor;
457 458
    }

459
    private List<TypeParameterDescriptorInitialization> createUninitializedClassTypeParameters(PsiClass psiClass, ResolverBinaryClassData classData, TypeVariableResolver typeVariableResolver) {
460 461 462 463 464
        JetClassAnnotation jetClassAnnotation = JetClassAnnotation.get(psiClass);
        classData.kotlin = jetClassAnnotation.isDefined();
        
        if (jetClassAnnotation.signature().length() > 0) {
            return resolveClassTypeParametersFromJetSignature(
S
Stepan Koltsov 已提交
465
                    jetClassAnnotation.signature(), psiClass, classData.classDescriptor);
466
        }
467

468
        return makeUninitializedTypeParameters(classData.classDescriptor, psiClass.getTypeParameters());
469 470
    }

471
    @NotNull
472
    private PsiTypeParameter getPsiTypeParameterByName(PsiTypeParameterListOwner clazz, String name) {
473 474 475 476 477
        for (PsiTypeParameter typeParameter : clazz.getTypeParameters()) {
            if (typeParameter.getName().equals(name)) {
                return typeParameter; 
            }
        }
478 479 480
        throw new IllegalStateException("PsiTypeParameter '" + name + "' is not found");
    }

S
Stepan Koltsov 已提交
481

482
    private static final FqName JL_OBJECT = new FqName("java.lang.Object");
S
Stepan Koltsov 已提交
483 484

    private boolean isJavaLangObject(JetType type) {
485 486 487
        ClassifierDescriptor classifierDescriptor = type.getConstructor().getDeclarationDescriptor();
        return classifierDescriptor instanceof ClassDescriptor &&
               DescriptorUtils.getFQName(classifierDescriptor).equals(JL_OBJECT.toUnsafe());
S
Stepan Koltsov 已提交
488 489 490
    }


491
    private abstract class JetSignatureTypeParameterVisitor extends JetSignatureExceptionsAdapter {
492 493

        @NotNull
494
        private final PsiTypeParameterListOwner psiOwner;
495
        @NotNull
496
        private final String name;
497
        @NotNull
498
        private final TypeVariableResolver typeVariableResolver;
499 500
        @NotNull
        private final TypeParameterDescriptor typeParameterDescriptor;
501

502 503
        protected JetSignatureTypeParameterVisitor(PsiTypeParameterListOwner psiOwner,
                String name, TypeVariableResolver typeVariableResolver, TypeParameterDescriptor typeParameterDescriptor)
504
        {
505 506 507
            if (name.isEmpty()) {
                throw new IllegalStateException();
            }
508

509 510
            this.psiOwner = psiOwner;
            this.name = name;
511
            this.typeVariableResolver = typeVariableResolver;
512
            this.typeParameterDescriptor = typeParameterDescriptor;
513 514 515 516
        }

        List<JetType> upperBounds = new ArrayList<JetType>();
        List<JetType> lowerBounds = new ArrayList<JetType>();
S
Stepan Koltsov 已提交
517
        
518 519
        @Override
        public JetSignatureVisitor visitClassBound() {
520
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
521 522
                @Override
                protected void done(@NotNull JetType jetType) {
S
Stepan Koltsov 已提交
523 524 525
                    if (isJavaLangObject(jetType)) {
                        return;
                    }
526 527 528 529 530 531 532
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public JetSignatureVisitor visitInterfaceBound() {
533
            return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
534 535 536 537 538 539 540 541 542
                @Override
                protected void done(@NotNull JetType jetType) {
                    upperBounds.add(jetType);
                }
            };
        }

        @Override
        public void visitFormalTypeParameterEnd() {
543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561
            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 已提交
562
        private JetSignatureTypeParametersVisitor(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameterListOwner psiOwner, @NotNull String context) {
563 564 565
            this.containingDeclaration = containingDeclaration;
            this.psiOwner = psiOwner;

S
Stepan Koltsov 已提交
566 567 568 569
            this.typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(
                    previousTypeParameters,
                    containingDeclaration,
                    context);
570 571 572 573 574 575 576 577 578
        }

        private int formalTypeParameterIndex = 0;


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

        @Override
        public JetSignatureVisitor visitFormalTypeParameter(final String name, final TypeInfoVariance variance, boolean reified) {
579 580 581
            TypeParameterDescriptor typeParameter = TypeParameterDescriptor.createForFurtherModification(
                    containingDeclaration,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO: wrong
582
                    reified,
583 584
                    JetSignatureUtils.translateVariance(variance),
                    name,
585 586 587 588 589 590 591 592 593 594 595
                    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);
                }
            };
596
        }
597 598
    }

599
    /**
S
Stepan Koltsov 已提交
600
     * @see #resolveMethodTypeParametersFromJetSignature(String, com.intellij.psi.PsiMethod, org.jetbrains.jet.lang.descriptors.DeclarationDescriptor)
601
     */
S
Stepan Koltsov 已提交
602 603 604 605
    private List<TypeParameterDescriptorInitialization> resolveClassTypeParametersFromJetSignature(String jetSignature,
            final PsiClass clazz, final ClassDescriptor classDescriptor) {
        String context = "class " + clazz.getQualifiedName();
        JetSignatureTypeParametersVisitor jetSignatureTypeParametersVisitor = new JetSignatureTypeParametersVisitor(classDescriptor, clazz, context) {
606 607 608 609 610 611 612 613 614 615 616
            @Override
            public JetSignatureVisitor visitSuperclass() {
                // TODO
                return new JetSignatureAdapter();
            }

            @Override
            public JetSignatureVisitor visitInterface() {
                // TODO
                return new JetSignatureAdapter();
            }
617 618 619
        };
        new JetSignatureReader(jetSignature).accept(jetSignatureTypeParametersVisitor);
        return jetSignatureTypeParametersVisitor.r;
620 621
    }

S
Stepan Koltsov 已提交
622
    private ClassOrNamespaceDescriptor resolveParentDescriptor(PsiClass psiClass) {
623 624
        PsiClass containingClass = psiClass.getContainingClass();
        if (containingClass != null) {
625
            return resolveClass(new FqName(containingClass.getQualifiedName()), DescriptorSearchRule.INCLUDE_KOTLIN);
626
        }
627

628
        return resolveNamespace(new FqName(psiClass.getQualifiedName()).parent(), DescriptorSearchRule.INCLUDE_KOTLIN);
629 630
    }

631 632
    private List<TypeParameterDescriptorInitialization> makeUninitializedTypeParameters(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter[] typeParameters) {
        List<TypeParameterDescriptorInitialization> result = Lists.newArrayList();
633
        for (PsiTypeParameter typeParameter : typeParameters) {
634
            TypeParameterDescriptorInitialization typeParameterDescriptor = makeUninitializedTypeParameter(containingDeclaration, typeParameter);
A
Andrey Breslav 已提交
635
            result.add(typeParameterDescriptor);
636 637 638 639
        }
        return result;
    }

640
    @NotNull
641
    private TypeParameterDescriptorInitialization makeUninitializedTypeParameter(@NotNull DeclarationDescriptor containingDeclaration, @NotNull PsiTypeParameter psiTypeParameter) {
642
        TypeParameterDescriptor typeParameterDescriptor = TypeParameterDescriptor.createForFurtherModification(
643
                containingDeclaration,
A
Andrey Breslav 已提交
644
                Collections.<AnnotationDescriptor>emptyList(), // TODO
A
Andrey Breslav 已提交
645
                false,
646
                Variance.INVARIANT,
647 648
                psiTypeParameter.getName(),
                psiTypeParameter.getIndex()
649
        );
650
        return new TypeParameterDescriptorInitialization(typeParameterDescriptor, psiTypeParameter);
651 652
    }

653
    private void initializeTypeParameter(TypeParameterDescriptorInitialization typeParameter, TypeVariableResolver typeVariableByPsiResolver) {
654 655 656
        TypeParameterDescriptor typeParameterDescriptor = typeParameter.descriptor;
        if (typeParameter.origin == TypeParameterDescriptorOrigin.KOTLIN) {
            List<?> upperBounds = typeParameter.upperBoundsForKotlin;
657 658 659
            if (upperBounds.size() == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            } else {
660
                for (JetType upperBound : typeParameter.upperBoundsForKotlin) {
661 662 663 664 665
                    typeParameterDescriptor.addUpperBound(upperBound);
                }
            }

            // TODO: lower bounds
666
        } else {
667
            PsiClassType[] referencedTypes = typeParameter.psiTypeParameter.getExtendsList().getReferencedTypes();
668 669 670 671
            if (referencedTypes.length == 0){
                typeParameterDescriptor.addUpperBound(JetStandardClasses.getNullableAnyType());
            }
            else if (referencedTypes.length == 1) {
A
Andrey Breslav 已提交
672
                typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedTypes[0], JavaTypeTransformer.TypeUsage.UPPER_BOUND, typeVariableByPsiResolver));
673 674 675
            }
            else {
                for (PsiClassType referencedType : referencedTypes) {
A
Andrey Breslav 已提交
676
                    typeParameterDescriptor.addUpperBound(semanticServices.getTypeTransformer().transformToType(referencedType, JavaTypeTransformer.TypeUsage.UPPER_BOUND, typeVariableByPsiResolver));
677
                }
A
Andrey Breslav 已提交
678 679
            }
        }
680
        typeParameterDescriptor.setInitialized();
681 682
    }

S
Stepan Koltsov 已提交
683
    private void initializeTypeParameters(List<TypeParameterDescriptorInitialization> typeParametersInitialization, @NotNull DeclarationDescriptor typeParametersOwner, @NotNull String context) {
684
        List<TypeParameterDescriptor> prevTypeParameters = new ArrayList<TypeParameterDescriptor>();
685
        for (TypeParameterDescriptorInitialization psiTypeParameter : typeParametersInitialization) {
686
            prevTypeParameters.add(psiTypeParameter.descriptor);
S
Stepan Koltsov 已提交
687 688
            initializeTypeParameter(psiTypeParameter,
                    TypeVariableResolvers.typeVariableResolverFromTypeParameters(prevTypeParameters, typeParametersOwner, context));
S
Stepan Koltsov 已提交
689
        }
A
Andrey Breslav 已提交
690 691
    }

692
    private Collection<JetType> getSupertypes(PsiClassWrapper psiClass, ClassDescriptor classDescriptor, List<TypeParameterDescriptor> typeParameters) {
693 694
        final List<JetType> result = new ArrayList<JetType>();

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

697
        if (psiClass.getJetClass().signature().length() > 0) {
S
Stepan Koltsov 已提交
698
            final TypeVariableResolver typeVariableResolver = TypeVariableResolvers.typeVariableResolverFromTypeParameters(typeParameters, classDescriptor, context);
699 700 701 702 703 704 705 706 707 708
            
            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() {
709
                    return new JetTypeJetSignatureReader(semanticServices, JetStandardLibrary.getInstance(), typeVariableResolver) {
710 711 712 713 714 715 716 717 718 719 720
                        @Override
                        protected void done(@NotNull JetType jetType) {
                            if (!jetType.equals(JetStandardClasses.getAnyType())) {
                                result.add(jetType);
                            }
                        }
                    };
                }

                @Override
                public JetSignatureVisitor visitInterface() {
S
Stepan Koltsov 已提交
721
                    return visitSuperclass();
722 723 724
                }
            });
        } else {
S
Stepan Koltsov 已提交
725 726 727
            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);
728
        }
729 730 731
        
        for (JetType supertype : result) {
            if (ErrorUtils.isErrorType(supertype)) {
732
                trace.record(BindingContext.INCOMPLETE_HIERARCHY, classDescriptor);
733 734 735
            }
        }
        
736 737 738
        if (result.isEmpty()) {
            result.add(JetStandardClasses.getAnyType());
        }
739 740 741
        return result;
    }

742
    private void transformSupertypeList(List<JetType> result, PsiClassType[] extendsListTypes, TypeVariableResolver typeVariableResolver, boolean annotation) {
743
        for (PsiClassType type : extendsListTypes) {
744
            PsiClass resolved = type.resolve();
S
Stepan Koltsov 已提交
745
            if (resolved != null && resolved.getQualifiedName().equals(JvmStdlibNames.JET_OBJECT.getFqName().getFqName())) {
746 747
                continue;
            }
748 749 750
            if (annotation && resolved.getQualifiedName().equals("java.lang.annotation.Annotation")) {
                continue;
            }
751
            
752
            JetType transform = semanticServices.getTypeTransformer().transformToType(type, typeVariableResolver);
753 754 755 756 757

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

758
    @Nullable
759
    public NamespaceDescriptor resolveNamespace(@NotNull FqName qualifiedName, @NotNull DescriptorSearchRule searchRule) {
760 761 762
        // First, let's check that there is no Kotlin package:
        NamespaceDescriptor kotlinNamespaceDescriptor = semanticServices.getKotlinNamespaceDescriptor(qualifiedName);
        if (kotlinNamespaceDescriptor != null) {
763 764 765 766 767 768 769 770 771 772
            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);
            }
773 774
        }

S
Stepan Koltsov 已提交
775
        PsiPackage psiPackage = psiClassFinder.findPsiPackage(qualifiedName);
776
        if (psiPackage == null) {
S
Stepan Koltsov 已提交
777
            PsiClass psiClass = psiClassFinder.findPsiClass(qualifiedName);
778 779
            if (psiClass == null) return null;
            return resolveNamespace(psiClass);
780
        }
781
        return resolveNamespace(psiPackage);
782 783
    }

784
    private NamespaceDescriptor resolveNamespace(@NotNull PsiPackage psiPackage) {
785 786
        FqName fqName = new FqName(psiPackage.getQualifiedName());
        ResolverNamespaceData namespaceData = namespaceDescriptorCacheByFqn.get(fqName);
787
        if (namespaceData == null) {
S
Stepan Koltsov 已提交
788
            return createJavaNamespaceDescriptor(psiPackage);
789
        }
790
        return namespaceData.namespaceDescriptor;
A
Andrey Breslav 已提交
791 792
    }

793
    private NamespaceDescriptor resolveNamespace(@NotNull PsiClass psiClass) {
794 795
        FqName fqName = new FqName(psiClass.getQualifiedName());
        ResolverNamespaceData namespaceData = namespaceDescriptorCacheByFqn.get(fqName);
796 797
        if (namespaceData == null) {
            namespaceData = createJavaNamespaceDescriptor(psiClass);
798
            namespaceDescriptorCacheByFqn.put(fqName, namespaceData);
S
Stepan Koltsov 已提交
799
        }
800 801
        return namespaceData.namespaceDescriptor;
    }
S
Stepan Koltsov 已提交
802

S
Stepan Koltsov 已提交
803 804
    private JavaNamespaceDescriptor createJavaNamespaceDescriptor(@NotNull PsiPackage psiPackage) {
        FqName fqName = new FqName(psiPackage.getQualifiedName());
805
        String name = psiPackage.getName();
S
Stepan Koltsov 已提交
806
        JavaNamespaceDescriptor namespaceDescriptor = new JavaNamespaceDescriptor(
807 808 809
                (NamespaceDescriptorParent) resolveParentDescriptor(psiPackage),
                Collections.<AnnotationDescriptor>emptyList(), // TODO
                name == null ? JAVA_ROOT : name,
S
Stepan Koltsov 已提交
810
                fqName,
811 812
                true
        );
S
Stepan Koltsov 已提交
813
        trace.record(BindingContext.NAMESPACE, psiPackage, namespaceDescriptor);
S
Stepan Koltsov 已提交
814

S
Stepan Koltsov 已提交
815 816 817
        ResolverNamespaceData scopeData = createNamespaceResolverScopeData(fqName, namespaceDescriptor);
        namespaceDescriptor.setMemberScope(scopeData.memberScope);
        return namespaceDescriptor;
818 819
    }

S
Stepan Koltsov 已提交
820
    @Nullable
S
Stepan Koltsov 已提交
821
    private ResolverNamespaceData createNamespaceResolverScopeData(@NotNull FqName fqName, @NotNull NamespaceDescriptor ns) {
S
Stepan Koltsov 已提交
822 823 824 825 826
        PsiPackage psiPackage = semanticServices.getPsiClassFinder().findPsiPackage(fqName);
        PsiClass psiClass = getPsiClassForJavaPackageScope(fqName);
        if (psiClass == null && psiPackage == null) {
            return null;
        }
S
Stepan Koltsov 已提交
827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 849 850 851 852 853 854 855 856 857 858 859 860 861 862

        if (psiPackage != null) {
            trace.record(JavaBindingContext.NAMESPACE_IS_CLASS_STATICS, ns, false);
        }

        JavaPackageScope scope = new JavaPackageScope(fqName, ns, semanticServices, psiPackage, psiClass);

        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
        namespaceData.namespaceDescriptor = ns;
        // TODO: hack
        namespaceData.kotlin = true;

        namespaceData.memberScope = scope;

        ResolverNamespaceData oldValue = namespaceDescriptorCacheByFqn.put(fqName, namespaceData);
        if (oldValue != null) {
            throw new IllegalStateException("rewrite at "  + fqName);
        }

        return namespaceData;
    }

    @Nullable
    public JavaPackageScope getJavaPackageScope(@NotNull FqName fqName, @NotNull NamespaceDescriptor ns) {
        ResolverNamespaceData resolverNamespaceData = namespaceDescriptorCacheByFqn.get(fqName);
        if (resolverNamespaceData == null) {
            resolverNamespaceData = createNamespaceResolverScopeData(fqName, ns);
        }
        if (resolverNamespaceData == null) {
            return null;
        }
        JavaPackageScope scope = resolverNamespaceData.memberScope;
        if (scope == null) {
            throw new IllegalStateException("fqn: " + fqName);
        }
        return scope;
S
Stepan Koltsov 已提交
863 864 865 866 867 868 869 870 871 872 873 874 875
    }

    private PsiClass getPsiClassForJavaPackageScope(@NotNull FqName packageFQN) {
        // TODO: move this check outside
        // If this package is actually a Kotlin namespace, then we access it through a namespace descriptor, and
        // Kotlin functions are already there
        NamespaceDescriptor kotlinNamespaceDescriptor = semanticServices.getKotlinNamespaceDescriptor(packageFQN);
        if (kotlinNamespaceDescriptor != null) {
            return null;
        } else {
            // TODO: what is GlobalSearchScope
            return semanticServices.getPsiClassFinder().findPsiClass(JavaPackageScope.getQualifiedName(packageFQN, JvmAbi.PACKAGE_CLASS));
        }
876
    }
877

878 879 880 881 882
    @NotNull
    private DeclarationDescriptor resolveParentDescriptor(@NotNull PsiPackage psiPackage) {
        PsiPackage parentPackage = psiPackage.getParentPackage();
        if (parentPackage == null) {
            return FAKE_ROOT_MODULE;
S
Stepan Koltsov 已提交
883
        }
884 885
        return resolveNamespace(parentPackage);
    }
886

887 888 889 890 891
    /**
     * TODO
     * @see #createClassObjectDescriptor(org.jetbrains.jet.lang.descriptors.ClassDescriptor, com.intellij.psi.PsiClass)
     */
    private ResolverNamespaceData createJavaNamespaceDescriptor(@NotNull final PsiClass psiClass) {
S
Stepan Koltsov 已提交
892

893
        checkPsiClassIsNotJet(psiClass);
S
Stepan Koltsov 已提交
894

895
        ResolverNamespaceData namespaceData = new ResolverNamespaceData();
S
Stepan Koltsov 已提交
896
        JavaNamespaceDescriptor ns = new JavaNamespaceDescriptor(
897 898 899 900 901 902
                (NamespaceDescriptorParent) resolveParentDescriptor(psiClass),
                Collections.<AnnotationDescriptor>emptyList(), // TODO
                psiClass.getName(),
                new FqName(psiClass.getQualifiedName()),
                false
        );
S
Stepan Koltsov 已提交
903
        namespaceData.namespaceDescriptor = ns;
904
        trace.record(JavaBindingContext.NAMESPACE_IS_CLASS_STATICS, namespaceData.namespaceDescriptor, true);
905

S
Stepan Koltsov 已提交
906
        ns.setMemberScope(new JavaClassMembersScope(namespaceData.namespaceDescriptor, psiClass, semanticServices, true));
907 908
        trace.record(BindingContext.NAMESPACE, psiClass, namespaceData.namespaceDescriptor);
        return namespaceData;
909
    }
910
    
911 912 913 914 915 916 917 918 919
    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;
        }
    }
920

921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953
    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
954
    private JvmMethodParameterMeaning resolveParameterDescriptor(DeclarationDescriptor containingDeclaration, int i,
955 956 957 958 959 960 961
            PsiParameterWrapper parameter, TypeVariableResolver typeVariableResolver) {

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

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

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

966 967
        if (parameter.getJetValueParameter().name().length() > 0) {
            name = parameter.getJetValueParameter().name();
968 969
        }
        
970 971 972 973
        String typeFromAnnotation = parameter.getJetValueParameter().type();
        boolean receiver = parameter.getJetValueParameter().receiver();
        boolean hasDefaultValue = parameter.getJetValueParameter().hasDefaultValue();

S
Stepan Koltsov 已提交
974
        JetType outType;
975
        if (typeFromAnnotation.length() > 0) {
976
            outType = semanticServices.getTypeTransformer().transformToType(typeFromAnnotation, typeVariableResolver);
S
Stepan Koltsov 已提交
977
        } else {
978
            outType = semanticServices.getTypeTransformer().transformToType(psiType, typeVariableResolver);
S
Stepan Koltsov 已提交
979
        }
980 981 982

        JetType varargElementType;
        if (psiType instanceof PsiEllipsisType) {
983
            varargElementType = JetStandardLibrary.getInstance().getArrayElementType(outType);
984 985 986 987
        } else {
            varargElementType = null;
        }

988 989 990
        if (receiver) {
            return JvmMethodParameterMeaning.receiver(outType);
        } else {
S
Stepan Koltsov 已提交
991 992 993 994

            JetType transformedType;
            if (parameter.getJetValueParameter().nullable()) {
                transformedType = TypeUtils.makeNullableAsSpecified(outType, parameter.getJetValueParameter().nullable());
S
Stepan Koltsov 已提交
995
            } else if (parameter.getPsiParameter().getModifierList().findAnnotation(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName().getFqName()) != null) {
S
Stepan Koltsov 已提交
996 997 998 999
                transformedType = TypeUtils.makeNullableAsSpecified(outType, false);
            } else {
                transformedType = outType;
            }
1000 1001 1002 1003 1004
            return JvmMethodParameterMeaning.regular(new ValueParameterDescriptorImpl(
                    containingDeclaration,
                    i,
                    Collections.<AnnotationDescriptor>emptyList(), // TODO
                    name,
S
Stepan Koltsov 已提交
1005
                    false,
S
Stepan Koltsov 已提交
1006
                    transformedType,
1007
                    hasDefaultValue,
1008 1009 1010
                    varargElementType
            ));
        }
1011 1012
    }

1013 1014
    public Set<VariableDescriptor> resolveFieldGroupByName(@NotNull ClassOrNamespaceDescriptor owner, @NotNull PsiClass psiClass, String fieldName, boolean staticMembers) {
        ResolverScopeData scopeData = getResolverScopeData(owner, new PsiClassWrapper(psiClass));
1015

1016 1017 1018
        NamedMembers namedMembers = scopeData.namedMembersMap.get(fieldName);
        if (namedMembers == null) {
            return Collections.emptySet();
1019
        }
1020
        Set<VariableDescriptor> r = new HashSet<VariableDescriptor>();
1021

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

1024 1025 1026 1027 1028 1029 1030
        r.addAll(namedMembers.propertyDescriptors);

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

        return r;
1031 1032 1033
    }
    
    @NotNull
1034
    public Set<VariableDescriptor> resolveFieldGroup(@NotNull ClassOrNamespaceDescriptor owner, @NotNull PsiClass psiClass, boolean staticMembers) {
1035

1036 1037
        ResolverScopeData scopeData = getResolverScopeData(owner, new PsiClassWrapper(psiClass));
        
1038
        Set<VariableDescriptor> descriptors = Sets.newHashSet();
1039 1040 1041 1042
        Map<String, NamedMembers> membersForProperties = scopeData.namedMembersMap;
        for (Map.Entry<String, NamedMembers> entry : membersForProperties.entrySet()) {
            NamedMembers namedMembers = entry.getValue();
            String propertyName = entry.getKey();
1043

S
Stepan Koltsov 已提交
1044
            resolveNamedGroupProperties(owner, scopeData, staticMembers, namedMembers, propertyName, "class or namespace " + psiClass.getQualifiedName());
1045
            descriptors.addAll(namedMembers.propertyDescriptors);
1046
        }
1047

1048
        return descriptors;
1049
    }
1050 1051 1052 1053 1054 1055 1056
    
    private Object key(TypeSource typeSource) {
        if (typeSource == null) {
            return "";
        } else if (typeSource.getTypeString().length() > 0) {
            return typeSource.getTypeString();
        } else {
1057
            return psiTypeToKey(typeSource.getPsiType());
1058 1059
        }
    }
1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072

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

1073 1074 1075 1076 1077
    private Object propertyKeyForGrouping(PropertyAccessorData propertyAccessor) {
        Object type = key(propertyAccessor.getType());
        Object receiverType = key(propertyAccessor.getReceiverType());
        return Pair.create(type, receiverType);
    }
1078

1079 1080 1081
    private void resolveNamedGroupProperties(
            @NotNull ClassOrNamespaceDescriptor owner,
            @NotNull ResolverScopeData scopeData,
S
Stepan Koltsov 已提交
1082 1083 1084
            boolean staticMembers, @NotNull NamedMembers namedMembers, @NotNull String propertyName,
            @NotNull String context
            ) {
1085 1086 1087 1088
        if (namedMembers.propertyDescriptors != null) {
            return;
        }
        
1089
        if (namedMembers.propertyAccessors == null) {
S
Stepan Koltsov 已提交
1090
            namedMembers.propertyAccessors = Collections.emptyList();
1091
        }
1092

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

1095 1096 1097 1098
        class GroupingValue {
            PropertyAccessorData getter;
            PropertyAccessorData setter;
            PropertyAccessorData field;
1099
            boolean ext;
1100
        }
1101 1102
        
        Map<Object, GroupingValue> map = new HashMap<Object, GroupingValue>();
1103

1104
        for (PropertyAccessorData propertyAccessor : namedMembers.propertyAccessors) {
1105

1106 1107 1108 1109 1110
            Object key = propertyKeyForGrouping(propertyAccessor);
            
            GroupingValue value = map.get(key);
            if (value == null) {
                value = new GroupingValue();
1111
                value.ext = propertyAccessor.getReceiverType() != null;
1112 1113
                map.put(key, value);
            }
1114

1115 1116 1117 1118
            if (value.ext != (propertyAccessor.getReceiverType() != null)) {
                throw new IllegalStateException("internal error, incorrect key");
            }

1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136
            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();
            }
1137
        }
1138

1139
        
S
Stepan Koltsov 已提交
1140
        Set<PropertyDescriptor> propertiesFromCurrent = new HashSet<PropertyDescriptor>(1);
1141

1142 1143 1144 1145 1146 1147 1148 1149 1150 1151 1152 1153 1154 1155
        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;
            }
1156

1157
            boolean isFinal;
1158 1159 1160
            if (!scopeData.kotlin) {
                isFinal = true;
            } else if (members.setter == null && members.getter == null) {
1161 1162 1163 1164 1165 1166 1167 1168
                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;
            }
1169

1170 1171 1172 1173 1174 1175 1176 1177 1178 1179
            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();
            }
1180

1181 1182 1183 1184 1185 1186
            boolean isVar;
            if (members.getter == null && members.setter == null) {
                isVar = !members.field.getMember().isFinal();
            } else {
                isVar = members.setter != null;
            }
1187 1188 1189 1190 1191 1192 1193 1194 1195 1196

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


1197 1198
            PropertyDescriptor propertyDescriptor = new PropertyDescriptor(
                    owner,
A
Alex Tkachman 已提交
1199
                    resolveAnnotations(anyMember.getMember().psiMember),
1200
                    modality,
1201
                    resolveVisibilityFromPsiModifiers(anyMember.getMember().psiMember),
1202 1203
                    isVar,
                    false,
1204 1205
                    propertyName,
                    CallableMemberDescriptor.Kind.DECLARATION);
1206

1207 1208 1209
            PropertyGetterDescriptor getterDescriptor = null;
            PropertySetterDescriptor setterDescriptor = null;
            if (members.getter != null) {
1210
                getterDescriptor = new PropertyGetterDescriptor(propertyDescriptor, resolveAnnotations(members.getter.getMember().psiMember), Modality.OPEN, Visibilities.PUBLIC, true, false, CallableMemberDescriptor.Kind.DECLARATION);
1211 1212
            }
            if (members.setter != null) {
1213
                setterDescriptor = new PropertySetterDescriptor(propertyDescriptor, resolveAnnotations(members.setter.getMember().psiMember), Modality.OPEN, Visibilities.PUBLIC, true, false, CallableMemberDescriptor.Kind.DECLARATION);
1214
            }
1215

1216
            propertyDescriptor.initialize(getterDescriptor, setterDescriptor);
1217

S
Stepan Koltsov 已提交
1218
            List<TypeParameterDescriptor> typeParameters = new ArrayList<TypeParameterDescriptor>(0);
1219 1220 1221

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

1223
                if (anyMember == members.setter) {
S
Stepan Koltsov 已提交
1224
                    typeParameters = resolveMethodTypeParameters(method, propertyDescriptor, typeVariableResolver);
1225 1226 1227 1228 1229 1230
                }
            }
            if (members.getter != null) {
                PsiMethodWrapper method = (PsiMethodWrapper) members.getter.getMember();

                if (anyMember == members.getter) {
S
Stepan Koltsov 已提交
1231
                    typeParameters = resolveMethodTypeParameters(method, propertyDescriptor, typeVariableResolver);
1232 1233 1234
                }
            }

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

1237 1238 1239 1240
            JetType propertyType;
            if (anyMember.getType().getTypeString().length() > 0) {
                propertyType = semanticServices.getTypeTransformer().transformToType(anyMember.getType().getTypeString(), typeVariableResolverForPropertyInternals);
            } else {
1241
                propertyType = semanticServices.getTypeTransformer().transformToType(anyMember.getType().getPsiType(), typeVariableResolverForPropertyInternals);
S
Stepan Koltsov 已提交
1242
                if (anyMember.getType().getPsiNotNullOwner().getModifierList().findAnnotation(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName().getFqName()) != null) {
S
Stepan Koltsov 已提交
1243 1244
                    propertyType = TypeUtils.makeNullableAsSpecified(propertyType, false);
                }
1245 1246 1247 1248 1249 1250 1251 1252
            }
            
            JetType receiverType;
            if (anyMember.getReceiverType() == null) {
                receiverType = null;
            } else if (anyMember.getReceiverType().getTypeString().length() > 0) {
                receiverType = semanticServices.getTypeTransformer().transformToType(anyMember.getReceiverType().getTypeString(), typeVariableResolverForPropertyInternals);
            } else {
1253
                receiverType = semanticServices.getTypeTransformer().transformToType(anyMember.getReceiverType().getPsiType(), typeVariableResolverForPropertyInternals);
1254 1255 1256 1257 1258 1259 1260
            }

            propertyDescriptor.setType(
                    propertyType,
                    typeParameters,
                    DescriptorUtils.getExpectedThisObjectIfNeeded(owner),
                    receiverType
1261
            );
1262 1263 1264 1265
            if (getterDescriptor != null) {
                getterDescriptor.initialize(propertyType);
            }
            if (setterDescriptor != null) {
1266
                setterDescriptor.initialize(new ValueParameterDescriptorImpl(setterDescriptor, 0, Collections.<AnnotationDescriptor>emptyList(), "p0"/*TODO*/, false, propertyDescriptor.getType(), false, null));
1267 1268
            }

1269
            trace.record(BindingContext.VARIABLE, anyMember.getMember().psiMember, propertyDescriptor);
1270
            
S
Stepan Koltsov 已提交
1271
            propertiesFromCurrent.add(propertyDescriptor);
1272
        }
1273

S
Stepan Koltsov 已提交
1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 1295 1296 1297

        Set<PropertyDescriptor> propertiesFromSupertypes = getPropertiesFromSupertypes(scopeData, propertyName);

        final Set<VariableDescriptor> properties = Sets.newHashSet();

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

            OverrideResolver.generateOverridesInFunctionGroup(propertyName, propertiesFromSupertypes, propertiesFromCurrent, classDescriptor, new OverrideResolver.DescriptorSink() {
                @Override
                public void addToScope(@NotNull CallableMemberDescriptor fakeOverride) {
                    properties.add((PropertyDescriptor) fakeOverride);
                }

                @Override
                public void conflict(@NotNull CallableMemberDescriptor fromSuper, @NotNull CallableMemberDescriptor fromCurrent) {
                    // nop
                }
            });
        }

        properties.addAll(propertiesFromCurrent);

        namedMembers.propertyDescriptors = properties;
1298
    }
1299

1300
    private void resolveNamedGroupFunctions(ClassOrNamespaceDescriptor owner, PsiClass psiClass, TypeSubstitutor typeSubstitutorForGenericSuperclasses, NamedMembers namedMembers, String methodName, ResolverScopeData scopeData) {
1301 1302 1303
        if (namedMembers.functionDescriptors != null) {
            return;
        }
1304 1305
        
        final Set<FunctionDescriptor> functions = new HashSet<FunctionDescriptor>();
1306

1307
        Set<SimpleFunctionDescriptor> functionsFromCurrent = Sets.newHashSet();
1308
        for (PsiMethodWrapper method : namedMembers.methods) {
1309 1310
            FunctionDescriptorImpl function = resolveMethodToFunctionDescriptor(owner, psiClass,
                    method);
1311
            if (function != null) {
1312
                functionsFromCurrent.add((SimpleFunctionDescriptor) function);
1313 1314 1315 1316 1317 1318
            }
        }

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

1319
            Set<SimpleFunctionDescriptor> functionsFromSupertypes = getFunctionsFromSupertypes(scopeData, methodName);
1320

S
Stepan Koltsov 已提交
1321
            OverrideResolver.generateOverridesInFunctionGroup(methodName, functionsFromSupertypes, functionsFromCurrent, classDescriptor, new OverrideResolver.DescriptorSink() {
1322
                @Override
S
Stepan Koltsov 已提交
1323 1324
                public void addToScope(@NotNull CallableMemberDescriptor fakeOverride) {
                    functions.add((FunctionDescriptor) fakeOverride);
1325
                }
1326 1327

                @Override
S
Stepan Koltsov 已提交
1328
                public void conflict(@NotNull CallableMemberDescriptor fromSuper, @NotNull CallableMemberDescriptor fromCurrent) {
1329 1330
                    // nop
                }
1331 1332 1333 1334 1335 1336 1337 1338 1339
            });

        }

        functions.addAll(functionsFromCurrent);

        namedMembers.functionDescriptors = functions;
    }
    
1340 1341
    private Set<SimpleFunctionDescriptor> getFunctionsFromSupertypes(ResolverScopeData scopeData, String methodName) {
        Set<SimpleFunctionDescriptor> r = new HashSet<SimpleFunctionDescriptor>();
1342 1343
        for (JetType supertype : getSupertypes(scopeData)) {
            for (FunctionDescriptor function : supertype.getMemberScope().getFunctions(methodName)) {
1344
                r.add((SimpleFunctionDescriptor) function);
1345
            }
1346
        }
1347
        return r;
1348 1349
    }

S
Stepan Koltsov 已提交
1350 1351 1352 1353 1354 1355 1356 1357 1358 1359
    private Set<PropertyDescriptor> getPropertiesFromSupertypes(ResolverScopeData scopeData, String propertyName) {
        Set<PropertyDescriptor> r = new HashSet<PropertyDescriptor>();
        for (JetType supertype : getSupertypes(scopeData)) {
            for (VariableDescriptor property : supertype.getMemberScope().getProperties(propertyName)) {
                r.add((PropertyDescriptor) property);
            }
        }
        return r;
    }

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

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

1387 1388 1389
        ResolverScopeData resolverScopeData = getResolverScopeData(descriptor, new PsiClassWrapper(psiClass));

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

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

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

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

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

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

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

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

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

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

1476
        ClassOrNamespaceDescriptor classDescriptor;
1477
        if (scopeData instanceof ResolverBinaryClassData) {
1478 1479
            ClassDescriptor classClassDescriptor = resolveClass(new FqName(method.getPsiMethod().getContainingClass().getQualifiedName()),
                    DescriptorSearchRule.INCLUDE_KOTLIN);
1480
            classDescriptor = classClassDescriptor;
1481 1482
        }
        else {
1483
            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
                Modality.convertFromFlags(method.getPsiMethod().hasModifierProperty(PsiModifier.ABSTRACT), !method.isFinal()),
1513 1514
                resolveVisibilityFromPsiModifiers(method.getPsiMethod()),
                /*isInline = */ false
A
Andrey Breslav 已提交
1515
        );
1516
        trace.record(BindingContext.FUNCTION, method.getPsiMethod(), functionDescriptorImpl);
A
Andrey Breslav 已提交
1517
        FunctionDescriptor substitutedFunctionDescriptor = functionDescriptorImpl;
S
Stepan Koltsov 已提交
1518 1519
        if (method.getPsiMethod().getContainingClass() != psiClass && !method.isStatic()) {
            throw new IllegalStateException("non-static method in subclass");
A
Andrey Breslav 已提交
1520
        }
1521
        return (FunctionDescriptorImpl) substitutedFunctionDescriptor;
A
Andrey Breslav 已提交
1522
    }
1523

1524 1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540
    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();
S
Stepan Koltsov 已提交
1541
        if (qname.startsWith("java.lang.annotation.") || qname.startsWith("jet.runtime.typeinfo.") || qname.equals(JvmAbi.JETBRAINS_NOT_NULL_ANNOTATION.getFqName().getFqName())) {
1542 1543 1544 1545
            // TODO
            return null;
        }

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

        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
1580 1581 1582
        return annotation;
    }

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

1586
        TypeSubstitutor substitutorForGenericSupertypes = typeSubstitutorForGenericSupertypes(scopeData);
1587

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

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

1597 1598
        return functions;
    }
1599

1600 1601 1602 1603 1604 1605 1606 1607 1608 1609 1610 1611
    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) {
1612
            return createSubstitutorForGenericSupertypes(((ResolverClassData)scopeData).getClassDescriptor());
1613 1614 1615 1616 1617
        } else {
            return TypeSubstitutor.EMPTY;
        }
    }

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

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

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

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

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

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

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

1675
    private static Visibility resolveVisibilityFromPsiModifiers(PsiModifierListOwner modifierListOwner) {
1676
        return modifierListOwner.hasModifierProperty(PsiModifier.PUBLIC) ? Visibilities.PUBLIC :
1677 1678 1679 1680
               (modifierListOwner.hasModifierProperty(PsiModifier.PRIVATE) ? Visibilities.PRIVATE :
                (modifierListOwner.hasModifierProperty(PsiModifier.PROTECTED) ? Visibilities.PROTECTED :
                 //Visibilities.PUBLIC));
                 PACKAGE_VISIBILITY));
1681 1682
    }

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

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