All contributions to the project must comply with the guidelines set forth in this document. Some older parts of the codebase do not follow these guidelines. If you are modifying such code, it is generally best to clean it up to comply with the current guidelines.
In order to better position our developers to produce quality, public-facing code, all new PartiQL projects will enable strict explicit API mode. In this Kotlin compilation mode, "the compiler performs additional checks that help make the library's API clearer and more consistent". The implications are required visibility modifiers and return types.
All internal
classes should be placed within impl
packages to help distinguish our public APIs from the internal
codebase.
See an example below:
⚬ partiql-spi
└── src/main/kotlin/org/partiql/spi/types
├── impl
| ├── StructElement.kt (internal)
| ├── StructType.kt (internal)
| ├── ...
| └── IntElement.kt
├── PartiQLElement.kt (Public Interface & Builder)
└── PartiQLType.kt (Public Interface & Builder)
For Public APIs, the Kotlin implementation will not allow top-level functions. Similarly, due to the resulting JVM bytecode,
there shall not be internal
top-level functions. They should be generally avoided.
All contributions must abide by the styling guidelines set by ktlint
. To automatically format the codebase to comply
with ktlint
, run:
./gradlew ktlintFormat
To check whether your contributions already comply with the style guidelines, run:
./gradlew ktlintCheck
Always include the copyright notice at the top of every file containing source code.
/*
* Copyright Amazon.com, Inc. or its affiliates. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at:
*
* http://aws.amazon.com/apache2.0/
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific
* language governing permissions and limitations under the License.
*/