eadf / cpp_map.rs

A simple C++ std::map emulator for Rust

Home Page:https://crates.io/crates/cpp_map

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Latest version Documentation Workflow Workflow dependency status license

cpp_map.rs

A simple C++ std::map emulator for Rust. Probably not useful for anyone.

I needed a data structure that could emulate a C++ std::map, and it's pointer based iterators. More specifically it needs to emulate the insertion position hint functionality as the keys I intend to use are not entirely transitive. i.e., searching for insertion position from the head or tail makes a big difference.

I also needed to be able to replace the key of an already inserted item w/o altering the order. - Don't ask.

Another gotcha is that a C++ std::map::insert(key, value) is a NOP if the key already exists, not even the new value will be used.

The current implementation uses a double linked Vec list, and it only supports sequential search.

License

Licensed under either of

at your option.

About

A simple C++ std::map emulator for Rust

https://crates.io/crates/cpp_map

License:Apache License 2.0


Languages

Language:Rust 100.0%