Pave the way for external mainline module API annotations.

This change prepares for adding mainline mode API annotations
(@CorePlatformApi etc.) supplied in external .annotated.java files so
they are not carried as patches in ojluni source files.

No real annotations are introduced in this change, and it has no
effect on the generated stubs for any of the affected targets (except,
seemingly, a few trivial whitespace changes).

Specifically, this change does the following:

- Adds a placeholder .annotated.java file (to be removed as soon as we
  have any real ones).

- Adds a @libcore.api.Hide annotation we can use as an alternative to
  the @hide javadoc tag.

- Changes the relevant mainline module API droidstubs rules to merge
  in the .annotated.java annotations and to respect the @Hide
  annotation.

- Refactors the openjdk_java_files targets to create a new category of
  source file, those which are annotated for the mainline module APIs
  but are not part of the public API. (The alternative to doing this
  would be to move them into the public category and change all the
  public API droidstubs to merge in the .annotated.java annotations
  and to respect @Hide, which would be significantly more invasive.)

- Changes the relevant mainline module API droidstubs rules use the
  new source categories.

Bug: 115746226
Test: `make core-platform-api-stubs core-intra-stubs core-libart+oj-intra-stubs`
Change-Id: I33e80603686112d3eb5a05debb58f13764b819b6
diff --git a/JavaLibrary.bp b/JavaLibrary.bp
index 4276511..559cb74 100644
--- a/JavaLibrary.bp
+++ b/JavaLibrary.bp
@@ -78,7 +78,11 @@
 }
 
 // The set of files in core that have been marked up with @hide and API-related
-// annotations.
+// annotations. Note that this includes the intra-core and core-platform APIs as
+// well as the public APIs. Some source files in :openjdk_mmodule_extra_files
+// are annotated by applying annotation to the .annotated.java stubs files in
+// ojluni/annotated/mmodules and rather than in the original source. See the
+// comments in openjdk_java_files.bp for more details.
 filegroup {
     name: "core_api_files",
     srcs: [
@@ -88,6 +92,7 @@
         ":core_libart_api_files",
         ":core_simple_java_files",
         ":okhttp_api_files",
+        ":openjdk_mmodule_extra_files",
     ],
 }
 
@@ -489,6 +494,10 @@
     name: "ojluni-annotated-sdk-stubs",
     path: "ojluni/annotations/sdk",
 }
+droiddoc_exported_dir {
+    name: "ojluni-annotated-mmodule-stubs",
+    path: "ojluni/annotations/mmodule",
+}
 
 // A file containing the list of tags that are "known" to us from the OpenJdk
 // source code and so should not cause an error or warning.