Fix Javadoc generation + Javadoc
------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=190916130
This commit is contained in:
parent
f634b1d4d8
commit
2b9b2510dc
@ -11,6 +11,8 @@
|
|||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
apply from: "${rootDir}/javadoc_util.gradle"
|
||||||
|
|
||||||
class CombinedJavadocPlugin implements Plugin<Project> {
|
class CombinedJavadocPlugin implements Plugin<Project> {
|
||||||
|
|
||||||
static final String TASK_NAME = "generateCombinedJavadoc"
|
static final String TASK_NAME = "generateCombinedJavadoc"
|
||||||
@ -20,29 +22,35 @@ class CombinedJavadocPlugin implements Plugin<Project> {
|
|||||||
project.gradle.projectsEvaluated {
|
project.gradle.projectsEvaluated {
|
||||||
Set<Project> libraryModules = getLibraryModules(project)
|
Set<Project> libraryModules = getLibraryModules(project)
|
||||||
if (!libraryModules.isEmpty()) {
|
if (!libraryModules.isEmpty()) {
|
||||||
String sdkDirectory = getSdkDirectory(libraryModules)
|
|
||||||
project.task(TASK_NAME, type: Javadoc) {
|
project.task(TASK_NAME, type: Javadoc) {
|
||||||
description = "Generates combined Javadoc."
|
description = "Generates combined Javadoc."
|
||||||
title = "ExoPlayer library"
|
title = "ExoPlayer library"
|
||||||
source = libraryModules.generateJavadoc.source
|
source = libraryModules.generateJavadoc.source
|
||||||
classpath = project.files(libraryModules.generateJavadoc.classpath)
|
classpath = project.files([])
|
||||||
destinationDir = project.file("$project.buildDir/docs/javadoc")
|
destinationDir = project.file("$project.buildDir/docs/javadoc")
|
||||||
options {
|
options {
|
||||||
links "http://docs.oracle.com/javase/7/docs/api/"
|
links "https://docs.oracle.com/javase/7/docs/api/",
|
||||||
linksOffline "https://developer.android.com/reference",
|
"https://developer.android.com/reference"
|
||||||
"${sdkDirectory}/docs/reference"
|
|
||||||
encoding = "UTF-8"
|
encoding = "UTF-8"
|
||||||
}
|
}
|
||||||
exclude "**/BuildConfig.java"
|
exclude "**/BuildConfig.java"
|
||||||
exclude "**/R.java"
|
exclude "**/R.java"
|
||||||
doLast {
|
doFirst {
|
||||||
libraryModules.each { libraryModule ->
|
libraryModules.each { libraryModule ->
|
||||||
project.copy {
|
libraryModule.android.libraryVariants.all { variant ->
|
||||||
from "${libraryModule.projectDir}/src/main/javadoc"
|
def name = variant.buildType.name
|
||||||
into "${project.buildDir}/docs/javadoc"
|
if (name.equals("release")) {
|
||||||
|
classpath +=
|
||||||
|
libraryModule.project.files(
|
||||||
|
variant.javaCompile.classpath.files,
|
||||||
|
libraryModule.project.android.getBootClasspath())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
doLast {
|
||||||
|
project.javadocFixLinks()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -56,12 +64,6 @@ class CombinedJavadocPlugin implements Plugin<Project> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns the Android SDK directory given a set of Android library modules.
|
|
||||||
private String getSdkDirectory(Set<Project> libraryModules) {
|
|
||||||
// We can retrieve the Android SDK directory from any module.
|
|
||||||
return libraryModules.iterator().next().android.sdkDirectory
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
apply plugin: CombinedJavadocPlugin
|
apply plugin: CombinedJavadocPlugin
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
// See the License for the specific language governing permissions and
|
// See the License for the specific language governing permissions and
|
||||||
// limitations under the License.
|
// limitations under the License.
|
||||||
|
apply from: "${rootDir}/javadoc_util.gradle"
|
||||||
|
|
||||||
android.libraryVariants.all { variant ->
|
android.libraryVariants.all { variant ->
|
||||||
def name = variant.buildType.name
|
def name = variant.buildType.name
|
||||||
if (!name.equals("release")) {
|
if (!name.equals("release")) {
|
||||||
@ -23,7 +25,7 @@ android.libraryVariants.all { variant ->
|
|||||||
options {
|
options {
|
||||||
links "http://docs.oracle.com/javase/7/docs/api/"
|
links "http://docs.oracle.com/javase/7/docs/api/"
|
||||||
linksOffline "https://developer.android.com/reference",
|
linksOffline "https://developer.android.com/reference",
|
||||||
"${android.sdkDirectory}/docs/reference"
|
"${android.sdkDirectory}/docs/reference"
|
||||||
encoding = "UTF-8"
|
encoding = "UTF-8"
|
||||||
}
|
}
|
||||||
exclude "**/BuildConfig.java"
|
exclude "**/BuildConfig.java"
|
||||||
@ -35,10 +37,7 @@ android.libraryVariants.all { variant ->
|
|||||||
project.android.getBootClasspath())
|
project.android.getBootClasspath())
|
||||||
}
|
}
|
||||||
doLast {
|
doLast {
|
||||||
copy {
|
project.javadocFixLinks()
|
||||||
from "src/main/javadoc"
|
|
||||||
into "$buildDir/docs/javadoc"
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
31
javadoc_util.gradle
Normal file
31
javadoc_util.gradle
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
// Copyright (C) 2018 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
ext.javadocFixLinks = {
|
||||||
|
// Fix external Android links to target the top frame.
|
||||||
|
def androidRoot = "https://developer.android.com/reference/"
|
||||||
|
def androidLink = "<a href=\"(${androidRoot}.*?)\\?is-external=true\""
|
||||||
|
def androidFixed = "<a href=\"\\1\" target=\"_top\""
|
||||||
|
ant.replaceregexp(
|
||||||
|
match:androidLink, replace:androidFixed, flags:'g', byline:true) {
|
||||||
|
fileset(dir: "${project.buildDir}/docs/javadoc")
|
||||||
|
}
|
||||||
|
// Fix external Oracle links to use frames and target the top frame.
|
||||||
|
def oracleRoot = "https://docs.oracle.com/javase/7/docs/api/"
|
||||||
|
def oracleLink = "<a href=\"(${oracleRoot})(.*?)\\?is-external=true\""
|
||||||
|
def oracleFixed = "<a href=\"\\1/index.html\\?\\2\" target=\"_top\""
|
||||||
|
ant.replaceregexp(
|
||||||
|
match:oracleLink, replace:oracleFixed, flags:'g', byline:true) {
|
||||||
|
fileset(dir: "${project.buildDir}/docs/javadoc")
|
||||||
|
}
|
||||||
|
}
|
@ -475,9 +475,9 @@ public final class DownloadManager {
|
|||||||
* <p>Transition diagram:
|
* <p>Transition diagram:
|
||||||
*
|
*
|
||||||
* <pre>
|
* <pre>
|
||||||
* -> canceled
|
* -> canceled
|
||||||
* queued <-> started -> ended
|
* queued <-> started -> ended
|
||||||
* -> error
|
* -> error
|
||||||
* </pre>
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@Retention(RetentionPolicy.SOURCE)
|
@Retention(RetentionPolicy.SOURCE)
|
||||||
|
@ -498,8 +498,8 @@ public class PlayerNotificationManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets whether the notification should be colorized (whether the notification color should be
|
* Sets whether the notification should be colorized. When set, the color set with {@link
|
||||||
* applied).
|
* setColor(int)} will be used as the background color for the notification.
|
||||||
*
|
*
|
||||||
* <p>See {@link NotificationCompat.Builder#setColorized(boolean)}.
|
* <p>See {@link NotificationCompat.Builder#setColorized(boolean)}.
|
||||||
*
|
*
|
||||||
@ -527,14 +527,11 @@ public class PlayerNotificationManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the color of the notification as a color value like for instance solid {@link
|
* Sets the accent color of the notification.
|
||||||
* Color#BLACK)}. When set to {@link Color#TRANSPARENT} and a large icon is provided the
|
|
||||||
* notification is colored with a color taken from the palette if the icon (when a media session
|
|
||||||
* token is provided).
|
|
||||||
*
|
*
|
||||||
* <p>See {@link NotificationCompat.Builder#setColor(int)}.
|
* <p>See {@link NotificationCompat.Builder#setColor(int)}.
|
||||||
*
|
*
|
||||||
* @param color The color.
|
* @param color The color, in ARGB integer form like the constants in {@link Color}.
|
||||||
*/
|
*/
|
||||||
public final void setColor(int color) {
|
public final void setColor(int color) {
|
||||||
if (this.color != color) {
|
if (this.color != color) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user