This repository contains proposals for the Kotlin Programming Language, including draft design notes and discussions for in-progress proposals as well as the design documentation on the changes that were already implemented.
The proposals themselves are colloquially referred to as KEEPs. They cover both the language itself and its standard library.
The implementation of the corresponding design enhancements usually lives in the Kotlin Source Code Repository.
- Current in-progress KEEPs are listed in issues.
- New KEEPs and additions to current KEEPs are submitted as pull requests.
- When KEEPs are implemented, the corresponding design documents are merged into this repository and stored in a proposals directory.
Some feature ideas that are being discussed for Kotlin represent important directions of potential enhancement but are not complete to call them design proposals. They still need to be discussed with the Kotlin community to gather use-cases for these features, their potential syntax, impact on existing Kotlin code, etc. They are called "design notes" and are stored in a separate notes directory.
Language enhancements/features usually go through the following informal stages:
- Discussion of an idea.
- Collection of use-cases.
- Design proposal and prototype implementation.
- Experimental support in the language.
- Further refinement and stable release.
All stages involve the gathering of feedback on the corresponding feature. It does not stop even when the feature becomes stable. The community feedback on all stages is crucial to the open philosophy of the Kotlin language enhancement process.
If you have a vague idea about the potential enhancement but you are not sure whether it is worthwhile and/or fits the Kotlin language, or just want to get community feedback, you can use either of the two channels you feel most comfortable with:
- #language-proposals channel in Kotlin public Slack (get an invite here);
- Kotlin Forum in the Language design category.
If you have a use case that is not covered by the language or have a specific language enhancement in mind,
then, please, file a YouTrack issue in the Language Design
subsystem.
While many popular enhancements and language design problems are already filed in
Kotlin YouTrack, your contribution to them is still very important:
- 👍 Vote for the issues you encounter in your work.
- 📝 Comment with the description of your specific use-cases.
Our practice of language design shows that contributing real-life use-cases is the most valuable piece of feedback from the Kotlin community.
Design proposals in this repository are expected to be well thought-through and usually come with a prototype implementation that demonstrates their feasibility. All design proposals in this repository shall be backed by maintainers of the corresponding subsystems in the Kotlin compiler or its standard library.
If you are in doubt about whether the proposal meets those criteria, please start with the discussion of your idea, use case, or a specific enhancement in the appropriate channels and secure support for your general idea/proposal from maintainers before submitting a KEEP.
We will be gradually moving KEEPs that are not backed by Kotlin maintainers into YouTrack issues for further discussions.
- For in-progress KEEPs, please keep discussions in the corresponding issue.
- If you find problems with the text or have text correction for merged KEEPs, feel free to create a separate issue or a pull request with the proposed correction.