Kotlin/Native is a LLVM backend for the Kotlin compiler, runtime implementation and native code generation facility using LLVM toolchain.
Kotlin/Native is primarily designed to allow compilation for platforms where virtual machines are not desirable or possible (such as iOS, embedded targets), or where developer is willing to produce reasonably-sized self-contained program without need to ship an additional execution runtime.
To get started with Kotlin/Native take a look at the attached samples.
androidNativeActivity
- Android Native Activity rendering 3D graphics using OpenGLEScsvparser
- simple CSV file parser and analyzerlibcurl
- using of FTP/HTTP/HTTPS client librarylibcurl
nonBlockingEchoServer
- multi-client TCP/IP echo server using co-routinesgitchurn
- program interoperating withlibgit2
for GIT repository analysisobjc
- AppKit Objective-C interoperability example for OSXopengl
- OpenGL/GLUT teapot examplesocket
- TCP/IP echo servertensorflow
- simple client for TensorFlow Machine Intelligence librarytetris
- Tetris game implementation (using SDL2 for rendering)uikit
- UIKit Objective-C interoperability example for iOSwin32
- trivial Win32 application
See README.md
in each sample directory for more information and build instructions.
Kotlin/Native could be used either as standalone compiler toolchain or as Gradle
plugin. See GRADLE_PLUGIN.md
for more details on how to use this plugin.
Compile your programs like that:
export PATH=kotlin-native-<platform>-<version>/bin:$PATH
kotlinc hello.kt -o hello
For an optimized compilation use -opt:
kotlinc hello.kt -o hello -opt
To generate interoperability stubs create library definition file
(take a look on samples/tetris/tetris.sdl
) and run cinterop
tool like this:
cinterop -def lib.def
See INTEROP.md
for more information on how to use C libraries from Kotlin/Native.
See RELEASE_NOTES.md
for information on supported platforms and current limitations.