ProductPromotion
Logo

Kotlin

made by https://0x3d.site

GitHub - facebook/ktfmt: A program that reformats Kotlin source code to comply with the common community standard for Kotlin code conventions.
A program that reformats Kotlin source code to comply with the common community standard for Kotlin code conventions. - facebook/ktfmt
Visit Site

GitHub - facebook/ktfmt: A program that reformats Kotlin source code to comply with the common community standard for Kotlin code conventions.

GitHub - facebook/ktfmt: A program that reformats Kotlin source code to comply with the common community standard for Kotlin code conventions.

ktfmt GitHub release Maven Central Version slack invite issues - ktfmt

ktfmt is a program that pretty-prints (formats) Kotlin code, based on google-java-format.

The minimum supported runtime version is JDK 11, released September 2018.

Demo

Before Formatting Formatted by ktfmt
Original ktfmt

For comparison, the same code formatted by ktlint and IntelliJ:

Formatted by ktlint Formatted by IntelliJ
ktlint IntelliJ

Playground

We have a live playground where you can easily see how ktfmt would format your code. Give it a try! https://facebook.github.io/ktfmt/

Using the formatter

IntelliJ, Android Studio, and other JetBrains IDEs

A ktfmt IntelliJ plugin is available from the plugin repository. To install it, go to your IDE's settings and select the Plugins category. Click the Marketplace tab, search for the ktfmt plugin, and click the Install button.

The plugin will be disabled by default. To enable it in the current project, go to File → Settings... → ktfmt Settings (or IntelliJ IDEA → Preferences... → Editor → ktfmt Settings on macOS) and check the Enable ktfmt checkbox. A notification will be presented when you first open a project offering to do this for you.

To enable it by default in new projects, use File → New Project Settings → Preferences for new Projects → Editor → ktfmt Settings.

When enabled, it will replace the normal Reformat Code action, which can be triggered from the Code menu or with the Ctrl-Alt-L (by default) keyboard shortcut.

To configure IntelliJ to approximate ktfmt's formatting rules during code editing, you can edit your project's .editorconfig file to include the Kotlin section from one of the files inside docs/editorconfig.

Share IntelliJ ktfmt settings

In order to share the settings, make sure to commit the file .idea/ktfmt.xml into your codebase.

Installation

Homebrew

If you're a Homebrew user, you can install ktfmt via:

$ brew install ktfmt

from the command-line

Download the formatter and run it with:

java -jar /path/to/ktfmt-<VERSION>-jar-with-dependencies.jar [--kotlinlang-style | --google-style] [files...]

--kotlinlang-style makes ktfmt use a block indent of 4 spaces instead of 2. See below for details.

Note: There is no configurability as to the formatter's algorithm for formatting (apart from the different styles). This is a deliberate design decision to unify our code formatting on a single format.

using Gradle

A Gradle plugin (ktfmt-gradle) is available on the Gradle Plugin Portal. To set it up, just follow the instructions in the How-to-use section.

Alternatively, you can use Spotless with the ktfmt Gradle plugin.

using Maven

Consider using Spotless with the ktfmt Maven plugin.

using pre-commit hooks

A pre-commit hook is implemented in language-formatters-pre-commit-hooks

FAQ

ktfmt vs ktlint vs IntelliJ

ktfmt uses google-java-format's underlying engine, and as such, many items on google-java-format's FAQ apply to ktfmt as well.

In particular, here are the principles that we try to adhere to:

  1. ktfmt ignores most existing formatting. It respects existing newlines in some places, but in general, its output is deterministic and is independent of the input code.
  2. ktfmt exposes no configuration options that govern formatting behavior. See https://github.com/google/google-java-format/wiki/FAQ#i-just-need-to-configure-it-a-bit-differently-how for the rationale.
    1. For exposed configurations, like style, we aim to make sure that those are easily shared across your organization/codebase to avoid bikeshedding discussions about code format.

These two properties make ktfmt a good fit in large Kotlin code bases, where consistency is very important.

We created ktfmt because at the time ktlint and IntelliJ sometimes failed to produce nice-looking code that fits in 100 columns, as can be seen in the Demo section.

ktfmt uses a 2-space indent; why not 4? any way to change that?

Two reasons -

  1. Many of our projects use a mixture of Kotlin and Java, and we found the back-and-forth in styles to be distracting.
  2. From a pragmatic standpoint, the formatting engine behind google-java-format uses more whitespace and newlines than other formatters. Using an indentation of 4 spaces quickly reaches the maximal column width.

However, we do offer an alternative style for projects that absolutely cannot make the move to ktfmt because of 2-space: the style --kotlinlang-style changes block indents to 4-space.

Developer's Guide

Setup

  • Open pom.xml in IntelliJ. Choose "Open as a Project"
  • The IntelliJ project will unfortunately be broken on import. To fix,

Development

  • Currently, we mainly develop by adding tests to FormatterTest.kt.

Building on the Command Line

  • Run mvn install
  • Run java -jar core/target/ktfmt-<VERSION>-jar-with-dependencies.jar

Releasing

See RELEASING.md.

License

Apache License 2.0

More Resources
to explore the angular.

mail [email protected] to add your project or resources here 🔥.

Related Articles
to learn about angular.

FAQ's
to learn more about Angular JS.

mail [email protected] to add more queries here 🔍.

More Sites
to check out once you're finished browsing here.

0x3d
https://www.0x3d.site/
0x3d is designed for aggregating information.
NodeJS
https://nodejs.0x3d.site/
NodeJS Online Directory
Cross Platform
https://cross-platform.0x3d.site/
Cross Platform Online Directory
Open Source
https://open-source.0x3d.site/
Open Source Online Directory
Analytics
https://analytics.0x3d.site/
Analytics Online Directory
JavaScript
https://javascript.0x3d.site/
JavaScript Online Directory
GoLang
https://golang.0x3d.site/
GoLang Online Directory
Python
https://python.0x3d.site/
Python Online Directory
Swift
https://swift.0x3d.site/
Swift Online Directory
Rust
https://rust.0x3d.site/
Rust Online Directory
Scala
https://scala.0x3d.site/
Scala Online Directory
Ruby
https://ruby.0x3d.site/
Ruby Online Directory
Clojure
https://clojure.0x3d.site/
Clojure Online Directory
Elixir
https://elixir.0x3d.site/
Elixir Online Directory
Elm
https://elm.0x3d.site/
Elm Online Directory
Lua
https://lua.0x3d.site/
Lua Online Directory
C Programming
https://c-programming.0x3d.site/
C Programming Online Directory
C++ Programming
https://cpp-programming.0x3d.site/
C++ Programming Online Directory
R Programming
https://r-programming.0x3d.site/
R Programming Online Directory
Perl
https://perl.0x3d.site/
Perl Online Directory
Java
https://java.0x3d.site/
Java Online Directory
Kotlin
https://kotlin.0x3d.site/
Kotlin Online Directory
PHP
https://php.0x3d.site/
PHP Online Directory
React JS
https://react.0x3d.site/
React JS Online Directory
Angular
https://angular.0x3d.site/
Angular JS Online Directory