egui VS ada-spark-rfcs

Compare egui vs ada-spark-rfcs and see what are their differences.

egui

egui: an easy-to-use immediate mode GUI in pure Rust (by mwcampbell)

ada-spark-rfcs

Platform to submit RFCs for the Ada & SPARK languages (by AdaCore)
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
egui ada-spark-rfcs
3 13
1 59
- -
0.0 2.8
29 days ago 10 days ago
Rust
Apache License 2.0 -
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.

egui

Posts with mentions or reviews of egui. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-10-18.
  • Why Rust?
    15 projects | news.ycombinator.com | 18 Oct 2022
    Anyone who's interested in the AccessKit integration can play with my work-in-progress branch: https://github.com/mwcampbell/egui/tree/accesskit

    It's currently Windows-only, and I'm working on the big missing feature, which is text editing support.

  • UIs are not pure functions of the model
    5 projects | news.ycombinator.com | 4 Jul 2022
    > A core premise of Cocoa, and MVC in general, is that UIs are a projection of data into a different form of data, specifically bits on a screen.

    This is a tangent, but the implicit assumption that the UI is visual is just begging for a response from an accessibility perspective, so here goes.

    Accessibility is very much an afterthought in native GUIs, not only in Cocoa, but also in Windows with the UI Automation API, and AFAIK with other native accessibility APIs as well. With these APIs, the assistive technology (e.g. screen reader) pulls information from the application (usually via the GUI toolkit), through repeated calls to methods defined by the accessibility API. Often the AT has to do several such calls in a row (and those often translate to multiple IPC round trips, making things slow). And the UI might change between such calls; there's no guaranteed way to get a consistent snapshot of the whole thing, as there is with a visual frame. On the application/toolkit side, these methods may return different responses from one call to the next, and the application or toolkit has to fire the right events when things change.

    The web improves on this, in that accessibility information is conveyed through HTML tags and attributes. And yes, this is included in the output of a React component's render function. So while in practice, implementing accessibility may still be an afterthought, it's not an architectural afterthought as it is in native platforms.

    One of my goals in AccessKit [1] is to work around this shortcoming of native accessibility APIs, particularly for developers of cross-platform non-web GUI toolkits. In AccessKit, the toolkit pushes a full or incremental accessibility tree update to the AccessKit platform adapter, which maintains the full tree in memory and uses that to implement the platform accessibility API. This even works for immediate-mode GUIs, as one can see in my proof-of-concept integration with the Rust egui toolkit [2].

    [1]: https://github.com/AccessKit/accesskit

    [2]: https://github.com/mwcampbell/egui/tree/accesskit

  • Raygui – A simple and easy-to-use immediate-mode GUI library
    6 projects | news.ycombinator.com | 26 Mar 2022
    I can also report some modest progress on my own work on accessibility of immediate-mode GUIs. I have a branch of the Rust egui library [1] that has basic accessibility on Windows using my AccessKit project [2]. I do have a long way to go to make this fully usable and ready to submit upstream, especially when taking non-Windows platforms into account.

    [1]: https://github.com/mwcampbell/egui/tree/accesskit

    [2]: https://github.com/AccessKit/accesskit

ada-spark-rfcs

