Expand ClangExtraExternalCflags to non-Google vendor projects
Some of the warnings are too common to fix/opt-out for non-Google projects. Also in the change, minor clean up of duplicated code. Test: presubmit Bug: 139945549 Change-Id: Ic176ef1f17133405851a79592b6bef5ccb403bd9
This commit is contained in:
committed by
Nick Desaulniers
parent
2d5ce8538b
commit
950e0baf2a
@@ -17,6 +17,7 @@ package cc
|
||||
import (
|
||||
"fmt"
|
||||
"path/filepath"
|
||||
"regexp"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
@@ -252,6 +253,7 @@ func addToModuleList(ctx ModuleContext, key android.OnceKey, module string) {
|
||||
// per-target values, module type values, and per-module Blueprints properties
|
||||
func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps PathDeps) Flags {
|
||||
tc := ctx.toolchain()
|
||||
modulePath := android.PathForModuleSrc(ctx).String()
|
||||
|
||||
compiler.srcsBeforeGen = android.PathsForModuleSrcExcludes(ctx, compiler.Properties.Srcs, compiler.Properties.Exclude_srcs)
|
||||
compiler.srcsBeforeGen = append(compiler.srcsBeforeGen, deps.GeneratedSources...)
|
||||
@@ -289,8 +291,8 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps
|
||||
|
||||
if compiler.Properties.Include_build_directory == nil ||
|
||||
*compiler.Properties.Include_build_directory {
|
||||
flags.Local.CommonFlags = append(flags.Local.CommonFlags, "-I"+android.PathForModuleSrc(ctx).String())
|
||||
flags.Local.YasmFlags = append(flags.Local.YasmFlags, "-I"+android.PathForModuleSrc(ctx).String())
|
||||
flags.Local.CommonFlags = append(flags.Local.CommonFlags, "-I"+modulePath)
|
||||
flags.Local.YasmFlags = append(flags.Local.YasmFlags, "-I"+modulePath)
|
||||
}
|
||||
|
||||
if !(ctx.useSdk() || ctx.useVndk()) || ctx.Host() {
|
||||
@@ -381,7 +383,7 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps
|
||||
"${config.CommonClangGlobalCflags}",
|
||||
fmt.Sprintf("${config.%sClangGlobalCflags}", hod))
|
||||
|
||||
if strings.HasPrefix(android.PathForModuleSrc(ctx).String(), "external/") {
|
||||
if isThirdParty(modulePath) {
|
||||
flags.Global.CommonFlags = append([]string{"${config.ClangExternalCflags}"}, flags.Global.CommonFlags...)
|
||||
}
|
||||
|
||||
@@ -438,7 +440,7 @@ func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags, deps
|
||||
// vendor/device specific things), we could extend this to be a ternary
|
||||
// value.
|
||||
strict := true
|
||||
if strings.HasPrefix(android.PathForModuleSrc(ctx).String(), "external/") {
|
||||
if strings.HasPrefix(modulePath, "external/") {
|
||||
strict = false
|
||||
}
|
||||
|
||||
@@ -580,3 +582,28 @@ func compileObjs(ctx android.ModuleContext, flags builderFlags,
|
||||
|
||||
return TransformSourceToObj(ctx, subdir, srcFiles, flags, pathDeps, cFlagsDeps)
|
||||
}
|
||||
|
||||
var thirdPartyDirPrefixExceptions = []*regexp.Regexp{
|
||||
regexp.MustCompile("^vendor/[^/]*google[^/]*/"),
|
||||
regexp.MustCompile("^hardware/google/"),
|
||||
regexp.MustCompile("^hardware/interfaces/"),
|
||||
regexp.MustCompile("^hardware/libhardware[^/]*/"),
|
||||
regexp.MustCompile("^hardware/ril/"),
|
||||
}
|
||||
|
||||
func isThirdParty(path string) bool {
|
||||
thirdPartyDirPrefixes := []string{"external/", "vendor/", "hardware/"}
|
||||
|
||||
for _, prefix := range thirdPartyDirPrefixes {
|
||||
if strings.HasPrefix(path, prefix) {
|
||||
for _, prefix := range thirdPartyDirPrefixExceptions {
|
||||
if prefix.MatchString(path) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
return true
|
||||
}
|
||||
|
Reference in New Issue
Block a user