| 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 | 6237092 | 2021-05-23 16:55:37 +0100 | [diff] [blame] | 86 |  | 
|  | 87 | // The output may not be set if the bootclasspath_fragment has not yet been updated to support | 
|  | 88 | // hidden API processing. | 
|  | 89 | // TODO(b/179354495): Switch back to append once all bootclasspath_fragment modules have been | 
|  | 90 | //  updated to support hidden API processing properly. | 
|  | 91 | appendIfNotNil := func(paths android.Paths, path android.Path) android.Paths { | 
|  | 92 | if path == nil { | 
|  | 93 | return paths | 
|  | 94 | } | 
|  | 95 | return append(paths, path) | 
|  | 96 | } | 
|  | 97 | i.StubFlagsPaths = appendIfNotNil(i.StubFlagsPaths, other.StubFlagsPath) | 
|  | 98 | i.AnnotationFlagsPaths = appendIfNotNil(i.AnnotationFlagsPaths, other.AnnotationFlagsPath) | 
|  | 99 | i.MetadataPaths = appendIfNotNil(i.MetadataPaths, other.MetadataPath) | 
|  | 100 | i.IndexPaths = appendIfNotNil(i.IndexPaths, other.IndexPath) | 
|  | 101 | i.AllFlagsPaths = appendIfNotNil(i.AllFlagsPaths, other.AllFlagsPath) | 
| Paul Duffin | 438eb57 | 2021-05-21 16:58:23 +0100 | [diff] [blame] | 102 | } | 
|  | 103 |  | 
|  | 104 | // dedup removes duplicates in all the paths, while maintaining the order in which they were | 
|  | 105 | // appended. | 
|  | 106 | func (i *MonolithicHiddenAPIInfo) dedup() { | 
|  | 107 | i.FlagsFilesByCategory.dedup() | 
|  | 108 | i.StubFlagsPaths = android.FirstUniquePaths(i.StubFlagsPaths) | 
|  | 109 | i.AnnotationFlagsPaths = android.FirstUniquePaths(i.AnnotationFlagsPaths) | 
|  | 110 | i.MetadataPaths = android.FirstUniquePaths(i.MetadataPaths) | 
|  | 111 | i.IndexPaths = android.FirstUniquePaths(i.IndexPaths) | 
|  | 112 | i.AllFlagsPaths = android.FirstUniquePaths(i.AllFlagsPaths) | 
|  | 113 | } | 
|  | 114 |  | 
| Paul Duffin | 524c82c | 2021-06-09 14:39:28 +0100 | [diff] [blame] | 115 | var MonolithicHiddenAPIInfoProvider = blueprint.NewProvider(MonolithicHiddenAPIInfo{}) |