forked from typelevel/sbt-typelevel
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request typelevel#126 from armanbilge/integration/0.4-main
Merge 0.4 to main
- Loading branch information
Showing
33 changed files
with
304 additions
and
181 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
# Customization | ||
|
||
The complete list of plugins, settings, and utilities is given below. The **sbt-typelevel-ci-release** and **sbt-typelevel** super-plugins automatically load most of them. The diagram at the bottom of the page shows their inter-dependencies. | ||
|
||
Instead of using the super-plugins, for finer-grained control you can always add plugins individually to your project and even build your own custom super-plugin. | ||
|
||
## Modules | ||
|
||
### sbt-typelevel-no-publish | ||
- `NoPublishPlugin` | ||
|
||
### sbt-typelevel-kernel | ||
- `TypelevelKernelPlugin` | ||
- `tlIsScala3` (setting): true if `scalaVersion` is 3.x | ||
- `tlReplaceCommandAlias` (method): replace a `addCommandAlias` definition | ||
- `tlReleaseLocal` (command): alias for `+publishLocal` | ||
|
||
### sbt-typelevel-versioning | ||
- `TypelevelVersioningPlugin`: Establishes a git-based, early semantic versioning scheme | ||
- `tlBaseVersion` (setting): the series your project is in. e.g., 0.2, 3.5 | ||
- `tlUntaggedAreSnapshots` (setting): If true, an untagged commit is given a snapshot version, e.g. `0.4.1-17-00218f9-SNAPSHOT`. If false, it is given a release version, e.g. `0.4.1-17-00218f9`. (default: true) | ||
|
||
### sbt-typelevel-mima | ||
- `TypelevelMimaPlugin`: Determines previous MiMa artifacts via your `version` setting and git tags. | ||
- `tlVersionIntroduced` (setting): A map `scalaBinaryVersion -> version` e.g. `Map("2.13" -> "1.5.2", "3" -> "1.7.1")` used to indicate that a particular `crossScalaVersions` value was introduced in a given version (default: empty). | ||
|
||
### sbt-typelevel-sonatype | ||
- `TypelevelSonatypePlugin`: Sets up publishing to Sonatype/Maven. | ||
- `tlRelease` (command): check binary-compatibility and `+publish` to Sonatype | ||
- `tlSonatypeUseLegacyHost` (setting): publish to `oss.sonatype.org` instead of `s01.oss.sonatype.org` (default: true) | ||
|
||
### sbt-typelevel-settings | ||
- `TypelevelSettingsPlugin`: Good and/or opinionated defaults for scalac settings etc., inspired by sbt-tpolecat. | ||
- `tlFatalWarnings` (setting): Convert compiler warnings into errors (default: false). | ||
|
||
### sbt-typelevel-github | ||
- `TypelevelGitHubPlugin`: Populates boilerplate settings assuming you are using GitHub. | ||
- `TypelevelScalaJSGitHubPlugin`: Points your sourcemaps to GitHub permalinks. Only activated for Scala.js projects. | ||
- `tlGitHubDev(user, fullName)` (method): Helper to create a `Developer` entry from a GitHub username. | ||
|
||
### sbt-typelevel-ci | ||
- `TypelevelCiPlugin`: Sets up GitHub actions to run tests and check binary-compatibility in CI. | ||
- `tlCrossRootProject` (method): helper to create a `root` project that can aggregate both `Project`s and `CrossProject`s. Automatically creates separate jobs in the CI matrix for each platform (JVM, JS, etc.). | ||
|
||
### sbt-typelevel-sonatype-ci-release | ||
- `TypelevelSonatypeCiReleasePlugin`: Sets up GitHub actions to publish to Sonatype in CI. | ||
- Requires the `SONATYPE_USERNAME` and `SONATYPE_PASSWORD` secrets | ||
- `tlCiReleaseTags` (setting): Controls whether or not v-prefixed tags should be released from CI (default true). | ||
- `tlCiReleaseBranches`: The branches in your repository to release from in CI on every push. Depending on your versioning scheme, they will be either snapshots or (hash) releases. Leave this empty if you only want CI releases for tags. (default: `[]`). | ||
|
||
### sbt-typelevel-ci-signing | ||
- `TypelevelCiSigningPlugin`: Sets up GitHub actions to sign your artifacts in CI. | ||
- Requires `PGP_SECRET` secret, with your base64-encoded PGP key | ||
- Optionally set the `PGP_PASSPHRASE` secret, but we do not recommend passphrase-protected keys for new projects. See discussion in [#9](https://github.com/typelevel/sbt-typelevel/discussions/9#discussioncomment-1251774). | ||
|
||
### sbt-typelevel-ci-release | ||
- `TypelevelCiReleasePlugin`: The super-plugin that sets you up with versioning, mima, signing, and sonatype publishing, all in GitHub actions. | ||
|
||
### sbt-typelevel | ||
- `TypelevelPlugin`: The super-super-plugin intended for bootstrapping the typical Typelevel project. Sets up CI release including snapshots, scalac settings, headers, and formatting. | ||
- `tlFatalWarningsInCi` (setting): Convert compiler warnings into errors under CI builds (default: true). | ||
|
||
### sbt-typelevel-site | ||
- `TypelevelSitePlugin`: Sets up an [mdoc](https://scalameta.org/mdoc/)/[Laika](https://planet42.github.io/Laika/)-generated microsite, automatically published to GitHub pages in CI. | ||
- `tlSitePublishBranch` (setting): The branch to publish the site from on every push. Set this to `None` if you only want to update the site on tag releases. (default: `main`) | ||
- `tlSiteApiUrl` (setting): URL to the API docs. (default: `None`) | ||
- `tlSiteHeliumConfig` (setting): the Laika Helium config. (default: how the sbt-typelevel site looks) | ||
|
||
## Dependency diagram | ||
|
||
sbt-typelevel plugins are in red and the super-plugins are boxed. | ||
|
||
<a href="plugins.svg"><img src="plugins.svg" style="width: 100%"/></a> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
laika.navigationOrder = [ | ||
index.md | ||
faq.md | ||
customization.md | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,86 @@ | ||
# FAQ | ||
|
||
## How do I cut a release? | ||
|
||
Create a release on GitHub with a v-prefixed, semantically-versioned tag (or, tag a commit locally and push to GitHub). This will start a CI release. Example tags: `v0.4.2`, `v1.2.3`, `v1.0.0-M1`, `v1.2.0-RC2`. | ||
|
||
It is also possible to run the release process entirely locally by invoking the `tlRelease` command, assuming that you have correctly configured your PGP keys and Sonatype credentials. | ||
|
||
## How do I introduce breaking changes intended for my next version? | ||
|
||
Bump your `tlBaseVersion` to the next breaking-version according to early-semver, e.g. 0.7 to 0.8 or 4.2 to 5.0. | ||
|
||
## How do I indicate the first version that I published Scala 3 artifacts for? | ||
|
||
```scala | ||
ThisBuild / tlVersionIntroduced := Map("3" -> "0.4.2") | ||
``` | ||
|
||
## How do I locally prepare my PR for CI? | ||
|
||
**sbt-typelevel** comes with a `prePR` command, which updates the GitHub workflow, generates headers, runs `scalafmt`, and clean compiles your code. | ||
|
||
## How do I disable fatal warnings in CI? | ||
|
||
If you are using **sbt-typelevel** fatal warnings are on by default in CI. | ||
|
||
```scala | ||
ThisBuild / tlFatalWarningsInCi := false | ||
``` | ||
|
||
If you are only using **sbt-typelevel-ci-release**, you are completely in charge of your own `scalacOptions`, including fatal warnings. | ||
|
||
## How do I publish snapshots in CI? | ||
|
||
```scala | ||
// any branches you want snapshots of | ||
ThisBuild / tlCiReleaseBranches := Seq("main") | ||
``` | ||
|
||
Make sure to `reload` sbt and run `githubWorkflowGenerate` after making a change to this setting. | ||
|
||
## What happens if I push a tag and commit at the same time? | ||
|
||
It Just Works™. | ||
|
||
## How do I split my CI matrix into separate jobs for JVM, JS, etc? | ||
|
||
```scala | ||
// Before | ||
val root = project.in(file(".")) | ||
.enablePlugins(NoPublishPlugin) | ||
.aggregate( | ||
coreJVM, | ||
coreJS, | ||
io.jvm, | ||
node.js, | ||
io.js, | ||
scodec.jvm, | ||
scodec.js, | ||
protocols.jvm, | ||
protocols.js, | ||
reactiveStreams, | ||
benchmark | ||
) | ||
|
||
// After | ||
val root = tlCrossRootProject | ||
.aggregate(core, io, node, scodec, protocols, reactiveStreams, benchmark) | ||
``` | ||
|
||
## How do I publish to `s01.oss.sonatype.org`? | ||
```scala | ||
ThisBuild / tlSonatypeUseLegacyHost := false | ||
``` | ||
|
||
## How do I publish a site like this one? | ||
|
||
```scala | ||
// project/plugins.sbt | ||
addSbtPlugin("org.typelevel" % "sbt-typelevel-site" % "@VERSION@") | ||
// build.sbt | ||
ThisBuild / tlSitePublishBranch := Some("main") // deploy docs from this branch | ||
lazy val docs = project.in(file("site")).enablePlugins(TypelevelSitePlugin) | ||
``` | ||
|
||
Place your `.md` files in the `docs/` directory of your project. The site is generated using [mdoc](https://scalameta.org/mdoc/) and [Laika](https://planet42.github.io/Laika/) and published to the `gh-pages` branch on every push to the specified branch. Make sure to enable GitHub pages in your repo settings. To preview locally, run `docs/mdoc` and then `docs/laikaPreview`. |
Oops, something went wrong.