#build-dependencies #cpp

build cxx-build

C++ code generator for integrating cxx crate into a Cargo build

195 stable releases

1.0.194 Jan 21, 2026
1.0.192 Dec 16, 2025
1.0.190 Nov 28, 2025
1.0.161 Jul 19, 2025
0.3.4 May 22, 2020

#48 in Build Utils

Download history 463772/week @ 2026-01-19 471614/week @ 2026-01-26 537858/week @ 2026-02-02 582978/week @ 2026-02-09 559747/week @ 2026-02-16 594343/week @ 2026-02-23 664667/week @ 2026-03-02 690649/week @ 2026-03-09 637160/week @ 2026-03-16 716703/week @ 2026-03-23 664365/week @ 2026-03-30 733360/week @ 2026-04-06 746383/week @ 2026-04-13 735846/week @ 2026-04-20 706048/week @ 2026-04-27 636218/week @ 2026-05-04

2,862,930 downloads per month
Used in 730 crates (234 directly)

MIT/Apache

410KB
11K SLoC

The CXX code generator for constructing and compiling C++ code.

This is intended to be used from Cargo build scripts to execute CXX's C++ code generator, set up any additional compiler flags depending on the use case, and make the C++ compiler invocation.


Example

Example of a canonical Cargo build script that builds a CXX bridge:

// build.rs

fn main() {
    cxx_build::bridge("src/main.rs")
        .file("src/demo.cc")
        .std("c++11")
        .compile("cxxbridge-demo");

    println!("cargo:rerun-if-changed=src/demo.cc");
    println!("cargo:rerun-if-changed=include/demo.h");
}

A runnable working setup with this build script is shown in the demo directory of https://github.com/dtolnay/cxx.


Alternatives

For use in non-Cargo builds like Bazel or Buck, CXX provides an alternate way of invoking the C++ code generator as a standalone command line tool. The tool is packaged as the cxxbridge-cmd crate.

$ cargo install cxxbridge-cmd  # or build it from the repo

$ cxxbridge src/main.rs --header > path/to/mybridge.h
$ cxxbridge src/main.rs > path/to/mybridge.cc

Dependencies

~2.5–5MB
~90K SLoC