https://github.com/alejandrohdezma/sbt-modules
SBT plugin that simplifies modules creation
https://github.com/alejandrohdezma/sbt-modules
modules sbt-plugin scala
Last synced: 3 months ago
JSON representation
SBT plugin that simplifies modules creation
- Host: GitHub
- URL: https://github.com/alejandrohdezma/sbt-modules
- Owner: alejandrohdezma
- License: apache-2.0
- Created: 2020-06-03T14:48:47.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-05-15T05:20:30.000Z (about 1 year ago)
- Last Synced: 2024-05-21T04:13:46.723Z (about 1 year ago)
- Topics: modules, sbt-plugin, scala
- Language: Scala
- Homepage:
- Size: 312 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# SBT plugin that simplifies modules creation
```diff
- skip in publish := true
-
lazy val docs = project
- .settings(skip in publish := true)
- .dependsOn(allProjects: _*)
+ .dependsOn(allModules)
.in(file("docs"))+ lazy val `my-library-core` = module
- lazy val core = project
- .in(file("modules/core"))
- .settings(name := "my-library-core")+ lazy val `my-library-plugin` = module
- lazy val plugin = project
- .in(file("modules/plugin"))
- .settings(name := "my-library-plugin")
- .dependsOn(core)
+ .dependsOn(`my-library-core`)
-
- lazy val allProjects: Seq[ClasspathDep[ProjectReference]] = Seq(
- core,
- plugin
- )
```## Installation
Add the following line to your `plugins.sbt` file:
```sbt
addSbtPlugin("com.alejandrohdezma" % "sbt-modules" % "0.3.2")
```## Usage
Use `module` instead of `project` to create your SBT modules. Unlike `project`, `module` expects your modules to live in `modules` folder and uses the name of the variable for the project's ID and base folder (just like `project` does).
For example, the following SBT configuration:
```sbt
lazy val `my-library-core` = modulelazy val `my-library-plugin` = module.dependsOn(`my-library-core`)
```Would expect the following directory structure:
```
.
+-- modules
| +-- my-library-core
| +-- src
| +-- my-library-plugin
| +-- src
+-- build.sbt
+-- project
```### Retrieveing all modules created with `module`
`sbt-modules` creates a special variable called `allModules` that aggregates all the modules created with `module`, so you can pass it along as a dependency to other projects in your build, like:
```sbt
lazy val documentation = project.dependsOn(allModules)lazy val `my-library-core` = module
lazy val `my-library-plugin` = module.dependsOn(`my-library-core`)
```> Important ‼️ The `allModules` variable is created by listing all the directories in the `modules` directory so ensure: (1) that all your modules have a corresponding directory inside `modules` and (2) that there are no directories inside `modules` that aren't a module.
### Auto-`skip in publish`
Forget about setting `skip in publish := true` again. Adding this plugin to your build will disable publishing for all the projects in the build (including the auto-generated root plugin), except for those created with `module`.
However, if you also want to exclude any of those created with `module` you can always add `.settings(skip in publish := true)`.
Example:
```sbt
// Will not be published
lazy val documentation = project.dependsOn(allmodules)// Will be published
lazy val `my-library-plugin` = module.dependsOn(`my-library-core`)// Will be published
lazy val `my-library-core` = module// Will not be published
lazy val `my-library-util` = module.settings(skip in publish := true)
```[github-action]: https://github.com/alejandrohdezma/sbt-modules/actions
[github-action-badge]: https://img.shields.io/endpoint.svg?url=https%3A%2F%2Factions-badge.atrox.dev%2Falejandrohdezma%2Fsbt-modules%2Fbadge%3Fref%3Dmaster&style=flat[maven]: https://search.maven.org/search?q=g:%20com.alejandrohdezma%20AND%20a:sbt-modules
[maven-badge]: https://maven-badges.herokuapp.com/maven-central/com.alejandrohdezma/sbt-modules/badge.svg?kill_cache=1[steward]: https://scala-steward.org
[steward-badge]: https://img.shields.io/badge/Scala_Steward-helping-brightgreen.svg?style=flat&logo=