Posts with mentions or reviews of ada-spark-rfcs. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-05-08.
  • Ada news digest April 2022
    2 projects | /r/ada | 8 May 2023
    Original discussion was there, I guess you can post your comments to that PR to keep the discussion in one place.
  • Is Maintaining An Ada ISO Standard Worthwhile?
    1 project | /r/ada | 7 May 2023
    I forgot where I saw it, but I do recall reading somewhere that the ARG had discussed whether a shorter revision cycle would be better or not. I wouldn't be surprised if the creation of this ( https://github.com/AdaCore/ada-spark-rfcs ) was inspired by that discussion.
  • Brett Slatkin: Why am I building a new functional programming language?
    10 projects | news.ycombinator.com | 5 Mar 2023
    Ada might be getting pattern matching soon too:

    https://github.com/AdaCore/ada-spark-rfcs/blob/master/protot...

  • Why Rust?
    15 projects | news.ycombinator.com | 18 Oct 2022
    > I did some ADA in the past and yes, it is a nice language, but it lacks the modernity and a dynamic community like Rust. ADA did received some nice update to its specification, but, just like C++, it struggle / cannot really fit the latest innovation in programming language that easily.

    I'm still learning both Ada and Rust, nevertheless I humbly disagree. The more I learn it and other "old" languages the more it looks to me like "modern" ones rediscover things that have been present in other languages for years.

    The really significant difference I can see for now is that Ada is not focused so strongly on functional programming paradigm. Rust borrow checker is a strong success of course and was another significant difference, but latest SPARK got borrow checking capabilities too, AFAIK.

    While Ada's open-source community is smaller, I find it as energetic and devoted to improving the ecosystem as Rust's. I have no idea about closed-source community, but in the past 4 years ArianeGroup [1], Airbus [2] and Nvidia [3] talked about choosing Ada for their high-integrity applications.

    > And to be fair, it is fine. ADA is very much a "committee" language (its spec are ISO/IEC) instead of a "community" language (all the spec and rfc of Rust are on github and anyone can easily discuss them).

    You can discuss Ada/SPARK RFCs here: https://github.com/AdaCore/ada-spark-rfcs . I think I once saw on Ada forum or chat that someone proposing changes to the language was simply invited to talk to people working on the standard, so it doesn't look like the language is developed in isolation or something.

    > This makes it so that ADA doesn't get the attention, and the rapidity of innovation, that a language like Rust does, but ADA is mostly made for program that will need to be maintained in critical operations for decades with the code being maintainable and compilable far into the future.

    I think that Ada adopted quiet quickly to standards set by Rust: lower entry barrier toolchain, compelling licensing, library distribution, RFCs, etc. And in terms of language features, in many areas it's not only on par, but ahead of competition. So you're less likely to see lots of changes, but they do happen nevertheless. I'm not saying Ada is perfect, of course. There are parts of it that other languages do better. No shame in that.

    IMHO, the reason Ada is unknown to many people is a combination of its past, myths surrounding it, and general trend of people to follow trends. ;) But I currently find Ada/SPARK even more compelling option than Rust, even though I like both.

    [1] https://www.facebook.com/ArianeGroup/posts/2872955946126067

  • Lessons from Learning Ada in 2021
    1 project | news.ycombinator.com | 9 Feb 2022
  • RFC on exceptional contracts for SPARK
    1 project | /r/ada | 5 Jan 2022
  • [RFC] declare local variables without a declare block
    1 project | /r/ada | 3 Nov 2021
  • Does ada support object methods?
    1 project | /r/ada | 26 Oct 2021
    There's a proposal to allow dot syntax for untagged types as well.
  • It's Ada Lovelace Day Learn the Ada Programming Language in 2021
    1 project | news.ycombinator.com | 12 Oct 2021
    There's also an active discussion about adding format strings to the language here: https://github.com/AdaCore/ada-spark-rfcs/pull/77
  • Looking for feedback about the syntax for format strings in Ada
    1 project | /r/ada | 29 Sep 2021

What are some alternatives?

When comparing egui and ada-spark-rfcs you can also consider the following projects:

fidget - Figma based UI library for nim, with HTML and OpenGL backends.

cortex-gnat-rts - This project contains various GNAT Ada Run Time Systems (RTSs) targeted at Cortex boards: so far, the Arduino Due, the STM32F4-series evaluation boards from STMicroelectronics, and the BBC micro:bit (v1)

react-community-tools-practices-cheatsheet - Descriptions and use cases for common tools and practices in the React community

Kind - A next-gen functional language

imgui - Dear ImGui: Bloat-free Graphical User interface for C++ with minimal dependencies

falcon.py - A python implementation of the signature scheme Falcon

raygui - A simple and easy-to-use immediate-mode gui library

ada-spark-rfcs - Platform to submit RFCs for the Ada & SPARK languages

accesskit - UI accessibility infrastructure across platforms and programming languages

mini-pinball-machine - A mini pinball machine based on the Raspberry Pi 4 with a laser-cut enclosure and custom software.