Clipper2
Polygon Clipping and Offsetting - C++, C# and Delphi (by AngusJohnson)
roxmltree
Represent an XML document as a read-only tree. (by RazrFalcon)
Clipper2 | roxmltree | |
---|---|---|
1 | 4 | |
1,265 | 403 | |
- | - | |
8.9 | 7.3 | |
5 days ago | 4 months ago | |
C++ | Rust | |
Boost Software License 1.0 | 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.
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.
Clipper2
Posts with mentions or reviews of Clipper2.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-06-09.
-
What are the scenarios where "Rewrite it in Rust" didn't meet your expectations or couldn't be successfully implemented?
I tried to rewrite Clipper2 in Rust. There's a C#, a Delphi and a C++ implementation, so how hard can it be?
roxmltree
Posts with mentions or reviews of roxmltree.
We have used some of these posts to build our list of alternatives
and similar projects. The last one was on 2023-06-09.
-
What are the scenarios where "Rewrite it in Rust" didn't meet your expectations or couldn't be successfully implemented?
This is exactly what I needed when implementing xml-mut :D I have used roxmltree instead and manipulated text directly. will try to rewrite it using Xot.
-
Surprises in the Rust JSON Ecosystem
In regards to the benchmarks, It makes sense to measure serializing/deserializing for parser crates. but since we are talking about dom implementations, metrics like traversal/iteration speed or insert/modification performance would be useful. a good example is roxmltree crate (readonly xml dom) which benches traversal/iteration performance and shows that by only focusing on readonly usecases, it gains substantial performance gains.
-
What are some less popular but well-made crates you'd like others to know about?
For xml parsing, I find https://github.com/RazrFalcon/roxmltree as a really good crate. It’s fast, light, and well documented/maintained. I have so much respect for the maintainer’s approach to merging PRs and the way they consider what’s important for the crate
-
fast-float - a super-fast float parser in Rust
I understand. But I've also wrote enough parsers and performance sensitive code in Rust (ttf-parser, tiny-skia, roxmltree). And in my experience, unsafe is not needed in 99% of the cases. Even something as performance sensitive as tiny-skia is unsafe-free (with some nuances).
What are some alternatives?
When comparing Clipper2 and roxmltree you can also consider the following projects:
polybooljs - Boolean operations on polygons (union, intersection, difference, xor)
fast-float-rust - Super-fast float parser in Rust (now part of Rust core)
xml-mut - xml mutation language resembling sql
json - Strongly typed JSON library for Rust
Relm4 - Build truly native applications with ease!
quick-xml - Rust high performance xml reader and writer
rust-openssl - OpenSSL bindings for Rust
log4rs - A highly configurable logging framework for Rust
CircleMUD - Unofficial mirror of the CircleMUD engine.
rust - Empowering everyone to build reliable and efficient software.
VulkanDemo - A cross-platform spike using Vulkan to render a complex, lit and shadowed environment.
cargo-fuzz - Command line helpers for fuzzing