compiler-team VS Graal

Compare compiler-team vs Graal and see what are their differences.

compiler-team

A home for compiler team planning documents, meeting minutes, and other such things. (by rust-lang)

Graal

GraalVM compiles Java applications into native executables that start instantly, scale fast, and use fewer compute resources 🚀 (by oracle)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
compiler-team Graal
46 156
380 19,788
1.8% 0.4%
6.8 10.0
13 days ago 5 days ago
HTML Java
Apache License 2.0 GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

compiler-team

Posts with mentions or reviews of compiler-team. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-18.
  • The Rust Calling Convention We Deserve
    3 projects | news.ycombinator.com | 18 Apr 2024
    > Also, why aren't we size-sorting fields already?

    We are for struct/enum fields. https://camlorn.net/posts/April%202017/rust-struct-field-reo...

    There's even an unstable flag to help catch incorrect assumptions about struct layout. https://github.com/rust-lang/compiler-team/issues/457

  • Rust proposal for ABI for higher-level languages
    1 project | news.ycombinator.com | 12 Apr 2024
  • The Linux Kernel Prepares for Rust 1.77 Upgrade
    9 projects | news.ycombinator.com | 18 Feb 2024
    Are you talking about https://github.com/rust-lang/compiler-team/issues/688 ? I think that issue provides a lot of interesting context for this specific improvement.
  • Progress toward a GCC-based Rust compiler
    8 projects | news.ycombinator.com | 18 Dec 2023
    And mips64, which rustc recently dumped support for after their attempt to extort funding/resources from Loongson failed:

    https://github.com/rust-lang/compiler-team/issues/648

    This is the biggest problem with the LLVM mentality: they use architecture support as a means to extract support (i.e. salaried dev positions) from hardware companies.

    GNU may have annoyingly-higher standards for merging changes, but once it's in there and supported they will keep it for the long haul.

  • Cargo has never frustrated me like npm or pip has. Does Cargo ever get frustrating? Does anyone ever find themselves in dependency hell?
    13 projects | /r/rust | 6 Dec 2023
    See https://github.com/rust-lang/compiler-team/issues/688
  • Rust: Drop MIPS to Tier 3
    1 project | news.ycombinator.com | 16 Nov 2023
  • There is now a proposal to switch Rustc Nightly to use a parallel frontend
    1 project | /r/rust | 16 Oct 2023
    The work has been going on for some time now and it seems we are quite close to it being enabled as a default for nightly builds, I am super thrilled upwards of 20% faster clean builds and possibly more are on the horizon. Hope everything works out without triggering some unseen ICE. https://github.com/rust-lang/compiler-team/issues/681 Edit: If you want to discuss this feature reach out on Zulip
  • Rust 1.72.0
    7 projects | news.ycombinator.com | 24 Aug 2023
    I'd recommend reading the MCP[1] they linked regarding the decision as well as their target tier policy [2].

    They are dropping tier 1 support for Win 7 and Win 8. That means they are no longer going to guarantee that the project builds on those platforms and passes all tests via CI.

    As long as it is feasible they will probably keep CI runs for those platforms and if interested parties step up and provide sufficient maintenance support, it will remain tier 2. i.e a guarantee that it builds on those platforms via CI but not necessarily that all features are supported and guaranteed via passing tests.

    If interested parties can provide sufficient maintenance that all tests continue passing, it will be tier 1 in all but name. However the rest of the development community won't waste their time with issues like Win 7 and 8's partial support for UTF-8.

    And once CI stops being feasible for the compiler team to host, it'll drop down to tier 3. If there's sufficient interest from the community towards maintaining these targets, in practice you should see comparable support to with tiers 1 or 2 however now any CI will be managed externally by the community and the compiler team will stop worrying about changes that could break compilation on those targets.

    TLDR: They aren't saying "it'll no longer work" but rather "if you want it to stay maintained for these targets, you have to pitch in dev hours to maintain it and eventually support the infrastructure to do this because we don't see a reason to continue doing this". So if you care for these targets, you'll have to contribute to keep it maintained.

    [1]: https://github.com/rust-lang/compiler-team/issues/651

  • Experimental feature gate for `extern "crabi"` ABI
    1 project | /r/ProgrammingLanguages | 10 May 2023
  • Prerequisites for a Windows XP 3D game engine
    2 projects | /r/rust_gamedev | 19 Apr 2023
    (The already broken) XP support was removed almost 3 years ago: https://github.com/rust-lang/compiler-team/issues/378

Graal

