Utility extensions, properties and useful methods to boost your programming with Kotlin.
Add the following repository to your pom.xml
:
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add the following dependencies to your pom.xml
:
<dependencies>
<dependency>
<groupId>com.github.carleslc</groupId>
<artifactId>kotlin-extensions</artifactId>
<version>0.6.1</version>
</dependency>
</dependencies>
If you need more powerful extensions and tools check the optional libraries section.
Add the following repository to your build.gradle
:
repositories {
maven { url 'https://jitpack.io' }
}
Add the following dependency to your build.gradle
:
dependencies {
compile 'com.github.carleslc:kotlin-extensions:0.6.1'
}
If you need more powerful extensions and tools check the optional libraries section.
git clone https://github.com/Carleslc/kotlin-extensions.git
cd kotlin-extensions
- Build the KotlinExtensions with
mvn clean install
. This also adds this project to your local Maven repository.
If you wish, you can use these steps to add the dependency using Maven or Gradle without accessing to the jitpack.io
remote repository.
Otherwise you will need to add the kotlin-extensions-0.6.1.jar
from generated target
folder as external dependency of your project.
If you need more powerful extensions and tools check the optional libraries section.
In order to use any of the extensions or methods of KotlinExtensions you only need to import them.
import me.carleslc.kotlin.extensions.standard.times
import me.carleslc.kotlin.extensions.standard.*
import me.carleslc.kotlin.extensions.arrays.*
Extensions for arrays, a syntactic-sugar way to create literal arrays like A[1, 2, 3]
instead typical arrayOf(1, 2, 3)
and methods to work with 2D arrays and matrices (2D arrays with fixed columns size) easier.
import me.carleslc.kotlin.extensions.bytes.*
Extensions for memory size conversions (from bits to pebibytes and petabytes).
Inspired from ktunits library.
import me.carleslc.kotlin.extensions.collections.*
Extensions for collections, sintactic-sugar for list and set literals with L[values]
or S[values]
and other global methods to create collections.
import me.carleslc.kotlin.extensions.conversions.*
Extensions for conversions between basic types.
import me.carleslc.kotlin.extensions.html.*
Extensions to generate HTML in a more readable way.
import me.carleslc.kotlin.extensions.map.*
Extensions for maps and sintactic-sugar for Map literals with M[pairs]
.
import me.carleslc.kotlin.extensions.number.*
Extensions for numbers and math operations.
import me.carleslc.kotlin.extensions.strings.*
Extensions for strings.
pluralize
and singularize
methods are extracted from kotlin-pluralizer.
import me.carleslc.kotlin.extensions.time.*
Extensions for timing, format and manage time or dates easily.
Inspired from kxdate and khronos libraries.
import me.carleslc.kotlin.extensions.tuples.*
Extensions for pairs and triples.
import me.carleslc.kotlin.extensions.preconditions.*
Extensions to ensure preconditions easily.
import me.carleslc.kotlin.extensions.standard.*
General purpose extensions and global methods that do not match any other package category (e.g. looping with 10 times { code }
or 10 * { code }
).
Do you want to contribute to this project? Great!
Simply fork and do a pull request. Then if it makes sense I will merge it creating a new version of this project.
Follow this rules when doing a pull request in order to be accepted:
- Match the code style of this project (default in IntelliJ). You can do
⌘ + Option + L
in Mac with IntelliJ IDE to reformat your code. - Unit Test your code.
- Inline your extensions when possible. Include
@file:Suppress("NOTHING_TO_INLINE")
to suppress warnings at top of your file. - Ensure that your extensions/methods are general enough to be used in many different contexts.
- Be descriptive in the title and description of your pull request.
This library includes some functional extensions and classes like those of the common and most used functional languages. It is a perfect library to use together with KotlinExtensions.
import org.funktionale.collections.*
import org.funktionale.complement.*
import org.funktionale.composition.*
import org.funktionale.currying.*
import org.funktionale.either.*
import org.funktionale.memoization.*
import org.funktionale.option.*
import org.funktionale.pairing.*
import org.funktionale.partials.*
import org.funktionale.pipe.*
import org.funktionale.reverse.*
import org.funktionale.state.*
import org.funktionale.tries.*
import org.funktionale.utils.*
import org.funktionale.validation.*
This library from Google Developers includes a lot of useful classes and methods to extend the language. Is written in Java but we can use it from Kotlin with no problems.
If you need extensions and useful tools for Android this library is a must for your Android development.