de14a57fe1
Since in Java 8 there are default methods in interface, method resolution algorithm becomes more complicated. This alseocauses several related changes. 1. Resolve methods as late as possible; do not resolve virtual call sites during DCE. 2. Due to several reasons we have to improve linking phase to preserve super methods that aren't actually ever called, but present in virtual call sites. Related issue: #311 |
||
---|---|---|
.idea | ||
all-deps | ||
classlib | ||
core | ||
extras-slf4j | ||
html4j | ||
interop/core | ||
jso | ||
metaprogramming | ||
platform | ||
samples | ||
tests | ||
tools | ||
.gitignore | ||
.travis.yml | ||
checkstyle.xml | ||
LICENSE | ||
license-regexp.txt | ||
NOTICE | ||
pom.xml | ||
README.md | ||
set-version.sh | ||
travis-settings.xml | ||
update-idea-repository.sh |
TeaVM
See documentation at the project web site.
Useful links:
Building TeaVM
Simply clone source code (git clone https://github.com/konsoletyper/teavm.git
) and run maven build (mvn clean install
). You can do things a little faster (mvn clean -DskipTests
) or even a little more faster (mvn clean -DskipTests -Dteavm.build.all=false
).
Preview builds
You may want to access new features and don't want to wait until stable release is published on Maven Central. In this case you can get latest development build from bintray. All you need is to put the following in your pom.xml
:
<repositories>
<repository>
<id>teavm-dev</id>
<url>https://dl.bintray.com/konsoletyper/teavm</url>
</repository>
</repositories>
IDEA plugin is also available in preview builds. You need to add corresponding repository manually to IDEA. Open Settings -> Plugins -> Browse repositories... -> Manage repositories..., click Add button and enter http://teavm.org/idea/dev/teavmRepository.xml
. Then get back to Browse repositories and pick TeaVM plugin from list.
Embedding TeaVM
If you are not satisfied with Maven, you can embed TeaVM in your program or even create your own plugin for any build tool, like Ant or Gradle. The starting point for you may be org.teavm.tooling.TeaVMTool
class from teavm-tooling
artifact. You may want to go deeper and use org.teavm.vm.TeaVM
from teavm-core
artifact, learn how TeaVMTool
initializes it. To learn how to use TeaVMTool
class itself, find its usages across project source code. You most likely encounter Maven and IDEA plugins.
Please, notice that these APIs for embedding are still unstable and may change between versions.
WebAssembly
WebAssembly support is in experimental status. It may lack major features available in JavaScript backend. There's no documentation yet and you should do many things by hands (like embedding generated wasm
file into your page, importing JavaScript objects, etc). Look at samples/benchmark module. You should first examine pom.xml
file to learn how to build wasm
file from Java. Then you may want to examine index-teavm.html
and index-teavm.js
to learn how to embed WebAssembly into your web page.
Feedback
More information is available at the official site: http://teavm.org.
Ask your questions by email: info@teavm.org. Also you can report issues on a project's issue tracker.