AA: indicate whether a value parameter is an implicit lambda parameter ^KTIJ-18800 In progress
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/components/KtFe10SymbolContainingDeclarationProvider.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/components/KtFe10SymbolContainingDeclarationProvider.kt index f249dcd..d43d78a 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/components/KtFe10SymbolContainingDeclarationProvider.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/components/KtFe10SymbolContainingDeclarationProvider.kt
@@ -18,6 +18,7 @@ import org.jetbrains.kotlin.analysis.api.symbols.KtBackingFieldSymbol import org.jetbrains.kotlin.analysis.api.symbols.KtPackageSymbol import org.jetbrains.kotlin.analysis.api.symbols.KtSymbol +import org.jetbrains.kotlin.analysis.api.symbols.KtValueParameterSymbol import org.jetbrains.kotlin.analysis.api.symbols.markers.KtSymbolKind import org.jetbrains.kotlin.analysis.api.symbols.markers.KtSymbolWithKind import org.jetbrains.kotlin.analysis.api.tokens.ValidityToken @@ -68,6 +69,13 @@ // TODO this is a dummy and incorrect implementation just to satisfy some tests override fun getContainingModule(symbol: KtSymbol): KtModule { + // Implicit lambda parameter doesn't have a source PSI. + if ((symbol as? KtValueParameterSymbol)?.isImplicitLambdaParameter == true) { + // Retrieve the module from its containing lambda instead. + getContainingDeclaration(symbol)?.let { parentLambdaSymbol -> + return getContainingModule(parentLambdaSymbol) + } + } return symbol.psi?.getKtModule(analysisSession.analysisContext.resolveSession.project) ?: symbol.getDescriptor()?.getFakeContainingKtModule() ?: TODO(symbol.toString()) @@ -98,4 +106,4 @@ else -> TODO(this.toString()) } } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescDefaultPropertySetterSymbol.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescDefaultPropertySetterSymbol.kt index d55582f..8eb7677 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescDefaultPropertySetterSymbol.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescDefaultPropertySetterSymbol.kt
@@ -14,7 +14,6 @@ import org.jetbrains.kotlin.analysis.api.symbols.KtPropertySetterSymbol import org.jetbrains.kotlin.analysis.api.symbols.KtSymbolOrigin import org.jetbrains.kotlin.analysis.api.symbols.KtValueParameterSymbol -import org.jetbrains.kotlin.analysis.api.annotations.KtAnnotationApplication import org.jetbrains.kotlin.analysis.api.annotations.KtAnnotationsList import org.jetbrains.kotlin.analysis.api.impl.base.annotations.KtEmptyAnnotationsList import org.jetbrains.kotlin.analysis.api.symbols.pointers.KtSymbolPointer @@ -24,7 +23,6 @@ import org.jetbrains.kotlin.descriptors.PropertyDescriptor import org.jetbrains.kotlin.descriptors.Visibility import org.jetbrains.kotlin.name.CallableId -import org.jetbrains.kotlin.name.ClassId import org.jetbrains.kotlin.name.Name class KtFe10DescDefaultPropertySetterSymbol( @@ -93,6 +91,9 @@ override val isVararg: Boolean get() = withValidityAssertion { false } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { false } + override val name: Name get() = withValidityAssertion { Name.identifier("value") } @@ -108,11 +109,10 @@ override val annotationsList: KtAnnotationsList get() = withValidityAssertion { KtEmptyAnnotationsList(token) } - override fun createPointer(): KtSymbolPointer<KtValueParameterSymbol> { withValidityAssertion { return KtFe10NeverRestoringSymbolPointer() } } } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescValueParameterSymbol.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescValueParameterSymbol.kt index 3ac4152..6146521 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescValueParameterSymbol.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/KtFe10DescValueParameterSymbol.kt
@@ -6,7 +6,6 @@ package org.jetbrains.kotlin.analysis.api.descriptors.symbols.descriptorBased import org.jetbrains.kotlin.analysis.api.descriptors.Fe10AnalysisContext -import org.jetbrains.kotlin.analysis.api.descriptors.KtFe10AnalysisSession import org.jetbrains.kotlin.analysis.api.descriptors.symbols.descriptorBased.base.KtFe10DescSymbol import org.jetbrains.kotlin.analysis.api.descriptors.symbols.descriptorBased.base.toKtType import org.jetbrains.kotlin.analysis.api.descriptors.symbols.pointers.KtFe10NeverRestoringSymbolPointer @@ -16,10 +15,14 @@ import org.jetbrains.kotlin.analysis.api.types.KtType import org.jetbrains.kotlin.analysis.api.withValidityAssertion import org.jetbrains.kotlin.descriptors.ValueParameterDescriptor +import org.jetbrains.kotlin.descriptors.impl.AnonymousFunctionDescriptor import org.jetbrains.kotlin.name.Name import org.jetbrains.kotlin.name.SpecialNames +import org.jetbrains.kotlin.psi.KtFunctionLiteral +import org.jetbrains.kotlin.resolve.BindingContext import org.jetbrains.kotlin.resolve.calls.components.hasDefaultValue import org.jetbrains.kotlin.resolve.calls.components.isVararg +import org.jetbrains.kotlin.resolve.source.getPsi internal class KtFe10DescValueParameterSymbol( override val descriptor: ValueParameterDescriptor, @@ -39,6 +42,18 @@ override val isVararg: Boolean get() = withValidityAssertion { descriptor.isVararg } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { + descriptor.containingDeclaration is AnonymousFunctionDescriptor && + descriptor.name.identifierOrNullIfSpecial == "it" && + // Implicit lambda parameter doesn't have a source PSI. + descriptor.source.getPsi() == null && + // But, that could be the case for a declaration from Library. Double-check the slice in the binding context + (descriptor.containingDeclaration.source.getPsi() as? KtFunctionLiteral)?.let { parentLambda -> + analysisContext.analyze(parentLambda).get(BindingContext.AUTO_CREATED_IT, descriptor) != null + } == true + } + override val returnType: KtType get() = withValidityAssertion { return (descriptor.varargElementType ?: descriptor.type).toKtType(analysisContext) @@ -47,4 +62,4 @@ override fun createPointer(): KtSymbolPointer<KtValueParameterSymbol> = withValidityAssertion { return KtPsiBasedSymbolPointer.createForSymbolFromSource(this) ?: KtFe10NeverRestoringSymbolPointer() } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/base/Kt1DescUtils.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/base/Kt1DescUtils.kt index 2161262..38a1359 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/base/Kt1DescUtils.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/descriptorBased/base/Kt1DescUtils.kt
@@ -305,6 +305,11 @@ val virtualFile = psi.containingFile.virtualFile return analysisContext.getOrigin(virtualFile) + } else { // psi == null + // Implicit lambda parameter + if (this is ValueParameterDescriptor && this.name.identifierOrNullIfSpecial == "it") { + return KtSymbolOrigin.SOURCE_MEMBER_GENERATED + } } return KtSymbolOrigin.SOURCE @@ -535,4 +540,4 @@ internal fun AnnotationDescriptor.getKtNamedAnnotationArguments() = allValueArguments.map { (name, value) -> KtNamedAnnotationValue(name, value.toKtAnnotationValue()) - } \ No newline at end of file + }
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultPropertySetterSymbol.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultPropertySetterSymbol.kt index b347c4c..7239978 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultPropertySetterSymbol.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultPropertySetterSymbol.kt
@@ -32,7 +32,6 @@ import org.jetbrains.kotlin.descriptors.Visibility import org.jetbrains.kotlin.lexer.KtTokens import org.jetbrains.kotlin.name.CallableId -import org.jetbrains.kotlin.name.ClassId import org.jetbrains.kotlin.name.Name import org.jetbrains.kotlin.psi.KtProperty import org.jetbrains.kotlin.psi.psiUtil.isExtensionDeclaration @@ -116,6 +115,9 @@ override val isVararg: Boolean get() = withValidityAssertion { false } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { false } + override val name: Name get() = withValidityAssertion { Name.identifier("value") } @@ -135,4 +137,4 @@ return KtFe10NeverRestoringSymbolPointer() } } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultSetterParameterSymbol.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultSetterParameterSymbol.kt index ba6d707..73ea243 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultSetterParameterSymbol.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiDefaultSetterParameterSymbol.kt
@@ -8,7 +8,6 @@ import com.intellij.psi.PsiElement import org.jetbrains.kotlin.analysis.api.descriptors.Fe10AnalysisContext import org.jetbrains.kotlin.analysis.api.descriptors.Fe10AnalysisFacade.AnalysisMode -import org.jetbrains.kotlin.analysis.api.descriptors.KtFe10AnalysisSession import org.jetbrains.kotlin.analysis.api.descriptors.symbols.base.KtFe10Symbol import org.jetbrains.kotlin.analysis.api.descriptors.symbols.descriptorBased.base.toKtType import org.jetbrains.kotlin.analysis.api.descriptors.symbols.pointers.KtFe10NeverRestoringSymbolPointer @@ -16,14 +15,12 @@ import org.jetbrains.kotlin.analysis.api.descriptors.utils.cached import org.jetbrains.kotlin.analysis.api.symbols.KtSymbolOrigin import org.jetbrains.kotlin.analysis.api.symbols.KtValueParameterSymbol -import org.jetbrains.kotlin.analysis.api.annotations.KtAnnotationApplication import org.jetbrains.kotlin.analysis.api.annotations.KtAnnotationsList import org.jetbrains.kotlin.analysis.api.impl.base.annotations.KtEmptyAnnotationsList import org.jetbrains.kotlin.analysis.api.symbols.pointers.KtSymbolPointer import org.jetbrains.kotlin.analysis.api.types.KtType import org.jetbrains.kotlin.analysis.api.withValidityAssertion import org.jetbrains.kotlin.descriptors.VariableDescriptor -import org.jetbrains.kotlin.name.ClassId import org.jetbrains.kotlin.name.Name import org.jetbrains.kotlin.psi.KtPropertyAccessor import org.jetbrains.kotlin.resolve.BindingContext @@ -46,6 +43,9 @@ override val isVararg: Boolean get() = withValidityAssertion { false } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { false } + override val returnType: KtType get() = withValidityAssertion { descriptor?.type?.toKtType(analysisContext) ?: createErrorType() } @@ -61,4 +61,4 @@ override fun createPointer(): KtSymbolPointer<KtValueParameterSymbol> = withValidityAssertion { return KtFe10NeverRestoringSymbolPointer() } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiValueParameterSymbol.kt b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiValueParameterSymbol.kt index a6e2075..6f05b86 100644 --- a/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiValueParameterSymbol.kt +++ b/analysis/analysis-api-fe10/src/org/jetbrains/kotlin/analysis/api/descriptors/symbols/psiBased/KtFe10PsiValueParameterSymbol.kt
@@ -7,7 +7,6 @@ import org.jetbrains.kotlin.analysis.api.descriptors.Fe10AnalysisContext import org.jetbrains.kotlin.analysis.api.descriptors.Fe10AnalysisFacade.AnalysisMode -import org.jetbrains.kotlin.analysis.api.descriptors.KtFe10AnalysisSession import org.jetbrains.kotlin.analysis.api.descriptors.symbols.descriptorBased.base.toKtType import org.jetbrains.kotlin.analysis.api.descriptors.symbols.pointers.KtFe10NeverRestoringSymbolPointer import org.jetbrains.kotlin.analysis.api.descriptors.symbols.psiBased.base.KtFe10PsiSymbol @@ -39,6 +38,9 @@ override val isVararg: Boolean get() = withValidityAssertion { psi.isVarArg } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { false } + override val returnType: KtType get() = withValidityAssertion { val type = (descriptor as? ValueParameterDescriptor)?.varargElementType ?: descriptor?.type @@ -51,4 +53,4 @@ override fun createPointer(): KtSymbolPointer<KtValueParameterSymbol> = withValidityAssertion { return KtPsiBasedSymbolPointer.createForSymbolFromSource(this) ?: KtFe10NeverRestoringSymbolPointer() } -} \ No newline at end of file +}
diff --git a/analysis/analysis-api-fe10/tests-gen/org/jetbrains/kotlin/analysis/api/fe10/test/cases/generated/cases/symbols/Fe10IdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java b/analysis/analysis-api-fe10/tests-gen/org/jetbrains/kotlin/analysis/api/fe10/test/cases/generated/cases/symbols/Fe10IdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java index 17471ec..aa210ba 100644 --- a/analysis/analysis-api-fe10/tests-gen/org/jetbrains/kotlin/analysis/api/fe10/test/cases/generated/cases/symbols/Fe10IdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java +++ b/analysis/analysis-api-fe10/tests-gen/org/jetbrains/kotlin/analysis/api/fe10/test/cases/generated/cases/symbols/Fe10IdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java
@@ -59,6 +59,12 @@ } @Test + @TestMetadata("explicitLambdaParameter.kt") + public void testExplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt"); + } + + @Test @TestMetadata("genericFromFunctionInLocalClass.kt") public void testGenericFromFunctionInLocalClass() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/genericFromFunctionInLocalClass.kt"); @@ -71,6 +77,12 @@ } @Test + @TestMetadata("implicitLambdaParameter.kt") + public void testImplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt"); + } + + @Test @TestMetadata("samConstructor.kt") public void testSamConstructor() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/samConstructor.kt");
diff --git a/analysis/analysis-api-fir/src/org/jetbrains/kotlin/analysis/api/fir/symbols/KtFirValueParameterSymbol.kt b/analysis/analysis-api-fir/src/org/jetbrains/kotlin/analysis/api/fir/symbols/KtFirValueParameterSymbol.kt index 658a006..c53f60d 100644 --- a/analysis/analysis-api-fir/src/org/jetbrains/kotlin/analysis/api/fir/symbols/KtFirValueParameterSymbol.kt +++ b/analysis/analysis-api-fir/src/org/jetbrains/kotlin/analysis/api/fir/symbols/KtFirValueParameterSymbol.kt
@@ -6,6 +6,7 @@ package org.jetbrains.kotlin.analysis.api.fir.symbols import com.intellij.psi.PsiElement +import org.jetbrains.kotlin.KtFakeSourceElementKind import org.jetbrains.kotlin.analysis.api.fir.KtSymbolByFirBuilder import org.jetbrains.kotlin.analysis.api.fir.annotations.KtFirAnnotationListForDeclaration import org.jetbrains.kotlin.analysis.api.fir.findPsi @@ -33,6 +34,11 @@ override val isVararg: Boolean get() = withValidityAssertion { firSymbol.isVararg } + override val isImplicitLambdaParameter: Boolean + get() = withValidityAssertion { + firSymbol.source?.kind == KtFakeSourceElementKind.ItLambdaParameter + } + override val returnType by cached { val returnType = firSymbol.resolvedReturnType return@cached if (firSymbol.isVararg) {
diff --git a/analysis/analysis-api-fir/tests-gen/org/jetbrains/kotlin/analysis/api/fir/test/cases/generated/cases/symbols/FirIdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java b/analysis/analysis-api-fir/tests-gen/org/jetbrains/kotlin/analysis/api/fir/test/cases/generated/cases/symbols/FirIdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java index c5e8493..ef3e3f3 100644 --- a/analysis/analysis-api-fir/tests-gen/org/jetbrains/kotlin/analysis/api/fir/test/cases/generated/cases/symbols/FirIdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java +++ b/analysis/analysis-api-fir/tests-gen/org/jetbrains/kotlin/analysis/api/fir/test/cases/generated/cases/symbols/FirIdeNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java
@@ -59,6 +59,12 @@ } @Test + @TestMetadata("explicitLambdaParameter.kt") + public void testExplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt"); + } + + @Test @TestMetadata("genericFromFunctionInLocalClass.kt") public void testGenericFromFunctionInLocalClass() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/genericFromFunctionInLocalClass.kt"); @@ -71,6 +77,12 @@ } @Test + @TestMetadata("implicitLambdaParameter.kt") + public void testImplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt"); + } + + @Test @TestMetadata("samConstructor.kt") public void testSamConstructor() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/samConstructor.kt");
diff --git a/analysis/analysis-api-standalone/tests-gen/org/jetbrains/kotlin/analysis/api/standalone/fir/test/cases/generated/cases/symbols/FirStandaloneNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java b/analysis/analysis-api-standalone/tests-gen/org/jetbrains/kotlin/analysis/api/standalone/fir/test/cases/generated/cases/symbols/FirStandaloneNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java index 63e6b2f..de2c4c1 100644 --- a/analysis/analysis-api-standalone/tests-gen/org/jetbrains/kotlin/analysis/api/standalone/fir/test/cases/generated/cases/symbols/FirStandaloneNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java +++ b/analysis/analysis-api-standalone/tests-gen/org/jetbrains/kotlin/analysis/api/standalone/fir/test/cases/generated/cases/symbols/FirStandaloneNormalAnalysisSourceModuleSymbolByReferenceTestGenerated.java
@@ -59,6 +59,12 @@ } @Test + @TestMetadata("explicitLambdaParameter.kt") + public void testExplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt"); + } + + @Test @TestMetadata("genericFromFunctionInLocalClass.kt") public void testGenericFromFunctionInLocalClass() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/genericFromFunctionInLocalClass.kt"); @@ -71,6 +77,12 @@ } @Test + @TestMetadata("implicitLambdaParameter.kt") + public void testImplicitLambdaParameter() throws Exception { + runTest("analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt"); + } + + @Test @TestMetadata("samConstructor.kt") public void testSamConstructor() throws Exception { runTest("analysis/analysis-api/testData/symbols/symbolByReference/samConstructor.kt");
diff --git a/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtSymbol.kt b/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtSymbol.kt index d053371..5764ee6 100644 --- a/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtSymbol.kt +++ b/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtSymbol.kt
@@ -50,11 +50,11 @@ SOURCE, /** - * Declaration which do not have it's PSI source and was generated, they are: + * Declaration which do not have its PSI source and was generated, they are: * For regular classes, implicit default constructor is generated * For data classes the `copy`, `component{N}`, `toString`, `equals`, `hashCode` functions are generated * For enum classes the `valueOf` & `values` functions are generated - * For lambda the `it` property is generated + * For lambda the `it` implicit parameter is generated */ SOURCE_MEMBER_GENERATED,
diff --git a/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtVariableLikeSymbol.kt b/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtVariableLikeSymbol.kt index 679d64a..d7c1581 100644 --- a/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtVariableLikeSymbol.kt +++ b/analysis/analysis-api/src/org/jetbrains/kotlin/analysis/api/symbols/KtVariableLikeSymbol.kt
@@ -151,9 +151,21 @@ final override val isExtension: Boolean get() = false final override val receiverType: KtType? get() = null + /** + * Whether this value parameter has a default value or not. + */ public abstract val hasDefaultValue: Boolean + + /** + * Whether this value parameter represents a variable number of arguments (`vararg`) or not. + */ public abstract val isVararg: Boolean + /** + * Whether this value parameter is an implicitly generated lambda parameter `it` or not. + */ + public abstract val isImplicitLambdaParameter: Boolean + abstract override fun createPointer(): KtSymbolPointer<KtValueParameterSymbol> /**
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/annotations.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/annotations.txt index 37b1502..80bca39 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/annotations.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/annotations.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: param1 origin: SOURCE @@ -17,6 +18,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: param2 origin: SOURCE @@ -120,4 +122,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/backingField.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/backingField.txt index 0aefcbb..ce730a0 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/backingField.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/backingField.txt
@@ -22,6 +22,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: value origin: SOURCE @@ -83,4 +84,4 @@ getterDeprecationStatus: null javaGetterName: getP javaSetterName: setP - setterDeprecationStatus: null \ No newline at end of file + setterDeprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/classSecondaryConstructors.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/classSecondaryConstructors.txt index 8d48857..21e6808 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/classSecondaryConstructors.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/classSecondaryConstructors.txt
@@ -20,6 +20,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: x origin: SOURCE @@ -53,6 +54,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: y origin: SOURCE @@ -67,6 +69,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: z origin: SOURCE @@ -116,4 +119,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/delegateField.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/delegateField.txt index 5dd2da3..f44ca91 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/delegateField.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/delegateField.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: x origin: SOURCE @@ -17,6 +18,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: y origin: SOURCE @@ -31,6 +33,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: z origin: SOURCE @@ -226,4 +229,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.descriptors.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.descriptors.txt index d669c3f..895d189 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.descriptors.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.descriptors.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: value origin: SOURCE @@ -149,4 +150,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.txt index 95131c3..9d44f2c 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/enumValueMember.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: value origin: SOURCE @@ -148,4 +149,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/function.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/function.txt index ccdac95..ed8b484 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/function.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/function.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: x origin: SOURCE @@ -37,4 +38,4 @@ ] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/functionWithTypeParams.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/functionWithTypeParams.txt index 01b1f7e..26e5516 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/functionWithTypeParams.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/functionWithTypeParams.txt
@@ -14,6 +14,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: x origin: SOURCE @@ -50,4 +51,4 @@ ] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/implicitConstructorDelegationCall.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/implicitConstructorDelegationCall.txt index 1e8ce8e..0e2f3e7 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/implicitConstructorDelegationCall.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/implicitConstructorDelegationCall.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: i origin: SOURCE @@ -51,4 +52,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/implicitReturnInLambda.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/implicitReturnInLambda.txt index c0b3a50..488dbfe 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/implicitReturnInLambda.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/implicitReturnInLambda.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: a origin: SOURCE @@ -55,6 +56,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: a origin: SOURCE @@ -158,6 +160,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: lmbd origin: SOURCE @@ -192,4 +195,4 @@ ] visibility: Private getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.descriptors.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.descriptors.txt index e9fe0a1..c7d6332 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.descriptors.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.descriptors.txt
@@ -59,6 +59,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: value origin: SOURCE @@ -147,4 +148,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.txt index a220192..aab4c5d 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/jvmName.txt
@@ -58,6 +58,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: value origin: SOURCE @@ -145,4 +146,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.descriptors.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.descriptors.txt index 71a72e6..57338f7 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.descriptors.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.descriptors.txt
@@ -125,6 +125,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: arg origin: SOURCE @@ -228,4 +229,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.txt index 5b6f96c..5368ca3 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/typeAnnotations.txt
@@ -125,6 +125,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: false name: arg origin: SOURCE @@ -227,4 +228,4 @@ typeParameters: [] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByPsi/varargFunctions.txt b/analysis/analysis-api/testData/symbols/symbolByPsi/varargFunctions.txt index 7483824..a529788 100644 --- a/analysis/analysis-api/testData/symbols/symbolByPsi/varargFunctions.txt +++ b/analysis/analysis-api/testData/symbols/symbolByPsi/varargFunctions.txt
@@ -3,6 +3,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: true name: a origin: SOURCE @@ -44,6 +45,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: true name: b origin: SOURCE @@ -85,6 +87,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: true name: c origin: SOURCE @@ -126,6 +129,7 @@ callableIdIfNonLocal: null hasDefaultValue: false isExtension: false + isImplicitLambdaParameter: false isVararg: true name: d origin: SOURCE @@ -160,4 +164,4 @@ ] visibility: Public getContainingModule: KtSourceModule "Sources of main" - deprecationStatus: null \ No newline at end of file + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.descriptors.txt b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.descriptors.txt new file mode 100644 index 0000000..5f10a5c --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.descriptors.txt
@@ -0,0 +1,14 @@ +KtValueParameterSymbol: + annotationsList: [] + callableIdIfNonLocal: null + hasDefaultValue: false + isExtension: false + isImplicitLambdaParameter: false + isVararg: false + name: it + origin: LIBRARY + receiverType: null + returnType: kotlin/Int + symbolKind: LOCAL + getContainingModule: KtSourceModule "Sources of main" + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt new file mode 100644 index 0000000..adbf2be --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.kt
@@ -0,0 +1,11 @@ +// DO_NOT_CHECK_SYMBOL_RESTORE + +inline fun <T, R> T.use(block: (T) -> R): R { + return block(this) +} + +fun foo() { + 42.use { it -> + i<caret>t.toString() + } +}
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.pretty.txt b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.pretty.txt new file mode 100644 index 0000000..b6ef1d2 --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.pretty.txt
@@ -0,0 +1 @@ +it: kotlin.Int
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.txt b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.txt new file mode 100644 index 0000000..3708715 --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/explicitLambdaParameter.txt
@@ -0,0 +1,14 @@ +KtValueParameterSymbol: + annotationsList: [] + callableIdIfNonLocal: null + hasDefaultValue: false + isExtension: false + isImplicitLambdaParameter: false + isVararg: false + name: it + origin: SOURCE + receiverType: null + returnType: kotlin/Int + symbolKind: LOCAL + getContainingModule: KtSourceModule "Sources of main" + deprecationStatus: null
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt new file mode 100644 index 0000000..448a963 --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.kt
@@ -0,0 +1,9 @@ +// DO_NOT_CHECK_SYMBOL_RESTORE + +inline fun <T, R> T.use(block: (T) -> R): R { + return block(this) +} + +fun foo() { + 42.use { i<caret>t.toString() } +}
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.pretty.txt b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.pretty.txt new file mode 100644 index 0000000..b6ef1d2 --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.pretty.txt
@@ -0,0 +1 @@ +it: kotlin.Int
diff --git a/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.txt b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.txt new file mode 100644 index 0000000..e8518d5 --- /dev/null +++ b/analysis/analysis-api/testData/symbols/symbolByReference/implicitLambdaParameter.txt
@@ -0,0 +1,14 @@ +KtValueParameterSymbol: + annotationsList: [] + callableIdIfNonLocal: null + hasDefaultValue: false + isExtension: false + isImplicitLambdaParameter: true + isVararg: false + name: it + origin: SOURCE_MEMBER_GENERATED + receiverType: null + returnType: kotlin/Int + symbolKind: LOCAL + getContainingModule: KtSourceModule "Sources of main" + deprecationStatus: null