2020-08-08 15:51:04 +07:00
|
|
|
# Coding Conventions
|
2020-06-13 20:51:37 +03:00
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
Generally, KMath code follows
|
|
|
|
general [Kotlin coding conventions](https://kotlinlang.org/docs/reference/coding-conventions.html), but with a number of
|
|
|
|
small changes and clarifications.
|
2020-06-13 20:51:37 +03:00
|
|
|
|
2020-08-08 15:51:04 +07:00
|
|
|
## Utility Class Naming
|
2020-06-13 20:51:37 +03:00
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
Filename should coincide with a name of one of the classes contained in the file or start with small letter and describe
|
|
|
|
its contents.
|
2020-08-08 15:51:04 +07:00
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
The code convention [here](https://kotlinlang.org/docs/reference/coding-conventions.html#source-file-names) says that
|
|
|
|
file names should start with a capital letter even if file does not contain classes. Yet starting utility classes and
|
|
|
|
aggregators with a small letter seems to be a good way to visually separate those files.
|
2020-06-13 20:51:37 +03:00
|
|
|
|
|
|
|
This convention could be changed in future in a non-breaking way.
|
|
|
|
|
2020-08-08 15:51:04 +07:00
|
|
|
## Private Variable Naming
|
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
Private variables' names may start with underscore `_` for of the private mutable variable is shadowed by the public
|
|
|
|
read-only value with the same meaning.
|
2020-06-13 20:51:37 +03:00
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
This rule does not permit underscores in names, but it is sometimes useful to "underscore" the fact that public and
|
|
|
|
private versions draw up the same entity. It is allowed only for private variables.
|
2020-06-13 20:51:37 +03:00
|
|
|
|
|
|
|
This convention could be changed in future in a non-breaking way.
|
|
|
|
|
2020-08-08 15:51:04 +07:00
|
|
|
## Functions and Properties One-liners
|
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
Use one-liners when they occupy single code window line both for functions and properties with getters like
|
|
|
|
`val b: String get() = "fff"`. The same should be performed with multiline expressions when they could be
|
2020-08-08 15:51:04 +07:00
|
|
|
cleanly separated.
|
2020-06-13 20:51:37 +03:00
|
|
|
|
2024-03-27 09:11:12 +03:00
|
|
|
There is no universal consensus whenever use `fun a() = ...` or `fun a() { return ... }`. Yet from reader outlook
|
|
|
|
one-lines seem to better show that the property or function is easily calculated.
|