This plugin allows you to run Scalafix (a refactoring and linting tool for Scala) on Gradle projects. It supports both syntactic and semantic rules and lets you load your own custom rules via Gradle dependencies.
- Gradle:
4.10
or later (except5.0
) - Scala:
2.12.x
/2.13.x
/3.x
(requires Gradle 7.3 or later) - JDK:
8
or later
To use the Scalafix plugin, please include the following snippet in your build script:
plugins {
id 'scala' // <-- required
id 'io.github.cosmicsilence.scalafix' version '<version>'
}
By default, Scalafix won't run any rules unless they are specified via configuration file or command line argument. In order to decide what rules to pick and how to configure them, please check out Scalafix's built-in rules as well as external rules provided by the community.
This is the recommended approach if you want to repeatedly run Scalafix as part of your build and day-to-day development.
For that you need to create a file named .scalafix.conf
in the root directory of your project and enter the configuration
for the rules you want to have enabled. The configuration uses the HOCON syntax and is well documented on the Scalafix
website. If you are using external rules,
please take a look at the documentation provided by them. Below is a basic example of using one of the Scalafix's built-in
rules so you can quickly get started:
rules = [
DisableSyntax
]
DisableSyntax.noNulls = true
DisableSyntax.noVars = true
Tip: Multi-modules Gradle projects are allowed to define different combinations of Scalafix rules/settings for each individual subproject. This can be achieved by having a
.scalafix.conf
file defined in the subproject folder. The Scalafix plugin will first try to locate the config file at the subproject level and, if not found, at the root project level. It is also possible to inform a custom path via the plugin extension in the build script. See the extension section for more details.
There are times when it may be desirable to run a single or a subset of Scalafix rules without having to touch the configuration
file. For those one-off scenarios, you can inform the rule(s) you want to run using the scalafix.rules
property:
./gradlew scalafix -Pscalafix.rules=DisableSyntax,RemoveUnused
Some Scalafix rules (e.g. RemoveUnused
in Scala 2.x) require additional options to be passed into the Scala compiler.
That can be achieved as following:
tasks.withType(ScalaCompile) {
scalaCompileOptions.additionalParameters = [ "-Ywarn-unused" ]
}
The following Gradle tasks are created when the Scalafix plugin is applied to a project:
Name | Description |
---|---|
scalafix |
Runs rewrite and linter rules for all source sets. Rewrite rules may modify files in-place whereas linter rules will print diagnostics to Gradle's output. |
scalafix<SourceSet> |
Same as above, but for a single source set (e.g. scalafixMain , scalafixTest , scalafixFoo ). |
checkScalafix |
Checks that source files of all source sets are compliant to rewrite and linter rules. Any violation is printed to Gradle's output and the task exits with an error. No source file gets modified. This task is automatically triggered by the check task. |
checkScalafix<SourceSet> |
Same as above, but for a single source set (e.g. checkScalafixMain , checkScalafixTest , checkScalafixBar ). |
Note: If the SemanticDB Scala compiler plugin is enabled (see the extension section for more details), any of these tasks will trigger partial or complete compilation of Scala source files.
The plugin defines the scalafix
extension which enables some customisations. None of the properties are mandatory:
Property name | Type | Description |
---|---|---|
configFile |
RegularFileProperty |
Used to inform a different location/name for the Scalafix configuration file. If not informed, the plugin will search for a .scalafix.conf in the current project directory and (if not found) in the root project directory. |
configFile |
String |
Same as above. |
includes |
SetProperty<String> |
Ant-like pattern to filter what Scala source files should be processed by Scalafix. Filter is applied to package portion of the source file path. By default all files are included. |
excludes |
SetProperty<String> |
Ant-like pattern to exclude Scala source files from being processed by Scalafix. Filter is applied to package portion of the source file path. By default no files are excluded. |
ignoreSourceSets |
SetProperty<String> |
Name of source sets to which the Scalafix plugin should not be applied (by default this plugin is applied to all source sets defined in the project). This option can be used (e.g.) to ignore source sets that point to the same source files of other source sets (which would cause them to be processed twice). Be careful with plugin application ordering. E.g. when using this plugin together with scoverage, scoverage plugin should be applied first. |
semanticdb |
SemanticdbParameters |
Used to configure the SemanticDB compiler plugin. See semanticdb |
semanticdb
is a closure where the following properties can be configured:
Property name | Type | Description |
---|---|---|
autoConfigure |
Property<Boolean> |
Used to indicate whether the SemanticDB compiler plugin should be automatically configured. This is mandatory to run semantic rules. If set to true (default), the Scalafix Gradle tasks will require the corresponding Scala compiler tasks to run prior to them. The Scalafix plugin only informs the necessary parameters to get the SemanticDB plugin set up (-Xplugin: , -P:semanticdb:sourceroot: and -Yrangepos ). If you need to use more advanced settings, please consult the Scalafix docs or the SemanticDB docs. Any additional SemanticDB parameters can be informed via the ScalaCompile tasks as shown earlier. Important: If your project only uses syntactic rules, we advise to set this property to false as that would make the Scalafix tasks run considerably faster. |
version |
Property<String> |
(Scala 2.x only) Used to override the version of the SemanticDB compiler plugin. By default, the plugin uses a version that is guaranteed to be compatible with Scalafix. Users do not need to set this property unless a specific version is required. This property is ignored when autoConfigure is disabled. |
Example:
scalafix {
configFile = file("config/myscalafix.conf")
includes = ["/com/**/*.scala"]
excludes = ["**/generated/**"]
ignoreSourceSets = ["scoverage"]
semanticdb {
autoConfigure = false
}
}
One of the nice things about the Scalafix tool is that it is extensible. That means that you can implement your own custom
rules or reuse rules somebody else has already implemented and load them into Scalafix to run in your projects.
The Gradle Scalafix plugin lets you take advantage of that feature by allowing external rules to be informed as regular
dependencies in your Gradle build script using the scalafix
configuration. Examples:
dependencies {
// From a published jar
scalafix "org.typelevel:typelevel-scalafix_${scalaVersion}:+"
// From a local subproject
scalafix project(':my-scalafix-rules')
// From a local source set
scalafix sourceSets.myScalafixRules.output
}
- Felix Sanjuan -
@fsanjuan
- Marcelo Cenerino -
@marcelocenerine