Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for using project dependencies in the declarative DSL with DependencyCollector #28465

Merged
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
Expand Up @@ -104,13 +104,22 @@ class ImplicitDependencyCollectorFunctionExtractor(val configurations: Dependenc
.filter { function -> hasDependencyCollectorGetterSignature(function) }
.map { function -> function.name.removePrefix("get").replaceFirstChar { it.lowercase(Locale.getDefault()) } }
.filter { confName -> confName in configurations.configurationNames }
.map { confName ->
DataMemberFunction(
kClass.toDataTypeRef(),
confName,
listOf(DataParameter("dependency", String::class.toDataTypeRef(), false, ParameterSemantics.Unknown)),
false,
FunctionSemantics.AddAndConfigure(kClass.toDataTypeRef(), NOT_ALLOWED)
.flatMap { confName ->
listOf(
DataMemberFunction(
kClass.toDataTypeRef(),
confName,
listOf(DataParameter("dependency", String::class.toDataTypeRef(), false, ParameterSemantics.Unknown)),
false,
FunctionSemantics.AddAndConfigure(kClass.toDataTypeRef(), NOT_ALLOWED)
),
DataMemberFunction(
kClass.toDataTypeRef(),
confName,
listOf(DataParameter("dependency", ProjectDependency::class.toDataTypeRef(), false, ParameterSemantics.Unknown)),
false,
FunctionSemantics.AddAndConfigure(kClass.toDataTypeRef(), NOT_ALLOWED)
)
)
}

Expand Down Expand Up @@ -148,14 +157,29 @@ class ImplicitDependencyCollectorFunctionResolver(configurations: DependencyConf
if (name in configurationNames) {
val getterFunction = getDependencyCollectorGetter(receiverClass, name)
if (getterFunction != null) {
return RuntimeFunctionResolver.Resolution.Resolved(object : DeclarativeRuntimeFunction {
override fun callBy(receiver: Any, binding: Map<DataParameter, Any?>, hasLambda: Boolean): DeclarativeRuntimeFunction.InvocationResult {
val dependencyNotation = binding.values.single().toString()
val collector: DependencyCollector = getterFunction.call(receiver) as DependencyCollector
collector.add(dependencyNotation)
return DeclarativeRuntimeFunction.InvocationResult(Unit, null)
}
})
val gavParam = DataParameter("dependency", String::class.toDataTypeRef(), false, ParameterSemantics.Unknown)
tresat marked this conversation as resolved.
Show resolved Hide resolved
val projectParam = DataParameter("dependency", ProjectDependency::class.toDataTypeRef(), false, ParameterSemantics.Unknown)
if (parameterValueBinding.bindingMap.containsKey(gavParam)) {
return RuntimeFunctionResolver.Resolution.Resolved(object : DeclarativeRuntimeFunction {
tresat marked this conversation as resolved.
Show resolved Hide resolved
override fun callBy(receiver: Any, binding: Map<DataParameter, Any?>, hasLambda: Boolean): DeclarativeRuntimeFunction.InvocationResult {
val dependencyNotation = binding.values.single().toString()
val collector: DependencyCollector = getterFunction.call(receiver) as DependencyCollector
collector.add(dependencyNotation)
return DeclarativeRuntimeFunction.InvocationResult(Unit, null)
}
})
} else if (parameterValueBinding.bindingMap.containsKey(projectParam)) {
return RuntimeFunctionResolver.Resolution.Resolved(object : DeclarativeRuntimeFunction {
override fun callBy(receiver: Any, binding: Map<DataParameter, Any?>, hasLambda: Boolean): DeclarativeRuntimeFunction.InvocationResult {
val dependencyNotation = binding.values.single() as ProjectDependency
val collector: DependencyCollector = getterFunction.call(receiver) as DependencyCollector
collector.add(dependencyNotation)
return DeclarativeRuntimeFunction.InvocationResult(Unit, null)
}
})
} else {
throw IllegalStateException()
tresat marked this conversation as resolved.
Show resolved Hide resolved
}
}
}
return RuntimeFunctionResolver.Resolution.Unresolved
Expand Down