Kotlin/Native is an LLVM backend for the Kotlin compiler, runtime implementation, and native code generation facility using the LLVM toolchain.
Kotlin/Native is primarily designed to allow compilation for platforms where virtual machines are not desirable or possible (such as iOS or embedded targets), or where a developer is willing to produce a reasonably-sized self-contained program without the need to ship an additional execution runtime.
- install JDK for your platform, instead of JRE. The build requires
tools.jar, which is not included in JRE;
- on macOS install Xcode 9.2
To compile from sources use following steps:
First, download dependencies:
Then, build the compiler and libraries:
The build can take about an hour on a Macbook Pro. To run a shorter build with only the host compiler and libraries, run:
./gradlew dist distPlatformLibs
After that, you should be able to compile your programs like this:
export PATH=./dist/bin:$PATH kotlinc hello.kt -o hello
For an optimized compilation, use
kotlinc hello.kt -o hello -opt
For tests, use:
To generate interoperability stubs, create a library definition file
samples/tetris/.../sdl.def), and run the
cinterop tool like this:
cinterop -def lib.def
The Interop tool generates a library in the
.klib library format. See
for more details on this file format.