https://github.com/ergrelet/cpplumber
Static analysis tool based on clang, which detects source-to-binary information leaks in C and C++ projects
https://github.com/ergrelet/cpplumber
anti-reversing c clang continuous-integration cpp devsecops obfuscation rust static-analysis
Last synced: 4 months ago
JSON representation
Static analysis tool based on clang, which detects source-to-binary information leaks in C and C++ projects
- Host: GitHub
- URL: https://github.com/ergrelet/cpplumber
- Owner: ergrelet
- License: gpl-3.0
- Created: 2022-08-06T18:11:09.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-10-02T18:58:34.000Z (about 3 years ago)
- Last Synced: 2025-04-27T15:49:18.251Z (6 months ago)
- Topics: anti-reversing, c, clang, continuous-integration, cpp, devsecops, obfuscation, rust, static-analysis
- Language: Rust
- Homepage: https://ergrelet.github.io/cpplumber/
- Size: 211 KB
- Stars: 85
- Watchers: 5
- Forks: 6
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# cpplumber [](https://img.shields.io/badge/license-GPL--3.0-blue.svg) [](https://img.shields.io/badge/rust-1.63.0%2B-orange.svg) [](https://github.com/ergrelet/cpplumber/actions?query=workflow%3ATests) [](https://coveralls.io/github/ergrelet/cpplumber?branch=main)
Cpplumber is a static analysis tool that helps detecting and keeping track of C
and C++ source code information that leaks into compiled executable files.The project is written in Rust and depends on libclang, so it's cross-platform and
can be used on projects that use the latest C and C++ standards.## Key Features
* Supports JSON compilation databases
* Tracks leaks of string literals, struct names and class names
* Allows filtering reported leaks through a YAML configuration file
* Generates raw text and JSON reports## Quick Example
Imagine you have a source file `file1.c` that you compiled into `a.out` and
you want to know if some string literal ended up in `a.out`, you can simply do:
```
$ cpplumber --bin a.out file1.c
[2022-09-24T19:57:14Z INFO cpplumber] Gathering source files...
[2022-09-24T19:57:14Z INFO cpplumber] Filtering suppressed files...
[2022-09-24T19:57:14Z INFO cpplumber] Extracting artifacts from source files...
[2022-09-24T19:57:15Z INFO cpplumber] Filtering suppressed artifacts...
[2022-09-24T19:57:15Z INFO cpplumber] Looking for leaks in 'a.out'...
"My_Super_Secret_API_Key" (string literal) leaked at offset 0x14f20 in "/full/path/to/a.out" [declared at /full/path/to/file1.c:5]
Error: Leaks detected!
```## Documentation
The full user documentation is available [here](https://ergrelet.github.io/cpplumber/)
(and also [here](https://github.com/ergrelet/cpplumber/blob/gh-pages/index.md)
as Markdown).## How to Build
Rust version 1.63.0 or greater is needed to build the project.
```
git clone https://github.com/ergrelet/cpplumber.git
cd cpplumber
cargo build --release
```## How to Install
If you have Rust installed, you can easily install Cpplumber with `cargo`:
```
cargo install --git https://github.com/ergrelet/cpplumber --tag 0.1.0
```After that, you can invoke `cpplumber` from anywhere through the command-line.
Keep in mind that you need to have the required dependencies installed for
`cpplumber` to run properly. Check out the user documentation for more details.