rpm-ostree VS cxx

Compare rpm-ostree vs cxx and see what are their differences.

rpm-ostree

⚛📦 Hybrid image/package system with atomic upgrades and package layering (by coreos)

cxx

Safe interop between Rust and C++ (by dtolnay)
Our great sponsors
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • WorkOS - The modern identity platform for B2B SaaS
  • SaaSHub - Software Alternatives and Reviews
rpm-ostree cxx
47 97
813 5,485
2.1% -
9.6 9.3
5 days ago 4 days ago
C Rust
GNU General Public License v3.0 or later 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.

rpm-ostree

Posts with mentions or reviews of rpm-ostree. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-13.
  • What do you prefer more and why?
    3 projects | /r/Fedora | 13 Jun 2023
    I definitely agree that immutability offers considerable value in regards to improving security. But arguably it's insufficient to pull the win over mutable Fedora due to the losses caused by the inability to install the kernel-hardened package and the lack of UKI (Unified Kernel Image) support.
  • Looking to test out fedora Silverblue. I have only 1 question
    1 project | /r/Fedora | 5 May 2023
    Issue: https://github.com/coreos/rpm-ostree/issues/3944
  • What is the difference between Immutable Desktops and non Immutable Desktops?
    4 projects | /r/linuxquestions | 30 Apr 2023
    Oversimplifying might have been the most sensible in this context. However, you might have gone a little bit too far as your description fits only NixOS, Guix and distros that utilize rpm-ostree.
  • Universal Blue is a new paradigm for the Linux desktop and it's brilliant
    1 project | /r/linuxmasterrace | 25 Apr 2023
    here's the documentation of ostree (the package manager)
  • Fedora Silverblue 38: rpm-ostree crashes
    1 project | /r/Fedora | 20 Apr 2023
    Now... this was VERY alarming to say the least, so I went online and did indeed find an issue on GitHub.
  • Fedora Linux 38 released!
    4 projects | /r/Fedora | 18 Apr 2023
  • The New website is here, with modern UI. And getfedora.org redirect to fedoraproject.org with fresh look.😃
    1 project | /r/Fedora | 18 Apr 2023
    And there are still some issues with layering. Some packages that don't behave or follow standards will modify files in /usr/local, which isn't supported, so you simply won't be able to install them on Silverblue. I think it's the same for /opt as well. (https://github.com/coreos/rpm-ostree/issues/233) This means it fundamentally can't do everything Workstation can, which is unfortunate.
  • Flatcar Container Linux
    14 projects | news.ycombinator.com | 9 Apr 2023
    ublue is based off of fedora and rpm-ostree, which is what "CoreOS" is today.

    What happened was old school CoreOS was A/B partition based: https://github.com/coreos/docs/blob/master/os/sdk-disk-parti...

    My memory is hazy but here's how I remember it: After Red Hat acquired CoreOS they rebased the entire thing around rpm-ostree, which is the CoreOS people know today: https://coreos.github.io/rpm-ostree/

    At the time there was some anxiety in the community as to what would happen, as there was no direct upgrade path from old CoreOS to new CoreOS. Theoretically if we all believed the kool-aid we were drinking it's just a redeploy, no pets!

    Kinvolk came along, forked it, and made Flatcar Linux, which kept the A/B partitioning system, and more crucially, let you just change a config file and all your old CoreOS nodes would just move to Flatcar and then you were good to go. So now if you wanted to stay on the system you were comfortable with you could just use Flatcar. If the composability of rpm-ostree attracted you then new CoreOS have you covered. Red Hat deserves a hat tip here because in their documentation/blog they explicitly mentioned Flatcar as an option for people who wanted to stick with what they know, which I thought was cool and how I discovered it!

    Later on Microsoft acquired Kinvolk and and then people raised eyebrows. I have not checked in a while but the folks involved continued to do their thing and run it like a good OSS project, hold public meetings, all that stuff.

    I use both and they're both high quality.

  • Immutable Linux Distributions for Those Looking to Embrace the Future
    7 projects | news.ycombinator.com | 31 Mar 2023
    Whenever I was looking at using CoreOS, I was somewhat disheartened that automatic reboots weren't built in: https://github.com/coreos/rpm-ostree/issues/2831. Has this changed? I know zincati has maintenance window support, which would also be nice to have.
  • [HELP] AMD REST BUG
    2 projects | /r/VFIO | 27 Mar 2023
    Doesn't look like it https://github.com/coreos/rpm-ostree/issues/1091

cxx

Posts with mentions or reviews of cxx. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-12-07.
  • Rust is having a positive effect in C/C++
    2 projects | /r/rust | 7 Dec 2023
    There are cxx and autocxx, what else do you propose to do?
  • Interoperability: Swift’s Super Power
    1 project | news.ycombinator.com | 22 Sep 2023
    I would like to see a comparison of how this compares to Rust. In terms of interoperability it has Cxx (https://cxx.rs) to offer safe bindings to C++ but also has great support for Android, Linux and many other systems. You don't even need to hack together Windows bindings (as explained in the blog post) because Microsoft offers official bindings (https://crates.io/crates/windows). I'm not sure if I'd call it a superpower if any potential interoperability has to be written to be used (compared to it already being available). Or rather, in comparison to what is interoperability a Swift superpower? Certainly not C++ or C which can be used in a far wider set of targets.
  • Rust Cryptography Should Be Written in Rust
    10 projects | news.ycombinator.com | 26 Aug 2023
    We selected Qt as a cross-platform solution. The C++/Rust interface is the clunkiest and ugliest part of the application, and rather complex because some state is shared between several windows in the GUI and several threads in the backend, and any component might modify that state at any time, and updates have to be transmitted to the other components without introducing inconsistencies. Using cxx [1] helped a little, though.

    The project began in 2020, and I'm not sure what I'd choose as a GUI framework today – definitely not Qt Widgets, though.

    [1] https://cxx.rs/

  • Link a C static library to rust cargo project
    2 projects | /r/rust | 24 Jun 2023
    If the build process for the C library isn't too involved I recommend using cxx bridge (https://cxx.rs/) and letting cargo handle the build and linking. cxx basically allows you to describe the bidirectional interface (although it sounds like you only need 1 direction, which is fine too) in Rust code and it provides a "good enough" API for compiling C code inside the build.rs file.
  • ffizz: Build a Beautiful C API in Rust
    6 projects | dev.to | 20 Jun 2023
    The tooling for the first kind -- calling Rust from another language -- is a bit less developed, and tends to rely on code generation that doesn't necessarily produce a natural C API. cbindgen, uniffi, cxx, and Diplomat all take this course.
  • Best practices in creating a Rust API for a C++ library? Seeking advice from those who've done it before.
    7 projects | /r/rust | 26 May 2023
    I would like to utilize OMPL's functionality in Rust code, so I want to call into OMPL C++ code somehow in Rust. I've seen two (non-mutually-exclusive) options so far: - rust-cpp, which allows you to write C++ code in Rust within the cpp!() macro. - cxx, which allows you to define both sides of the FFI boundary manually (as opposed to bindgen's automatic generation).
  • Hey Rustaceans! Got a question? Ask here (20/2023)!
    4 projects | /r/rust | 15 May 2023
    I'm not sure how to do this in cxx; issues like https://github.com/dtolnay/cxx/issues/447 suggest that this isn't settled yet?
  • Hello r/Rust! We are Meta Engineers who created the Open Source Buck2 Build System! Ask us anything! [Mod approved]
    9 projects | /r/rust | 3 May 2023
    I use non-vendored dependencies for the Buck build in https://github.com/dtolnay/cxx.
  • Microsoft is rewriting core Windows libraries in Rust
    6 projects | /r/programming | 29 Apr 2023
    There's also the cpp and cxx crates for doing C++/Rust interop, but they probably aren't appropriate to use in all cases. The C ABI is definitely the safest way to go unless you're really trying to marry Rust and C++ code bases, not just writing library bindings.
  • How can I use rust libraries in C++
    2 projects | /r/cpp_questions | 16 Apr 2023
    There's also cxx (can't vouch for it personally but it claims to make things a lot easier) https://github.com/dtolnay/cxx

What are some alternatives?

When comparing rpm-ostree and cxx you can also consider the following projects:

ostree - Operating system and container binary deployment and upgrades

cbindgen - A project for generating C bindings from Rust code

vscode-remote-release - Visual Studio Code Remote Development: Open any folder in WSL, in a Docker container, or on a remote machine using SSH and take advantage of VS Code's full feature set.

rust-bindgen - Automatically generates Rust FFI bindings to C (and some C++) libraries.

openvpn-install - OpenVPN road warrior installer for Ubuntu, Debian, AlmaLinux, Rocky Linux, CentOS and Fedora

autocxx - Tool for safe ergonomic Rust/C++ interop driven from existing C++ headers

tectonic - A modernized, complete, self-contained TeX/LaTeX engine, powered by XeTeX and TeXLive.

uniffi-rs - a multi-language bindings generator for rust

distrobox - Use any linux distribution inside your terminal. Enable both backward and forward compatibility with software and freedom to use whatever distribution you’re more comfortable with. Mirror available at: https://gitlab.com/89luca89/distrobox

rust-cpp - Embed C++ directly inside your rust code!

com.unity.UnityHub

ritual - Use C++ libraries from Rust