Mark ab/7061308 as merged in stage.

Bug: 180401296
Merged-In: I3d49e9da3021672f1896504ec29c10a5595d6ea4
Change-Id: Ic2fbffeb6d9cb36802e62346409d610f29a9119d
diff --git a/Android.bp b/Android.bp
index 2281e3d..e3d8c85 100644
--- a/Android.bp
+++ b/Android.bp
@@ -1,3 +1,44 @@
+package {
+    default_applicable_licenses: ["external_clang_license"],
+}
+
+// Added automatically by a large-scale-change that took the approach of
+// 'apply every license found to every target'. While this makes sure we respect
+// every license restriction, it may not be entirely correct.
+//
+// e.g. GPL in an MIT project might only apply to the contrib/ directory.
+//
+// Please consider splitting the single license below into multiple licenses,
+// taking care not to lose any license_kind information, and overriding the
+// default license using the 'licenses: [...]' property on targets as needed.
+//
+// For unused files, consider creating a 'fileGroup' with "//visibility:private"
+// to attach the license to, and including a comment whether the files may be
+// used in the current project.
+//
+// large-scale-change included anything that looked like it might be a license
+// text as a license_text. e.g. LICENSE, NOTICE, COPYING etc.
+//
+// Please consider removing redundant or irrelevant files from 'license_text:'.
+//
+// large-scale-change filtered out the below license kinds as false-positives:
+//   SPDX-license-identifier-GPL
+// See: http://go/android-license-faq
+license {
+    name: "external_clang_license",
+    visibility: [":__subpackages__"],
+    license_kinds: [
+        "SPDX-license-identifier-Apache-2.0",
+        "SPDX-license-identifier-BSD",
+        "SPDX-license-identifier-MIT",
+        "SPDX-license-identifier-NCSA",
+    ],
+    license_text: [
+        "LICENSE.TXT",
+        "NOTICE",
+    ],
+}
+
 cc_defaults {
     name: "clang-defaults",
     defaults: [
diff --git a/lib/ARCMigrate/Android.bp b/lib/ARCMigrate/Android.bp
index 3a799ae..5d2c7f9 100644
--- a/lib/ARCMigrate/Android.bp
+++ b/lib/ARCMigrate/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangARCMigrate",
     defaults: ["clang-defaults"],
diff --git a/lib/AST/Android.bp b/lib/AST/Android.bp
index 5579bb5..6618768 100644
--- a/lib/AST/Android.bp
+++ b/lib/AST/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangAST",
     defaults: ["clang-defaults"],
diff --git a/lib/ASTMatchers/Android.bp b/lib/ASTMatchers/Android.bp
index dbdf173..09e6754 100644
--- a/lib/ASTMatchers/Android.bp
+++ b/lib/ASTMatchers/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangASTMatchers",
     defaults: ["clang-defaults"],
diff --git a/lib/Analysis/Android.bp b/lib/Analysis/Android.bp
index cb9300c..0fe899a 100644
--- a/lib/Analysis/Android.bp
+++ b/lib/Analysis/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangAnalysis",
     defaults: ["clang-defaults"],
diff --git a/lib/Android.bp b/lib/Android.bp
index b44c296..99b29ff 100644
--- a/lib/Android.bp
+++ b/lib/Android.bp
@@ -1 +1,11 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-MIT
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 subdirs = ["*"]
diff --git a/lib/Basic/Android.bp b/lib/Basic/Android.bp
index e2318a1..166dc1b 100644
--- a/lib/Basic/Android.bp
+++ b/lib/Basic/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangBasic",
     defaults: ["clang-defaults"],
diff --git a/lib/CodeGen/Android.bp b/lib/CodeGen/Android.bp
index ca1bce0..3b64065 100644
--- a/lib/CodeGen/Android.bp
+++ b/lib/CodeGen/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangCodeGen",
     defaults: ["clang-defaults"],
diff --git a/lib/Driver/Android.bp b/lib/Driver/Android.bp
index 5e6858d..b58748f 100644
--- a/lib/Driver/Android.bp
+++ b/lib/Driver/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangDriver",
     defaults: ["clang-defaults"],
diff --git a/lib/Edit/Android.bp b/lib/Edit/Android.bp
index ec7e358..f6569e9 100644
--- a/lib/Edit/Android.bp
+++ b/lib/Edit/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangEdit",
     defaults: ["clang-defaults"],
diff --git a/lib/Format/Android.bp b/lib/Format/Android.bp
index c61e5bb..40a6cd1 100644
--- a/lib/Format/Android.bp
+++ b/lib/Format/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangFormat",
     defaults: ["clang-defaults"],
diff --git a/lib/Frontend/Android.bp b/lib/Frontend/Android.bp
index ab539cf..1bb9b39 100644
--- a/lib/Frontend/Android.bp
+++ b/lib/Frontend/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangFrontend",
     defaults: ["clang-defaults"],
diff --git a/lib/Frontend/Rewrite/Android.bp b/lib/Frontend/Rewrite/Android.bp
index 6508a12..fcdd04b 100644
--- a/lib/Frontend/Rewrite/Android.bp
+++ b/lib/Frontend/Rewrite/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangRewriteFrontend",
     defaults: ["clang-defaults"],
diff --git a/lib/FrontendTool/Android.bp b/lib/FrontendTool/Android.bp
index 4d63425..0e33bbc 100644
--- a/lib/FrontendTool/Android.bp
+++ b/lib/FrontendTool/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_host_static {
     name: "libclangFrontendTool",
     defaults: ["clang-defaults"],
diff --git a/lib/Index/Android.bp b/lib/Index/Android.bp
index b1e9306..255f02e 100644
--- a/lib/Index/Android.bp
+++ b/lib/Index/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangIndex",
     defaults: ["clang-defaults"],
diff --git a/lib/Lex/Android.bp b/lib/Lex/Android.bp
index c8a8bd8..8e9bd79 100644
--- a/lib/Lex/Android.bp
+++ b/lib/Lex/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangLex",
     defaults: ["clang-defaults"],
diff --git a/lib/Parse/Android.bp b/lib/Parse/Android.bp
index 4bc2b7c..4687f1d 100644
--- a/lib/Parse/Android.bp
+++ b/lib/Parse/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangParse",
     defaults: ["clang-defaults"],
diff --git a/lib/Rewrite/Android.bp b/lib/Rewrite/Android.bp
index ea657e2..e6b556d 100644
--- a/lib/Rewrite/Android.bp
+++ b/lib/Rewrite/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangRewrite",
     defaults: ["clang-defaults"],
diff --git a/lib/Sema/Android.bp b/lib/Sema/Android.bp
index 02c0dda..13ca9d6 100644
--- a/lib/Sema/Android.bp
+++ b/lib/Sema/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangSema",
     defaults: ["clang-defaults"],
diff --git a/lib/Serialization/Android.bp b/lib/Serialization/Android.bp
index 5f3762f..6f49ce8 100644
--- a/lib/Serialization/Android.bp
+++ b/lib/Serialization/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangSerialization",
     defaults: ["clang-defaults"],
diff --git a/lib/StaticAnalyzer/Android.bp b/lib/StaticAnalyzer/Android.bp
index b44c296..4fe1a8c 100644
--- a/lib/StaticAnalyzer/Android.bp
+++ b/lib/StaticAnalyzer/Android.bp
@@ -1 +1,10 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 subdirs = ["*"]
diff --git a/lib/StaticAnalyzer/Checkers/Android.bp b/lib/StaticAnalyzer/Checkers/Android.bp
index 4213615..0880b0c 100644
--- a/lib/StaticAnalyzer/Checkers/Android.bp
+++ b/lib/StaticAnalyzer/Checkers/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_host_static {
     name: "libclangStaticAnalyzerCheckers",
     defaults: ["clang-defaults"],
diff --git a/lib/StaticAnalyzer/Checkers/MPI-Checker/Android.bp b/lib/StaticAnalyzer/Checkers/MPI-Checker/Android.bp
index 1e0a78d..dafa1c9 100644
--- a/lib/StaticAnalyzer/Checkers/MPI-Checker/Android.bp
+++ b/lib/StaticAnalyzer/Checkers/MPI-Checker/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangStaticAnalyzerMPIChecker",
     defaults: ["clang-defaults"],
diff --git a/lib/StaticAnalyzer/Core/Android.bp b/lib/StaticAnalyzer/Core/Android.bp
index 80f3912..74859ac 100644
--- a/lib/StaticAnalyzer/Core/Android.bp
+++ b/lib/StaticAnalyzer/Core/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_host_static {
     name: "libclangStaticAnalyzerCore",
     defaults: ["clang-defaults"],
diff --git a/lib/StaticAnalyzer/Frontend/Android.bp b/lib/StaticAnalyzer/Frontend/Android.bp
index 975d3a4..bec40c6 100644
--- a/lib/StaticAnalyzer/Frontend/Android.bp
+++ b/lib/StaticAnalyzer/Frontend/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_host_static {
     name: "libclangStaticAnalyzerFrontend",
     defaults: ["clang-defaults"],
diff --git a/lib/Tooling/Android.bp b/lib/Tooling/Android.bp
index 118eece..cff0e4a 100644
--- a/lib/Tooling/Android.bp
+++ b/lib/Tooling/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangTooling",
     defaults: ["clang-defaults"],
diff --git a/lib/Tooling/Core/Android.bp b/lib/Tooling/Core/Android.bp
index 517b9bb..dfd3a70 100644
--- a/lib/Tooling/Core/Android.bp
+++ b/lib/Tooling/Core/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangToolingCore",
     defaults: ["clang-defaults"],
diff --git a/soong/Android.bp b/soong/Android.bp
index fecbf7b..06dae747 100644
--- a/soong/Android.bp
+++ b/soong/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-Apache-2.0
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 bootstrap_go_package {
     name: "soong-clang",
     pkgPath: "android/soong/external/clang",
diff --git a/tools/libclang/Android.bp b/tools/libclang/Android.bp
index a55cbcf..67dcb6b 100644
--- a/tools/libclang/Android.bp
+++ b/tools/libclang/Android.bp
@@ -1,3 +1,12 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_library_static {
     name: "libclangLibclang",
     defaults: ["clang-defaults"],
diff --git a/utils/TableGen/Android.bp b/utils/TableGen/Android.bp
index c42a7a0..6bfbce7 100644
--- a/utils/TableGen/Android.bp
+++ b/utils/TableGen/Android.bp
@@ -1,3 +1,13 @@
+package {
+    // See: http://go/android-license-faq
+    // A large-scale-change added 'default_applicable_licenses' to import
+    // all of the 'license_kinds' from "external_clang_license"
+    // to get the below license kinds:
+    //   SPDX-license-identifier-MIT
+    //   SPDX-license-identifier-NCSA
+    default_applicable_licenses: ["external_clang_license"],
+}
+
 cc_binary_host {
     name: "clang-tblgen",
     defaults: ["llvm-defaults"],