You can find documentation at the wiki.
JTransc (Java Trans Compiler) is an AOT (ahead of time compiler) that compiles .class and .jar filesinto a target programming language / executable bundling all the required dependencies in a single file or folder,without requiring a jitter or an external runtime.
There are a lot of technologies in order to convert languages into other ones. For example, converting Java into JavaScript.Or KotlinJS Kotlin backend that already targets JavaScript. So why using JTransc?
One reason is that JTransc allows mixed projects. You can use Java libraries with Kotlin code for example.
Instead of using several technologies, JTransc allows you to target to several languages and platforms.
Using just one technology guarantees consistency between targets. For example, Kotlin JS doesn't support full Java reflection.
Instead of generating C++ and then using emscripten or other technologies, JTransc allows you to generate code that isnative to your platform. For example: when targeting JS you will use native JS best-in-class GC instead of a GCemulated in C++ & emscripten. And no need to know a proper heap size beforehand targeting JS.
Some classes like String, StringBuilder or ArrayList are implemented in a way that it uses native JavaScript/AS3/Dart... facilities.Like JavaScript String, Array and so on.
Instead of generating huge projects including everything, or having complex proguard configuration files.JTransc includes treeshaking in a simple way. You can use annotations to keep methods, classes and fields or another annotations.It works for all targets and it is fully integrated in the workflow.
JTransc supports plain Java applications using Threads and sync I/O in JS converting that into an asynchronous version in JSusing await/async detecting branches not using Threads/sync I/O for fastest performance.
Along JTransc, I'm writting a set of libraries to be able to use JTransc.
https://github.com/soywiz/korlibs
Kotlin Game Engine that uses JTransc for multiplatform: https://github.com/soywiz/korge
Also there is a GDX backend using JTransc+Haxe: https://github.com/jtransc/gdx-backend-jtransc
JTransc
JTransc (Java Trans Compiler) is an AOT (ahead of time compiler) that compiles .class and .jar filesinto a target programming language / executable bundling all the required dependencies in a single file or folder, without requiringa jitter or an external runtime.
At the beginning it generated as3 and javascript, but right now there are several targets: Javascript, Haxe, C++, and D.Haxe itself allow to target several other languages: JS, AS3, C++, C#, Java, PHP and Python.This in turn allows running the program on different platforms such as desktop, browsers and mobile.
The aim of this project is to bring the high productivity of Kotlin (and other JVM languages)to the highly portable Haxe platform.It already supports most of the core Java APIs and plain Java reflection API out of the box.
The initial focus is on JVM6, Kotlin and Games, but it will get better in the future supporting newer jvm versions,and other use cases like frontend and backend applications.
Right now JTransc support Java8 lambdas and default methods.
There is a module called jtransc-rt-core that could be included in any project (whether using JTransc or not).It provides the com.jtransc
package, specific annotations, fast memory access and asynchronous APIs,that will use JTransc features when compiling using JTransc.
These is also a couple of projects for multimedia applications using jtransc:
You can find examples here jtransc/jtransc-examples.
# jtransc script can be found under the jtransc-main-run folder
javac com/test/Main.java -d target/classes
jtransc dependency.jar target/classes -main com.test.Main -out program.js
node program.js
This is the preferred way of using JTransc. You can include it from maven central or directly from gradle plugins repository:
plugins {
id "com.jtransc" version "0.6.8"
}
This will add several tasks for building your application.There is a gradle block called jtransc, that allows you to specify stuff for the build.
For example gradle runJs
would generate a JS file at build/jtransc-js/program.js
and run it using node.js.
You can see how to use it in the documentation.
You can also use Maven, though due to the nature of JTransc gradle fits better.You can see how to use it in the documentation.
There is a plugin in the works that will allow to run and debug within intelliJ. Though it is not ready yet.You can find it in jtransc-intellij-plugin folder.
Eventually that intermediate AST will be able to be generated or consumed.So others could generate that without JVM and others could generate other targets from that AST directly without all the complexities of stack-based IRs.
echo "export JAVA_HOME=$(/usr/libexec/java_home)" >> ~/.bash_profile
source ~/.bash_profile
haxelib install lime 5.5.0
haxelib install hxcpp 3.4.64
haxelib run lime setup
######https://github.com/openfl/lime/issues/831
lime setup android
If try install you gain Out of Memory, choose manual mode.Download and install the Android SDK? [y/n/a] ? n
Download and install the Android NDK? [y/n/a] ? n
Download and install the Java JDK? [y/n/a] ? n
Path to Android SDK [C:\tools\android-sdk]:
Path to Android NDK []: C:\tools\android-ndk
Path to Java JDK [C:\Program Files\Java\jdk1.8.0_131]:
lime rebuild hxcpp tvos
haxelib remove lime
git clone --recursive https://github.com/openfl/lime
haxelib dev lime lime
haxelib install format
lime rebuild mac
lime rebuild ios
lime rebuild tvos
WINDOWS
PATH
environment variable strongly on first lineWorkaround for big projects: haxe 3.4.2 can failed with out of memory. You can try replace haxe filesfrom develop,but this dangerous way, and get only stable, see history on github.My current choose: 2017-03-23 05:39:01 >> 4876859 >> haxe_2017-03-23_development_ada466c.tar.gz
WINDOWS 64
neko run.n Build.xml -Dwindows -DHXCPP_M64 -Dstatic_link ./project/
haxelib remove lime
git clone --recursive https://github.com/openfl/lime -b master
haxelib dev lime lime
haxelib install format
if use MSVC 2013 with not fully supported c99 standard, then replace in lib\openal all inline to __inline, and snprintf to _snprintf
lime rebuild windows -64
MAC
brew install automake libtool pkg-config
sudo npm install -g ios-deploy --unsafe-perm --allow-root