| Crates.io | g2dem |
| lib.rs | g2dem |
| version | 0.1.0 |
| created_at | 2025-09-18 21:52:55.767316+00 |
| updated_at | 2025-09-18 21:52:55.767316+00 |
| description | `c++filt` clone cli tool for GNU V2 mangled symbols |
| homepage | |
| repository | https://github.com/Decompollaborate/gnuv2_demangle |
| max_upload_size | |
| id | 1845477 |
| size | 9,814 |
A c++filt clone cli tool for GNU V2 mangled symbols.
This crate demangles symbols for the outdated and no-longer-used V2 ABI mangling scheme of GNU g++. It is very unlikely this is actually the you are looking for, since this stuff is ancient.
Only use this crate if you are sure you want to use the g++ mangling scheme used in gcc 2.9 and older.
It is more likely you are looking for crates like
cpp_demangle,
symbolic-demangle
or cplus_demangle
Prebuilt binaries are available on the Github releases page.
Alternatively, you can install the latest version with Cargo. Note you'll need an updated Rust toolchain to install via Cargo.
cargo install g2dem --locked
Pass any number of symbols as arguments to g2dem to demangle them. If a name
can't be demangled then it will be echoed to stdout as-is.
$ g2dem do_thing__C6StupidRC6StupidT1 not_a_mangled_sym
Stupid::do_thing(Stupid const &, Stupid const &) const
not_a_mangled_sym
If no symbols are passed on the command line, then g2dem will read from
stdin instead.
$ echo do_thing__C6StupidRC6StupidT1 | g2dem
Stupid::do_thing(Stupid const &, Stupid const &) const
Pass --help to see other available options.
I implemented this crate by throwing a lot of symbols at an old version of
c++filt (2.9 ish), looking the output and trying to make sense of the
demangling process.
Because of this, you can expect some inconsistencies, mismangled symbols and other issues while using this crate. If you find any problem feel free to reach out via Github issues or a PR.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
This library follows Semantic Versioning. We try to always keep backwards compatibility, so no breaking changes should happen until a major release (i.e. jumping from 1.X.X to 2.0.0).
To see what changed on each release visit either the CHANGELOG.md file or check the releases page on Github. You can also use this link to check the latest release.