Allow modules to override --error-when-new UnflaggedApi

Some `java_sdk_library` and `droidstubs` modules already specify
`--error UnflaggedApi` but they are currently ignored because they are
added before the `--error-when-new UnflaggedApi` automatically added by
Soong and Metalava uses the last setting. That means adding
`--error-when-new UnflaggedApi` in change https://r.android.com/3248013
actually reduced the severity of the issue for those modules making it
more likely that they would be missed.

This change only adds the `--error-when-new UnflaggedApi` if it does
not already appear in the metalava command.

Bug: 361582214
Test: m checkapi
Change-Id: I499183276c7520605cca7acc6e6e9ab535feaa86
This commit is contained in:
Paul Duffin
2024-08-29 15:35:58 +01:00
parent 88d3b39846
commit 3001ce3bf5

View File

@@ -970,10 +970,14 @@ func (d *Droidstubs) everythingOptionalCmd(ctx android.ModuleContext, cmd *andro
d.apiLintReport = android.PathForModuleOut(ctx, Everything.String(), "api_lint_report.txt")
cmd.FlagWithOutput("--report-even-if-suppressed ", d.apiLintReport) // TODO: Change to ":api-lint"
// Make sure that existing UnflaggedApi issues are reported as warnings but issues in
// new/changed code are treated as errors by the Build Warnings Aye Aye Analyzer in Gerrit.
// If UnflaggedApi issues have not already been configured then make sure that existing
// UnflaggedApi issues are reported as warnings but issues in new/changed code are treated as
// errors by the Build Warnings Aye Aye Analyzer in Gerrit.
// Once existing issues have been fixed this will be changed to error.
cmd.Flag("--error-when-new UnflaggedApi")
// TODO(b/362771529): Switch to --error
if !strings.Contains(cmd.String(), " UnflaggedApi ") {
cmd.Flag("--error-when-new UnflaggedApi")
}
// TODO(b/154317059): Clean up this allowlist by baselining and/or checking in last-released.
if d.Name() != "android.car-system-stubs-docs" &&