Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 1 | // Copyright (C) 2021 The Android Open Source Project |
| 2 | // |
| 3 | // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | // you may not use this file except in compliance with the License. |
| 5 | // You may obtain a copy of the License at |
| 6 | // |
| 7 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | // |
| 9 | // Unless required by applicable law or agreed to in writing, software |
| 10 | // distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | // See the License for the specific language governing permissions and |
| 13 | // limitations under the License. |
| 14 | |
| 15 | package java |
| 16 | |
| 17 | import ( |
| 18 | "android/soong/android" |
| 19 | "github.com/google/blueprint" |
| 20 | ) |
| 21 | |
| 22 | // MonolithicHiddenAPIInfo contains information needed/provided by the hidden API generation of the |
| 23 | // monolithic hidden API files. |
| 24 | // |
| 25 | // Each list of paths includes all the equivalent paths from each of the bootclasspath_fragment |
| 26 | // modules that contribute to the platform-bootclasspath. |
| 27 | type MonolithicHiddenAPIInfo struct { |
| 28 | // FlagsFilesByCategory maps from the flag file category to the paths containing information for |
| 29 | // that category. |
| 30 | FlagsFilesByCategory FlagFilesByCategory |
| 31 | |
| 32 | // The paths to the generated stub-flags.csv files. |
| 33 | StubFlagsPaths android.Paths |
| 34 | |
| 35 | // The paths to the generated annotation-flags.csv files. |
| 36 | AnnotationFlagsPaths android.Paths |
| 37 | |
| 38 | // The paths to the generated metadata.csv files. |
| 39 | MetadataPaths android.Paths |
| 40 | |
| 41 | // The paths to the generated index.csv files. |
| 42 | IndexPaths android.Paths |
| 43 | |
| 44 | // The paths to the generated all-flags.csv files. |
| 45 | AllFlagsPaths android.Paths |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 46 | |
| 47 | // The classes jars from the libraries on the platform bootclasspath. |
| 48 | ClassesJars android.Paths |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 49 | } |
| 50 | |
| 51 | // newMonolithicHiddenAPIInfo creates a new MonolithicHiddenAPIInfo from the flagFilesByCategory |
| 52 | // plus information provided by each of the fragments. |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 53 | func newMonolithicHiddenAPIInfo(ctx android.ModuleContext, flagFilesByCategory FlagFilesByCategory, classpathElements ClasspathElements) MonolithicHiddenAPIInfo { |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 54 | monolithicInfo := MonolithicHiddenAPIInfo{} |
| 55 | |
| 56 | monolithicInfo.FlagsFilesByCategory = flagFilesByCategory |
| 57 | |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 58 | // Merge all the information from the classpathElements. The fragments form a DAG so it is possible that |
| 59 | // this will introduce duplicates so they will be resolved after processing all the classpathElements. |
| 60 | for _, element := range classpathElements { |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 61 | switch e := element.(type) { |
| 62 | case *ClasspathLibraryElement: |
Paul Duffin | d6a072b | 2021-07-20 19:04:46 +0100 | [diff] [blame] | 63 | classesJars := retrieveClassesJarsFromModule(e.Module()) |
| 64 | monolithicInfo.ClassesJars = append(monolithicInfo.ClassesJars, classesJars...) |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 65 | |
| 66 | case *ClasspathFragmentElement: |
| 67 | fragment := e.Module() |
| 68 | if ctx.OtherModuleHasProvider(fragment, HiddenAPIInfoProvider) { |
| 69 | info := ctx.OtherModuleProvider(fragment, HiddenAPIInfoProvider).(HiddenAPIInfo) |
| 70 | monolithicInfo.append(&info) |
Paul Duffin | d6a072b | 2021-07-20 19:04:46 +0100 | [diff] [blame] | 71 | } else { |
| 72 | ctx.ModuleErrorf("%s does not provide hidden API information", fragment) |
Paul Duffin | 89f570a | 2021-06-16 01:42:33 +0100 | [diff] [blame] | 73 | } |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 74 | } |
| 75 | } |
| 76 | |
| 77 | // Dedup paths. |
| 78 | monolithicInfo.dedup() |
| 79 | |
| 80 | return monolithicInfo |
| 81 | } |
| 82 | |
| 83 | // append appends all the files from the supplied info to the corresponding files in this struct. |
Paul Duffin | af99afa | 2021-05-21 22:18:56 +0100 | [diff] [blame] | 84 | func (i *MonolithicHiddenAPIInfo) append(other *HiddenAPIInfo) { |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 85 | i.FlagsFilesByCategory.append(other.FlagFilesByCategory) |
Paul Duffin | ed12c13 | 2021-07-20 19:08:39 +0100 | [diff] [blame^] | 86 | i.StubFlagsPaths = append(i.StubFlagsPaths, other.StubFlagsPath) |
| 87 | i.AnnotationFlagsPaths = append(i.AnnotationFlagsPaths, other.AnnotationFlagsPath) |
| 88 | i.MetadataPaths = append(i.MetadataPaths, other.MetadataPath) |
| 89 | i.IndexPaths = append(i.IndexPaths, other.IndexPath) |
| 90 | i.AllFlagsPaths = append(i.AllFlagsPaths, other.AllFlagsPath) |
Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 91 | } |
| 92 | |
| 93 | // dedup removes duplicates in all the paths, while maintaining the order in which they were |
| 94 | // appended. |
| 95 | func (i *MonolithicHiddenAPIInfo) dedup() { |
| 96 | i.FlagsFilesByCategory.dedup() |
| 97 | i.StubFlagsPaths = android.FirstUniquePaths(i.StubFlagsPaths) |
| 98 | i.AnnotationFlagsPaths = android.FirstUniquePaths(i.AnnotationFlagsPaths) |
| 99 | i.MetadataPaths = android.FirstUniquePaths(i.MetadataPaths) |
| 100 | i.IndexPaths = android.FirstUniquePaths(i.IndexPaths) |
| 101 | i.AllFlagsPaths = android.FirstUniquePaths(i.AllFlagsPaths) |
| 102 | } |
| 103 | |
Paul Duffin | 524c82c | 2021-06-09 14:39:28 +0100 | [diff] [blame] | 104 | var MonolithicHiddenAPIInfoProvider = blueprint.NewProvider(MonolithicHiddenAPIInfo{}) |