Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cortinico/ktfmt-gradle
A Gradle plugin to apply ktfmt to your builds, and reformat you Kotlin source code like a glimpse ๐งน๐
https://github.com/cortinico/ktfmt-gradle
formatter formatting gradle gradle-plugin gradle-plugin-kotlin hacktoberfest kotlin kotlin-android kotlin-gradle ktfmt ktfmt-gradle lint linter reformat
Last synced: 6 days ago
JSON representation
A Gradle plugin to apply ktfmt to your builds, and reformat you Kotlin source code like a glimpse ๐งน๐
- Host: GitHub
- URL: https://github.com/cortinico/ktfmt-gradle
- Owner: cortinico
- License: mit
- Created: 2020-11-13T15:23:07.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-10-23T21:18:07.000Z (3 months ago)
- Last Synced: 2024-10-29T16:57:20.222Z (3 months ago)
- Topics: formatter, formatting, gradle, gradle-plugin, gradle-plugin-kotlin, hacktoberfest, kotlin, kotlin-android, kotlin-gradle, ktfmt, ktfmt-gradle, lint, linter, reformat
- Language: Kotlin
- Homepage:
- Size: 798 KB
- Stars: 154
- Watchers: 7
- Forks: 19
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - cortinico/ktfmt-gradle - A Gradle plugin to apply ktfmt to your builds, and reformat you Kotlin source code like a glimpse ๐งน๐ (Kotlin)
README
# ktfmt-gradle ๐งน๐
A wrapper to apply [ktfmt](https://github.com/facebookincubator/ktfmt) to your Gradle builds, and reformat you Kotlin
source code like a glimpse.[![Plugin Portal](https://img.shields.io/maven-metadata/v/https/plugins.gradle.org/m2/com/ncorti/ktfmt/gradle/com.ncorti.ktfmt.gradle.gradle.plugin/maven-metadata.xml.svg?label=Gradle%20Plugin%20Portal&colorB=brightgreen&logo=gradle)](https://plugins.gradle.org/plugin/com.ncorti.ktfmt.gradle) [![Pre Merge Checks](https://github.com/cortinico/ktfmt-gradle/workflows/Pre%20Merge%20Checks/badge.svg)](https://github.com/cortinico/ktfmt-gradle/actions?query=workflow%3A%22Pre+Merge+Checks%22) ![Language](https://img.shields.io/github/languages/top/cortinico/kotlin-android-template?color=blue&logo=kotlin) [![License](https://img.shields.io/github/license/cortinico/kotlin-android-template.svg)](LICENSE) [![Use this template](https://img.shields.io/badge/from-kotlin--gradle--plugin--template-brightgreen?logo=dropbox)](https://github.com/cortinico/kotlin-gradle-plugin-template/generate) [![Twitter](https://img.shields.io/badge/[email protected]?style=flat&logo=twitter)](http://twitter.com/cortinico)
## How to use ๐ฃ
**ktfmt-gradle** is distributed through [Gradle Plugin Portal](https://plugins.gradle.org/). To use it you need to add
the following dependency to your gradle files.Please note that those code needs to be added the gradle file of the **module** where you want to reformat the code
(**not the top level** build.gradle[.kts] file).If you're using the `plugin{}` blocks in your Gradle file:
```kotlin
plugins {
id("com.ncorti.ktfmt.gradle") version ""
}
```If you're instead using the Groovy Gradle files and the old `buildscript` block:
```groovy
buildscript {
repositories {
maven { url "https://plugins.gradle.org/m2/" }
}dependencies {
classpath "com.ncorti.ktfmt.gradle:plugin:"
}
}apply plugin: "com.ncorti.ktfmt.gradle"
```### Requirements
Please note that `ktfmt-gradle` relies on `ktfmt` hence the minimum supported JDK version is **11**.
Please also note the following requirements:
* **Kotlin 1.4+**. In order to reformat Kotlin 1.4 code, you need run on **Gradle to 6.8+** (This is due to Gradle 6.7 embedding Kotlin 1.3.x - See [#12660](https://github.com/gradle/gradle/issues/12660)).
* **Android**. `ktfmt-gradle` relies on features from **Android Gradle Plugin 4.1+**. So make sure you bump AGP before applying this plugin.
### Task
By default, `ktfmt-gradle` will add two Gradle tasks to your build:
- `ktfmtCheck` that will check if the code in your module is ktfmt-compliant
- `ktfmtFormat` that will reformat your code with ktfmtThose two tasks will invoke `ktfmt` on the **whole module**. More specific tasks are avialable based on the module type.
Additionally, the plugin will create check/format tasks for top-level Kotlin script files:
- `ktfmtCheckScripts` that will check if the top-level script files in your module is ktfmt-compliant
- `ktfmtFormatScripts` that will reformat top-level script files with ktfmt#### Jvm/Js Modules
For Jvm/Js modules, the plugin will create a check/format task for **every source set**. For example, jvm modules will
have a `ktfmtCheckMain` and `ktfmtCheckTest` tasks for the `main` and `test` source sets.#### Multiplatform Modules
Kotlin Multiplatform modules will have separate tasks for **every target/source set**. You will have tasks
like `ktfmtCheckCommonMain` and `ktfmtCheckCommonTest` and so on. If you target also Android, the tasks explained below
will be added as well.#### Android Modules
Kotlin Android modules will also have separate tasks for **every source set**. Due to how source sets are handled on
Android, you can expect ktfmt tasks to follow the convention: `ktfmt[Check|Format][SourceSet][Variant]JavaSource`. For
example, the `ktfmtCheckAndroidTestDebugJavaSource`.## Features ๐จ
- 100% Kotlin-only plugin.
- **Parallel** file processing with Kotlin Coroutines.
- Supports **incremental** builds (i.e. checks tasks won't rerun if source is unchanged).
- Configurable thanks to the `ktfmt{}` block.
- Integrated with Jvm/Android/KMM modules.## Configuring ๐
You can configure the behavior of the `ktfmt` invocation with the `ktfmt` block in your `build.gradle.[kts]` file.
To enable different styles you can simply:
```kotlin
ktfmt {
// Google style - 2 space indentation & automatically adds/removes trailing commas
googleStyle()
// KotlinLang style - 4 space indentation - From kotlinlang.org/docs/coding-conventions.html
kotlinLangStyle()
}
```If you wish to have further control on the tool you can instead:
```kotlin
ktfmt {
// Breaks lines longer than maxWidth. Default 100.
maxWidth.set(80)
// blockIndent is the indent size used when a new block is opened, in spaces.
blockIndent.set(8)
// continuationIndent is the indent size used when a line is broken because it's too
continuationIndent.set(8)
// Whether ktfmt should remove imports that are not used.
removeUnusedImports.set(false)
// Whether ktfmt should automatically add/remove trailing commas.
manageTrailingCommas.set(false)
}
```By default, sourceSets that are in your `build` folder are ignored. To customize this, you can set a regex pattern to
exclude certain sourceSets:```kotlin
ktfmt {
srcSetPathExclusionPattern = Regex(".*generated.*")
}
```Please note, that this property will only affect the sourceSet path and not the individual files inside the sourceSet.
To include or exclude files inside a sourceSet, use the include and exclude properties of the ktfmt tasks.## Using with a pre-commit hook ๐ฃ
You can leverage the `--include-only` to let ktfmt-gradle run only on a specific subset of files.
To do this you can register a simple task of type `KtfmtCheckTask` or `KtfmtFormatTask` in your `build.gradle.kts` as
follows:```kotlin
import com.ncorti.ktfmt.gradle.tasks.*tasks.register("ktfmtPrecommit") {
source = project.fileTree(rootDir)
include("**/*.kt")
}
```You can then invoke the task with `--include-only` and a comma-separated (or colon-separated) list of relative path of
files:```
./gradlew ktfmtPrecommit --include-only=src/main/java/File1.kt:src/main/java/File2.kt
```The task will execute only on the file you passed and will skip all the others.
## Contributing ๐ค
Feel free to open a issue or submit a pull request for any bugs/improvements.
## License ๐
This project is licensed under the MIT License - see the [License](License) file for details