Merge "Make source_stem required for Rust SourceProviders"
This commit is contained in:
commit
d13b308960
3 changed files with 38 additions and 7 deletions
|
@ -34,6 +34,7 @@ bootstrap_go_package {
|
||||||
"library_test.go",
|
"library_test.go",
|
||||||
"project_json_test.go",
|
"project_json_test.go",
|
||||||
"rust_test.go",
|
"rust_test.go",
|
||||||
|
"source_provider_test.go",
|
||||||
"test_test.go",
|
"test_test.go",
|
||||||
],
|
],
|
||||||
pluginFor: ["soong_build"],
|
pluginFor: ["soong_build"],
|
||||||
|
|
|
@ -19,9 +19,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type SourceProviderProperties struct {
|
type SourceProviderProperties struct {
|
||||||
// name for the generated source file. Defaults to module name (e.g. moduleNameFoo.rs is produced by default).
|
// filename for the generated source file (<source_stem>.rs). This field is required.
|
||||||
// Importantly, the inherited "stem" property for this module sets the output filename for the generated library
|
// The inherited "stem" property sets the output filename for the generated library variants only.
|
||||||
// variants only
|
|
||||||
Source_stem *string `android:"arch_variant"`
|
Source_stem *string `android:"arch_variant"`
|
||||||
|
|
||||||
// crate name, used for the library variant of this source provider. See additional details in rust_library.
|
// crate name, used for the library variant of this source provider. See additional details in rust_library.
|
||||||
|
@ -65,11 +64,11 @@ func NewSourceProvider() *baseSourceProvider {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (sp *baseSourceProvider) getStem(ctx android.ModuleContext) string {
|
func (sp *baseSourceProvider) getStem(ctx android.ModuleContext) string {
|
||||||
stem := ctx.ModuleName()
|
if String(sp.Properties.Source_stem) == "" {
|
||||||
if String(sp.Properties.Source_stem) != "" {
|
ctx.PropertyErrorf("source_stem",
|
||||||
stem = String(sp.Properties.Source_stem)
|
"source_stem property is undefined but required for rust_bindgen modules")
|
||||||
}
|
}
|
||||||
return stem
|
return String(sp.Properties.Source_stem)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (sp *baseSourceProvider) sourceProviderDeps(ctx DepsContext, deps Deps) Deps {
|
func (sp *baseSourceProvider) sourceProviderDeps(ctx DepsContext, deps Deps) Deps {
|
||||||
|
|
31
rust/source_provider_test.go
Normal file
31
rust/source_provider_test.go
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
// Copyright 2020 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
package rust
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
var stemRequiredError = "source_stem property is undefined but required for rust_bindgen modules"
|
||||||
|
|
||||||
|
func TestSourceProviderRequiredFields(t *testing.T) {
|
||||||
|
testRustError(t, stemRequiredError, `
|
||||||
|
rust_bindgen {
|
||||||
|
name: "libbindgen",
|
||||||
|
wrapper_src: "src/any.h",
|
||||||
|
crate_name: "bindgen",
|
||||||
|
}
|
||||||
|
`)
|
||||||
|
}
|
Loading…
Reference in a new issue