001 /* 002 * Copyright 2010-2015 JetBrains s.r.o. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016 017 package org.jetbrains.kotlin.resolve.calls.context; 018 019 import org.jetbrains.annotations.NotNull; 020 import org.jetbrains.annotations.Nullable; 021 import org.jetbrains.kotlin.descriptors.CallableDescriptor; 022 import org.jetbrains.kotlin.psi.Call; 023 import org.jetbrains.kotlin.resolve.BindingTrace; 024 import org.jetbrains.kotlin.resolve.StatementFilter; 025 import org.jetbrains.kotlin.resolve.calls.checkers.CallChecker; 026 import org.jetbrains.kotlin.resolve.calls.model.MutableDataFlowInfoForArguments; 027 import org.jetbrains.kotlin.resolve.calls.model.MutableResolvedCall; 028 import org.jetbrains.kotlin.resolve.calls.smartcasts.DataFlowInfo; 029 import org.jetbrains.kotlin.resolve.calls.tasks.TracingStrategy; 030 import org.jetbrains.kotlin.resolve.scopes.LexicalScope; 031 import org.jetbrains.kotlin.resolve.scopes.receivers.Receiver; 032 import org.jetbrains.kotlin.resolve.scopes.receivers.ReceiverValue; 033 import org.jetbrains.kotlin.types.KotlinType; 034 035 public final class CallCandidateResolutionContext<D extends CallableDescriptor> extends CallResolutionContext<CallCandidateResolutionContext<D>> { 036 @NotNull 037 public final MutableResolvedCall<D> candidateCall; 038 @NotNull 039 public final TracingStrategy tracing; 040 @NotNull 041 public final Receiver explicitExtensionReceiverForInvoke; 042 @NotNull 043 public final CandidateResolveMode candidateResolveMode; 044 045 private CallCandidateResolutionContext( 046 @NotNull MutableResolvedCall<D> candidateCall, 047 @NotNull TracingStrategy tracing, 048 @NotNull BindingTrace trace, 049 @NotNull LexicalScope scope, 050 @NotNull Call call, 051 @NotNull KotlinType expectedType, 052 @NotNull DataFlowInfo dataFlowInfo, 053 @NotNull ContextDependency contextDependency, 054 @NotNull CheckArgumentTypesMode checkArguments, 055 @NotNull ResolutionResultsCache resolutionResultsCache, 056 @Nullable MutableDataFlowInfoForArguments dataFlowInfoForArguments, 057 @NotNull CallChecker callChecker, 058 @NotNull StatementFilter statementFilter, 059 @NotNull Receiver explicitExtensionReceiverForInvoke, 060 @NotNull CandidateResolveMode candidateResolveMode, 061 boolean isAnnotationContext, 062 boolean collectAllCandidates 063 ) { 064 super(trace, scope, call, expectedType, dataFlowInfo, contextDependency, checkArguments, resolutionResultsCache, 065 dataFlowInfoForArguments, callChecker, statementFilter, isAnnotationContext, 066 collectAllCandidates); 067 this.candidateCall = candidateCall; 068 this.tracing = tracing; 069 this.explicitExtensionReceiverForInvoke = explicitExtensionReceiverForInvoke; 070 this.candidateResolveMode = candidateResolveMode; 071 } 072 073 public static <D extends CallableDescriptor> CallCandidateResolutionContext<D> create( 074 @NotNull MutableResolvedCall<D> candidateCall, @NotNull CallResolutionContext<?> context, @NotNull BindingTrace trace, 075 @NotNull TracingStrategy tracing, @NotNull Call call, @NotNull Receiver explicitExtensionReceiverForInvoke, 076 @NotNull CandidateResolveMode candidateResolveMode 077 ) { 078 return new CallCandidateResolutionContext<D>( 079 candidateCall, tracing, trace, context.scope, call, context.expectedType, 080 context.dataFlowInfo, context.contextDependency, context.checkArguments, 081 context.resolutionResultsCache, context.dataFlowInfoForArguments, 082 context.callChecker, context.statementFilter, explicitExtensionReceiverForInvoke, 083 candidateResolveMode, context.isAnnotationContext, context.collectAllCandidates); 084 } 085 086 @NotNull 087 public static <D extends CallableDescriptor> CallCandidateResolutionContext<D> createForCallBeingAnalyzed( 088 @NotNull MutableResolvedCall<D> candidateCall, @NotNull BasicCallResolutionContext context, @NotNull TracingStrategy tracing 089 ) { 090 return new CallCandidateResolutionContext<D>( 091 candidateCall, tracing, context.trace, context.scope, context.call, context.expectedType, 092 context.dataFlowInfo, context.contextDependency, context.checkArguments, context.resolutionResultsCache, 093 context.dataFlowInfoForArguments, context.callChecker, context.statementFilter, 094 ReceiverValue.NO_RECEIVER, CandidateResolveMode.FULLY, context.isAnnotationContext, context.collectAllCandidates); 095 } 096 097 @Override 098 protected CallCandidateResolutionContext<D> create( 099 @NotNull BindingTrace trace, 100 @NotNull LexicalScope scope, 101 @NotNull DataFlowInfo dataFlowInfo, 102 @NotNull KotlinType expectedType, 103 @NotNull ContextDependency contextDependency, 104 @NotNull ResolutionResultsCache resolutionResultsCache, 105 @NotNull StatementFilter statementFilter, 106 boolean collectAllCandidates 107 ) { 108 return new CallCandidateResolutionContext<D>( 109 candidateCall, tracing, trace, scope, call, expectedType, dataFlowInfo, contextDependency, checkArguments, 110 resolutionResultsCache, dataFlowInfoForArguments, callChecker, statementFilter, 111 explicitExtensionReceiverForInvoke, candidateResolveMode, isAnnotationContext, collectAllCandidates); 112 } 113 }