Ensure Android Code Quality: Use ktlint in your Kotlin Projects

Introduction

Kotlin is the primary language recommended by Google for Android app development. Compared to Java, it will make the life of Android app developers easier, but if you are new in this field, you may not know how to format your code correctly.

Instead of starting researching and learning specific rules to write clean code using Kotlin, you can use ktlint, which was developed for this particular purpose:

ktlint is an anti-bikeshedding Kotlin linter with a built-in format
- ktlint
💡
Note: ktlint is an Open Source project that is maintained and used by Pinterest. It can be found and downloaded on GitHub: https://pinterest.github.io/ktlint/

This means it checks the code styling and helps to format the code by making automatic changes. This will result in more readable and understandable code.

Benefits of using ktlint:

  • ktlint can save time
  • ktlint will save energy by avoiding checking code styling manually
  • ktlint simplifies the formatting process

What can ktlint do?

ktlint can be broken down into two main tasks:

  1. ktlint is a linting tool: Linting done by ktlint is based on the official Kotlin standard style guide. This means it will validate the code and check if it adheres to the official Kotlin style guides.
  2. ktlint is a formatter: If issues are found in the code by using ktlint, it is possible to run the ktlint formatted to automatically fix these issues.

Also, ktlint can be installed and used in two separate ways:

  1. As a Gradle Task using ktlint-gradle. This task can also be used in CI/CD pipelines or pre-commit/pre-push hooks to automatically check and fix your code.
  2. As an Android Studio plugin to enable automatic IDE integration on your development machine.

How to implement ktlint-gradle in a Kotlin Android project

To implement ktlint in any Android app, it will be added to the project using the ktlint-gradle plugin. This is a separate third-party plugin on top of the basic ktlint tool. It will enable working with ktlint by providing Gradle tasks that internally run ktlint commands.

Add ktlint-gradle to an Android Project

To enable ktlint in an Android project, the Gradle plugin has to be added to the root-level build.gradle file:

plugins {
  id("org.jlleitschuh.gradle.ktlint") version "11.1.0"
}

repositories {
  // Required to download KtLint
  mavenCentral()
}

If the Android app uses the plugin DSL, the Gradle plugin will be added differently:

buildscript {
  repositories {
    maven("https://plugins.gradle.org/m2/")
  }
  dependencies {
    classpath("org.jlleitschuh.gradle:ktlint-gradle:11.1.0")
  }
}

repositories {
  // Required to download KtLint
  mavenCentral()
}

apply(plugin = "org.jlleitschuh.gradle.ktlint")
💡
Note: Keep in mind that this tutorial is written with the actual version 11.1.0 of the ktlint-gradle plugin.!

Apply the ktlint-gradle plugin to all Projects

If working with multiple submodules within an Android project, the ktlint-gradle plugin should be added to the allprojects{...} block in the root-level build.gradle file:

// root-level build.gradle
allprojects {
	...
	apply plugin: "org.jlleitschuh.gradle.ktlint"
}

Use ktlint-gradle to check Kotlin code

After setting up the ktlint-gradle plugin, the lint and format tasks are now available in the Android app.

There are two ways to find out which tasks could be run in the app:

  • Run ./gradlew tasks in the CLI and find any ktlint task that can be run
  • Use the Gradle tool in Android Studio to list every available task

To check the code with ktlint, the following command can be either run in the CLI or selected from the Gradle tool:

./gradle ktlintCheck

This command will go through the project and report any error found using the default ktlint-gradle configuration.

Automatically fixing any errors reported by ktlintCheck can be done by executing the following:

./gradle ktlintFormat

This command will attempt to fix every error and report every other error that could not be fixed automatically.


After both commands are executed, your code should be optimized in terms of the Kotlin style guide.

Adjust/Specifying ktlint Rules

Although there are many standard rules applied as default by ktlint, it is possible to modify or specify rules to fit any needs:

  • have no newline at the end of a file
  • indentation size of 2 (instead of 4)
  • disable any rule

To apply these rules, you create a new .editorconfig file in the project root directory and specify everything. ktlint-gradle will use this config every time it runs a code checkup.

The following .editorconfig applies the previously defined rules and specifies that ktlint should ignore the no-wildcard-imports rule:

[*]
indent_size = 2
indent_style = space
insert_final_newline = true


[*.{kt,kts}]
disabled_rules=no-wildcard-imports

Using Android Studio Extension

Instead of manually installing ktlint-gradle and using a Gradle task to execute it, you can use Android Studio to install an unofficial plugin from the JetBrains marketplace: https://plugins.jetbrains.com/plugin/15057-ktlint-unofficial-/

This plugin will be fully integrated into your IDE and will internally use ktlint rules to format your code.

Installing can be done with the Plugins manager of Android Studio. Open the Plugins menu by selecting File -> Settings -> Plugins and search for ktlint:

Image of Android Studio Plugins section used to install Ktlint

Next, install the plugin, restart your IDE and open File -> Settings -> Tools -> ktlint, and adjust the settings to your needs:

Image of Android Studio Tools section used to configure Ktlint

Now if you press CTRL + ALT + L it will automatically format your code and apply all ktlint rules.

Closing Notes

I hope this article has helped show you how to implement ktlint in your Android projects using the Android Studio plugin or the Gradle task and making the most of its features.

Implementing it in Android Studio is straightforward and should be done by every Android app developer to optimize their code quality. Also, using ktlint-gradle as part of your CI/CD pipeline ensures that your code remains compliant with Kotlin coding standards even as your team grows and evolves.

Using ktlint can save time and resources by preventing potential bugs and reducing the time spent on code review. Also, overall code quality will be optimized.

To further optimize overall Android code quality and speed up the app development process, you can check out the following two tutorials:

  1. Improving Code Quality Of Android Apps With SonarQube And Gradle Detekt
  2. Optimize Android App Development With Docker, SonarQube, Detekt, and MobSF

Finally, what do you think about ktlint and using it to optimize code quality? Are you eager to apply it to your project? Also, do you have any questions regarding how to implement it? I would love to hear your thoughts and answer your questions. Please share everything in the comments.

Feel free to connect with me on Medium, LinkedIn, Twitter, and GitHub.

Thank you for reading, and happy coding!