Use generics for providers API
Using generics for the providers API allows a type to be associated with a ProviderKey, resulting in a type-safe API without that doesn't require runtime type assertions by every caller. Unfortunately, Go does not allow generic types in methods, only in functions [1]. This prevents a type-safe API on ModuleContext, and requires moving the API to be functions that take a ModuleContext as a parameter. This CL creates the new API, but doesn't convert all of the callers. [1] https://go.googlesource.com/proposal/+/refs/heads/master/design/43651-type-parameters.md#no-parameterized-methods) Bug: 316410648 Test: builds Change-Id: I3e30d68b966b730efd968166a38a25cc144bd6de
This commit is contained in:
@@ -159,7 +159,7 @@ type AndroidMkEntriesContext interface {
|
||||
}
|
||||
|
||||
type AndroidMkExtraEntriesContext interface {
|
||||
Provider(provider blueprint.ProviderKey) interface{}
|
||||
Provider(provider blueprint.AnyProviderKey) (any, bool)
|
||||
}
|
||||
|
||||
type androidMkExtraEntriesContext struct {
|
||||
@@ -167,8 +167,8 @@ type androidMkExtraEntriesContext struct {
|
||||
mod blueprint.Module
|
||||
}
|
||||
|
||||
func (a *androidMkExtraEntriesContext) Provider(provider blueprint.ProviderKey) interface{} {
|
||||
return a.ctx.ModuleProvider(a.mod, provider)
|
||||
func (a *androidMkExtraEntriesContext) Provider(provider blueprint.AnyProviderKey) (any, bool) {
|
||||
return a.ctx.moduleProvider(a.mod, provider)
|
||||
}
|
||||
|
||||
type AndroidMkExtraEntriesFunc func(ctx AndroidMkExtraEntriesContext, entries *AndroidMkEntries)
|
||||
@@ -492,8 +492,9 @@ type fillInEntriesContext interface {
|
||||
ModuleDir(module blueprint.Module) string
|
||||
ModuleSubDir(module blueprint.Module) string
|
||||
Config() Config
|
||||
ModuleProvider(module blueprint.Module, provider blueprint.ProviderKey) interface{}
|
||||
ModuleHasProvider(module blueprint.Module, provider blueprint.ProviderKey) bool
|
||||
ModuleProvider(module blueprint.Module, provider blueprint.AnyProviderKey) any
|
||||
ModuleHasProvider(module blueprint.Module, provider blueprint.AnyProviderKey) bool
|
||||
moduleProvider(module blueprint.Module, provider blueprint.AnyProviderKey) (any, bool)
|
||||
ModuleType(module blueprint.Module) string
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user