vectops
rpds
vectops | rpds | |
---|---|---|
1 | 3 | |
5 | 1,125 | |
- | - | |
2.3 | 7.6 | |
about 1 year ago | 3 months ago | |
Clojure | Rust | |
The Unlicense | Mozilla Public License 2.0 |
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.
vectops
-
How many clojure people just use a regular repl instead of emacs/cursive/calva/etc?
launch script like https://github.com/strojure/vectops/blob/default/test/dev/node_repl.cljc with command clj -m dev.node-repl
rpds
-
Getting both a mutable and immutable reference to a shared structure?
Another option I can think of - but not completely sure how one would implement in Rust - would be to never mutate the shared state, but rather when updating it - completely swapping it out with a completely new copy of the desired state. There's lots of different ways to go about doing this - each with their own trade offs. But using some form of Persistent Data Structure would probably be a good way to start. If you only have a single writer - then I believe using a Cell and simply updating which version of the structure is being read could work. rpds seems to be a decent start to look at these sorts of structures in Rust.
-
Learning Clojure made me return back to C/C++
Thanks for taking the time to provide a detailed response. Need to think on this. I had actually started a regular Clojure parser using LLVM as a hobby, but then my friend said it was better to implement this in a safe-memory and. save-concurrency language like Rust and leverage cranelift for code generation. So, now I am learning rust, lol. (Btw, Rust has a persistent data structures lib too: https://github.com/orium/rpds )
-
Persisting data that has revisions for values
Take a look at https://github.com/orium/rpds or one of the many others.
What are some alternatives?
ladder - A fast, simple persistent queue written in Java
hypergraph - Hypergraph is data structure library to create a directed hypergraph in which a hyperedge can join any number of vertices.
ecsharp - Home of LoycCore, the LES language of Loyc trees, the Enhanced C# parser, the LeMP macro preprocessor, and the LLLPG parser generator.
moodycamel - A fast multi-producer, multi-consumer lock-free concurrent queue for C++11
java-immutable-collections - Efficient Immutable/Persistent Collections for Java
rust-rocksdb - rust wrapper for rocksdb
functionaljava - Functional programming in Java
cranelift - Cranelift code generator
immutable - Thread-safe, persistent, immutable collections for the Crystal language
pest - The Elegant Parser
Weaviate - Weaviate is an open-source vector database that stores both objects and vectors, allowing for the combination of vector search with structured filtering with the fault tolerance and scalability of a cloud-native database.
bimap-rs - Generic bijective maps in Rust