chore: Temporarily disable the license report generation to speed up build (#704)

* fix: using project/index generator

* fix: broken link

* chore: reformat code

* simplify generator and build fixes

* additional documentation clarify

* code format chore

* chore: reducing cr cost

* chore: remove unnecessary

* reset link configuration

* keep index doc

* disable license report by default

* reduce license because disable by default

* Change the description of build paradox

* chore: code fmt
This commit is contained in:
AndyChen 2024-01-23 19:33:33 +08:00 committed by GitHub
parent 6df4b88df4
commit 108f5d123a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
11 changed files with 106 additions and 17 deletions

View file

@ -35,7 +35,7 @@ jobs:
uses: coursier/setup-action@v1.3.3
- name: Create the Pekko site
run: sbt -Dpekko.genjavadoc.enabled=true "Javaunidoc/doc; Compile/unidoc; docs/paradox"
run: sbt -Dpekko.genjavadoc.enabled=true -Dpekko.genlicensereport.enabled=true "Javaunidoc/doc; Compile/unidoc; docs/paradox"
- name: Run Link Validator
run: cs launch net.runne::site-link-validator:0.2.2 -- scripts/link-validator.conf

View file

@ -55,7 +55,7 @@ jobs:
# TODO come up with a better way to control the version, possibly based on git tags
- name: Build Documentation
run: |-
sbt -Dpekko.genjavadoc.enabled=true "set ThisBuild / version := \"1.0.2\"; docs/paradox; unidoc"
sbt -Dpekko.genjavadoc.enabled=true -Dpekko.genlicensereport.enabled=true "set ThisBuild / version := \"1.0.2\"; docs/paradox; unidoc"
# Create directory structure upfront since rsync does not create intermediate directories otherwise
- name: Create directory structure

View file

@ -65,4 +65,4 @@ jobs:
- name: Build Documentation
run: |-
sbt -Dpekko.genjavadoc.enabled=true docs/paradox unidoc
sbt -Dpekko.genjavadoc.enabled=true -Dpekko.genlicensereport.enabled=true docs/paradox unidoc

View file

@ -64,7 +64,7 @@ jobs:
- name: Build Documentation
run: |-
sbt -Dpekko.genjavadoc.enabled=true docs/paradox unidoc
sbt -Dpekko.genjavadoc.enabled=true -Dpekko.genlicensereport.enabled=true docs/paradox unidoc
# Create directory structure upfront since rsync does not create intermediate directories otherwise
- name: Create nightly directory structure

View file

@ -346,6 +346,18 @@ sbt -Dpekko.genjavadoc.enabled=true Javaunidoc/doc
Which will generate JavaDoc style docs in `./target/javaunidoc/index.html`. This requires a JDK version 11 or later.
#### Changing the project information page index
In case you want to change the index of `Project Information` page, you need to change it on the
`project/ProjectIndexGenerator.scala` so it can be included in the automatic docs generation.
#### License Report Generation
By default, license report generation is disabled to improve compilation speed. You can enable it by configuring `-Dpekko.genlicensereport.enabled=true`. e.g.:
- `sbt -Dpekko.genlicensereport.enabled=true "docs/paradox"`
- `sbt -Dpekko.genlicensereport.enabled=true shell` And then `docs/paradox`
### External dependencies
All the external runtime dependencies for the project, including transitive dependencies, must have an open source license that is equal to, or compatible with, [Apache 2](https://www.apache.org/licenses/LICENSE-2.0).

View file

@ -257,6 +257,7 @@ lazy val docs = pekkoModule("docs")
PekkoParadoxPlugin,
NoPublish,
ParadoxBrowse,
ProjectIndexGenerator,
ScaladocNoVerificationOfDiagrams,
StreamOperatorsIndexGenerator,
Jdk9)

View file

@ -17,7 +17,7 @@
* [index-utilities](index-utilities.md)
* [common/other-modules](common/other-modules.md)
* [additional/deploy](additional/deploy.md)
* [project/index](project/index.md)
* [project/index](project/project-index.md)
* [classic](index-classic.md)
@@@

View file

@ -1,3 +1,4 @@
<!-- DO NOT EDIT DIRECTLY: This file is generated by `project/ProjectIndexGenerator`. See CONTRIBUTING.md for details. -->
# Project Information
@@toc { depth=2 }
@ -8,16 +9,15 @@
* [scala3](scala3.md)
* [downstream-upgrade-strategy](downstream-upgrade-strategy.md)
* [../common/may-change](../common/may-change.md)
* [ide] (../additional/ide.md)
* [lombok](immutable.md)
* [osgi](../additional/osgi.md)
* [../additional/ide](../additional/ide.md)
* [immutable](immutable.md)
* [../additional/osgi](../additional/osgi.md)
* [migration-guides](migration-guides.md)
* [rolling-update](rolling-update.md)
* [issue-tracking](issue-tracking.md)
* [licenses](licenses.md)
* [license-report](license-report.md)
* [faq](../additional/faq.md)
* [books](../additional/books.md)
* [../additional/faq](../additional/faq.md)
* [../additional/books](../additional/books.md)
* [examples](examples.md)
* [links](links.md)

View file

@ -95,10 +95,10 @@ object Paradox {
lazy val sourceGeneratorSettings = Seq(
Compile / paradoxMarkdownToHtml / sourceGenerators += Def.taskDyn {
val targetFile = (Compile / paradox / sourceManaged).value / "project" / "license-report.md"
(LocalRootProject / dumpLicenseReportAggregate).map { dir =>
IO.copy(List(dir / "pekko-root-licenses.md" -> targetFile)).toList
}
ProjectIndexGenerator.CliOptions.generateLicenseReportEnabled.ifTrue(
(LocalRootProject / dumpLicenseReportAggregate).map { dir =>
IO.copy(List(dir / "pekko-root-licenses.md" -> targetFile)).toList
}).orElse(Some(Def.task(List.empty[File]))).get
}.taskValue)
lazy val settings =

View file

@ -308,8 +308,9 @@ object PekkoBuild {
UsefulTask("sortImports", "Sort the imports"),
UsefulTask("mimaReportBinaryIssues ", "Check binary issues"),
UsefulTask("validatePullRequest ", "Validate pull request"),
UsefulTask("docs/paradox", "Build documentation (takes ~10+ minutes)"),
UsefulTask("docs/paradoxBrowse", "Browse the generated documentation (takes ~10+ minutes)"),
UsefulTask("docs/paradox", "Build documentation (license report will be generate on CI or Publish)"),
UsefulTask("docs/paradoxBrowse",
"Browse the generated documentation (license report will be generate on CI or Publish)"),
UsefulTask("tips:", "prefix commands with `+` to run against cross Scala versions."),
UsefulTask("Contributing guide:", "https://github.com/apache/incubator-pekko/blob/main/CONTRIBUTING.md")).map(
_.noAlias))

View file

@ -0,0 +1,75 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.
*/
import sbt._
import Keys._
object ProjectIndexGenerator extends AutoPlugin {
object CliOptions {
val generateLicenseReportEnabled = CliOption("pekko.genlicensereport.enabled", false)
}
override val projectSettings: Seq[Setting[_]] = inConfig(Compile)(
Seq(
resourceGenerators +=
generateIndex(sourceDirectory, _ / "paradox" / "project" / "project-index.md")))
def generateIndex(dir: SettingKey[File], locate: File => File) = Def.task[Seq[File]] {
val file = locate(dir.value)
val markdownFilesBeforeLicense = Seq(
"../common/binary-compatibility-rules.md",
"scala3.md",
"downstream-upgrade-strategy.md",
"../common/may-change.md",
"../additional/ide.md",
"immutable.md",
"../additional/osgi.md",
"migration-guides.md",
"rolling-update.md",
"issue-tracking.md",
"licenses.md")
val markdownFilesAfterLicense = Seq(
"../additional/faq.md",
"../additional/books.md",
"examples.md",
"links.md")
val markdownFiles = if (CliOptions.generateLicenseReportEnabled.get) {
markdownFilesBeforeLicense ++ Seq("license-report.md") ++ markdownFilesAfterLicense
} else {
markdownFilesBeforeLicense ++ markdownFilesAfterLicense
}
val content =
s"""<!-- DO NOT EDIT DIRECTLY: This file is generated by `project/ProjectIndexGenerator`. See CONTRIBUTING.md for details. -->
|# Project Information
|
|@@toc { depth=2 }
|
|@@@ index
|
|${markdownFiles.map(f => s"* [${f.replace(".md", "")}]($f)").mkString("\n")}
|
|@@@
|""".stripMargin
if (!file.exists || IO.read(file) != content) IO.write(file, content)
Seq(file)
}
}