Posts with mentions or reviews of Graal. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-17.
  • Java 23: The New Features Are Officially Announced
    5 projects | news.ycombinator.com | 17 Apr 2024
    Contrary to what vocal Kotlin advocates might believe, Kotlin only matters on Android, and that is thanks to Google pushing it no matter what.

    https://spectrum.ieee.org/the-top-programming-languages-2023

    https://snyk.io/reports/jvm-ecosystem-report-2021/

    And even so, they had to conceed Android and Kotlin on their own, without the Java ecosystem aren't really much useful, thus ART is now updatable via Play Store, and currently supports OpenJDK 17 LTS on Android 12 and later devices.

    As for your question regarding numbers, mostly Java 74.6%, C++ 13.7%, on the OpenJDK, other JVM implementations differ, e.g. GraalVM is mostly Java 91.8%, C 3.6%.

    https://github.com/openjdk/jdk

    https://github.com/oracle/graal

    Two examples from many others, https://en.wikipedia.org/wiki/List_of_Java_virtual_machines

  • FLaNK Stack 05 Feb 2024
    49 projects | dev.to | 5 Feb 2024
  • Apple releases Pkl – onfiguration as code language
    14 projects | news.ycombinator.com | 3 Feb 2024
    Pkl was built using the GraalVM Truffle framework. So it supports runtime compilation using Futurama Projections. We have been working with Apple on this for a while, and I am quite happy that we can finally read the sources!

    https://github.com/oracle/graal/tree/master/truffle

    Disclaimer: graalvm dev here.

  • Live Objects All the Way Down: Removing the Barriers Between Apps and VMs
    1 project | news.ycombinator.com | 8 Jan 2024
    That's pretty interesting. It's not as aggressive as Bee sounds, but the Espresso JVM is somewhat similar in concept. It's a full blown JVM written in Java with all the mod cons, which can either be compiled ahead of time down to memory-efficient native code giving something similar to a JVM written in C++, or run itself as a Java application on top of another JVM. In the latter mode it obviously doesn't achieve top-tier performance, but the advantage is you can easily hack on it using all the regular Java tools, including hotswapping using the debugger.

    When run like this, the bytecode interpreter, runtime system and JIT compiler are all regular Java that can be debugged, edited, explored in the IDE, recompiled quickly and so on. Only the GC is provided by the host system. If you compile it to native code, the GC is also written in Java (with some special conventions to allow for convenient direct memory access).

    What's most interesting is that Espresso isn't a direct translation of what a classical C++ VM would look like. It's built on the Truffle framework, so the code is extremely high level compared to traditional VM code. Details like how exactly transitions between the interpreter/compiled code happen, how you communicate pointer maps to the GC and so on are all abstracted away. You don't even have to invoke the JIT compiler manually, that's done for you too. The only code Espresso really needs is that which defines the semantics of the Java bytecode language and associated tools like the JDWP debugger protocol.

    https://github.com/oracle/graal/tree/master/espresso

    This design makes it easy to experiment with new VM features that would be too difficult or expensive to implement otherwise. For example it implements full hotswap capability that lets you arbitrarily redefine code and data on the fly. Espresso can also fully self-host recursively without limit, meaning you can achieve something like what's described in the paper by running Espresso on top of Espresso.

  • Crash report and loading time
    1 project | /r/fabricmc | 15 Nov 2023
    I'm also using GraalVM if that's of any help.
  • Quarkus 3.4 - Container-first Java Stack: Install with OpenJDK 21 and Create REST API
    7 projects | dev.to | 16 Oct 2023
    Quarkus is one of Java frameworks for microservices development and cloud-native deployment. It is developed as container-first stack and working with GraalVM and HotSpot virtual machines (VM).
  • Level-up your Java Debugging Skills with on-demand Debugging
    3 projects | news.ycombinator.com | 4 Oct 2023
    Apologies, I didn't mean to imply DCEVM went poof, just that I was sad it didn't make it into OpenJDK so one need not do JDK silliness between the production one and the "debugging one" since my experience is that's an absolutely stellar way to produce Heisenbugs

    And I'll be straight: Graal scares me 'cause Oracle but I just checked and it looks to the casual observer that it's straight-up GPLv2 now so maybe my fears need revisiting: https://github.com/oracle/graal/blob/vm-23.1.0/LICENSE

  • Rust vs Go: A Hands-On Comparison
    6 projects | news.ycombinator.com | 27 Sep 2023
    > to be compiled to a single executable is a strength that Java does not have

    I think this is very outdated claim: https://www.graalvm.org/

  • Leveraging Rust in our high-performance Java database
    3 projects | news.ycombinator.com | 20 Sep 2023
  • Java 21 makes me like Java again
    22 projects | news.ycombinator.com | 16 Sep 2023
    https://github.com/oracle/graal/issues/7182

What are some alternatives?

When comparing compiler-team and Graal you can also consider the following projects:

libvfio-user - framework for emulating devices in userspace

Liberica JDK - Free and 100% open source Progressive Java Runtime for modern Javaâ„¢ deployments supported by a leading OpenJDK contributor

llvm-mos - Port of LLVM to the MOS 6502 and related processors

Adopt Open JDK - Eclipse Temurinâ„¢ build scripts - common across all releases/versions

ua-parser-js - UAParser.js - Free & open-source JavaScript library to detect user's Browser, Engine, OS, CPU, and Device type/model. Runs either in browser (client-side) or node.js (server-side).

awesome-wasm-runtimes - A list of webassemby runtimes

namespacing-rfc - RFC for Packages as Optional Namespaces

SAP Machine - An OpenJDK release maintained and supported by SAP

cargo-show-asm - cargo subcommand showing the assembly, LLVM-IR and MIR generated for Rust code

maven-jpackage-template - Sample project illustrating building nice, small cross-platform JavaFX or Swing desktop apps with native installers while still using the standard Maven dependency system.

libgccjit-patches - Patches awaiting review for libgccjit

wasmer - 🚀 The leading Wasm Runtime supporting WASIX, WASI and Emscripten