| // Copyright 2016 Google Inc. All rights reserved. |
| // |
| // 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 config |
| |
| import ( |
| "strings" |
| |
| "android/soong/android" |
| ) |
| |
| func init() { |
| // Most Android source files are not clang-tidy clean yet. |
| // Global tidy checks include only google*, performance*, |
| // and misc-macro-parentheses, but not google-readability* |
| // or google-runtime-references. |
| pctx.VariableFunc("TidyDefaultGlobalChecks", func(config android.Config) (string, error) { |
| if override := config.Getenv("DEFAULT_GLOBAL_TIDY_CHECKS"); override != "" { |
| return override, nil |
| } |
| return strings.Join([]string{ |
| "-*", |
| "google*", |
| "misc-macro-parentheses", |
| "performance*", |
| "-google-readability*", |
| "-google-runtime-references", |
| }, ","), nil |
| }) |
| |
| // There are too many clang-tidy warnings in external and vendor projects. |
| // Enable only some google checks for these projects. |
| pctx.VariableFunc("TidyExternalVendorChecks", func(config android.Config) (string, error) { |
| if override := config.Getenv("DEFAULT_EXTERNAL_VENDOR_TIDY_CHECKS"); override != "" { |
| return override, nil |
| } |
| return strings.Join([]string{ |
| "-*", |
| "google*", |
| "-google-build-using-namespace", |
| "-google-default-arguments", |
| "-google-explicit-constructor", |
| "-google-readability*", |
| "-google-runtime-int", |
| "-google-runtime-references", |
| }, ","), nil |
| }) |
| |
| // Give warnings to header files only in selected directories. |
| // Do not give warnings to external or vendor header files, which contain too |
| // many warnings. |
| pctx.StaticVariable("TidyDefaultHeaderDirs", strings.Join([]string{ |
| "art/", |
| "bionic/", |
| "bootable/", |
| "build/", |
| "cts/", |
| "dalvik/", |
| "developers/", |
| "development/", |
| "frameworks/", |
| "libcore/", |
| "libnativehelper/", |
| "system/", |
| }, "|")) |
| } |
| |
| type PathBasedTidyCheck struct { |
| PathPrefix string |
| Checks string |
| } |
| |
| const tidyDefault = "${config.TidyDefaultGlobalChecks}" |
| const tidyExternalVendor = "${config.TidyExternalVendorChecks}" |
| |
| // This is a map of local path prefixes to the set of default clang-tidy checks |
| // to be used. |
| // The last matched local_path_prefix should be the most specific to be used. |
| var DefaultLocalTidyChecks = []PathBasedTidyCheck{ |
| {"external/", tidyExternalVendor}, |
| {"external/google", tidyDefault}, |
| {"external/webrtc", tidyDefault}, |
| {"frameworks/compile/mclinker/", tidyExternalVendor}, |
| {"hardware/qcom", tidyExternalVendor}, |
| {"vendor/", tidyExternalVendor}, |
| {"vendor/google", tidyDefault}, |
| {"vendor/google_devices", tidyExternalVendor}, |
| } |
| |
| var reversedDefaultLocalTidyChecks = reverseTidyChecks(DefaultLocalTidyChecks) |
| |
| func reverseTidyChecks(in []PathBasedTidyCheck) []PathBasedTidyCheck { |
| ret := make([]PathBasedTidyCheck, len(in)) |
| for i, check := range in { |
| ret[len(in)-i-1] = check |
| } |
| return ret |
| } |
| |
| func TidyChecksForDir(dir string) string { |
| for _, pathCheck := range reversedDefaultLocalTidyChecks { |
| if strings.HasPrefix(dir, pathCheck.PathPrefix) { |
| return pathCheck.Checks |
| } |
| } |
| return tidyDefault |
| } |