aboutsummaryrefslogtreecommitdiffstats
path: root/cc
diff options
context:
space:
mode:
authorPirama Arumuga Nainar <pirama@google.com>2019-03-29 09:31:24 -0700
committerandroid-build-merger <android-build-merger@google.com>2019-03-29 09:31:24 -0700
commit5f4da30d62d8cd232ea5613f3e4afcad751753b6 (patch)
treefa3373316792bff0af26c970f6dd533d36c69155 /cc
parenta5d59cce588070355e622b7420ba2112e07b53b5 (diff)
parent2bccc05cbf1a0e0d3ac3d7e06e8073f73ab960c2 (diff)
downloadbuild_soong-5f4da30d62d8cd232ea5613f3e4afcad751753b6.tar.gz
build_soong-5f4da30d62d8cd232ea5613f3e4afcad751753b6.tar.bz2
build_soong-5f4da30d62d8cd232ea5613f3e4afcad751753b6.zip
Refactor coverage support am: ee30d5e132 am: 312b5f4407
am: 2bccc05cbf Change-Id: Ie2a491d4865015f7d3c062e0390a03de0ca14bc8
Diffstat (limited to 'cc')
-rw-r--r--cc/coverage.go64
1 files changed, 36 insertions, 28 deletions
diff --git a/cc/coverage.go b/cc/coverage.go
index ad2f1e4b..fabcbf4d 100644
--- a/cc/coverage.go
+++ b/cc/coverage.go
@@ -23,6 +23,9 @@ import (
type CoverageProperties struct {
Native_coverage *bool
+ NeedCoverageVariant bool `blueprint:"mutated"`
+ NeedCoverageBuild bool `blueprint:"mutated"`
+
CoverageEnabled bool `blueprint:"mutated"`
IsCoverageVariant bool `blueprint:"mutated"`
}
@@ -38,8 +41,6 @@ func (cov *coverage) props() []interface{} {
return []interface{}{&cov.Properties}
}
-func (cov *coverage) begin(ctx BaseModuleContext) {}
-
func (cov *coverage) deps(ctx BaseModuleContext, deps Deps) Deps {
return deps
}
@@ -100,40 +101,47 @@ func (cov *coverage) flags(ctx ModuleContext, flags Flags) Flags {
return flags
}
-func coverageMutator(mctx android.BottomUpMutatorContext) {
+func (cov *coverage) begin(ctx BaseModuleContext) {
// Coverage is disabled globally
- if !mctx.DeviceConfig().NativeCoverageEnabled() {
+ if !ctx.DeviceConfig().NativeCoverageEnabled() {
return
}
- if c, ok := mctx.Module().(*Module); ok {
- var needCoverageVariant bool
- var needCoverageBuild bool
-
- if mctx.Host() {
- // TODO(dwillemsen): because of -nodefaultlibs, we must depend on libclang_rt.profile-*.a
- // Just turn off for now.
- } else if c.IsStubs() {
- // Do not enable coverage for platform stub libraries
- } else if c.isNDKStubLibrary() {
- // Do not enable coverage for NDK stub libraries
- } else if c.coverage != nil {
- // Check if Native_coverage is set to false. This property defaults to true.
- needCoverageVariant = BoolDefault(c.coverage.Properties.Native_coverage, true)
-
- if sdk_version := String(c.Properties.Sdk_version); sdk_version != "current" {
- // Native coverage is not supported for SDK versions < 23
- if fromApi, err := strconv.Atoi(sdk_version); err == nil && fromApi < 23 {
- needCoverageVariant = false
- }
+ var needCoverageVariant bool
+ var needCoverageBuild bool
+
+ if ctx.Host() {
+ // TODO(dwillemsen): because of -nodefaultlibs, we must depend on libclang_rt.profile-*.a
+ // Just turn off for now.
+ } else if ctx.isStubs() {
+ // Do not enable coverage for platform stub libraries
+ } else if ctx.isNDKStubLibrary() {
+ // Do not enable coverage for NDK stub libraries
+ } else {
+ // Check if Native_coverage is set to false. This property defaults to true.
+ needCoverageVariant = BoolDefault(cov.Properties.Native_coverage, true)
+
+ if sdk_version := ctx.sdkVersion(); ctx.useSdk() && sdk_version != "current" {
+ // Native coverage is not supported for SDK versions < 23
+ if fromApi, err := strconv.Atoi(sdk_version); err == nil && fromApi < 23 {
+ needCoverageVariant = false
}
+ }
- if needCoverageVariant {
- // Coverage variant is actually built with coverage if enabled for its module path
- needCoverageBuild = mctx.DeviceConfig().CoverageEnabledForPath(mctx.ModuleDir())
- }
+ if needCoverageVariant {
+ // Coverage variant is actually built with coverage if enabled for its module path
+ needCoverageBuild = ctx.DeviceConfig().CoverageEnabledForPath(ctx.ModuleDir())
}
+ }
+ cov.Properties.NeedCoverageBuild = needCoverageBuild
+ cov.Properties.NeedCoverageVariant = needCoverageVariant
+}
+
+func coverageMutator(mctx android.BottomUpMutatorContext) {
+ if c, ok := mctx.Module().(*Module); ok && c.coverage != nil {
+ needCoverageVariant := c.coverage.Properties.NeedCoverageVariant
+ needCoverageBuild := c.coverage.Properties.NeedCoverageBuild
if needCoverageVariant {
m := mctx.CreateVariations("", "cov")