fuzzcheck 0.1.0

A coverage-guided, structure-aware fuzzing engine for Rust functions
Documentation
use std::env;
use std::path::Path;
use std::process::Command;

fn main() {
    let out_dir = env::var("OUT_DIR").unwrap();
    // note that there are a number of downsides to this approach, the comments
    // below detail how to improve the portability of these commands.
    Command::new("gcc")
        .args(&["src/code_coverage_sensor/c_builtins.c", "-c", "-fPIC", "-o"])
        .arg(&format!("{}/c_builtins.o", out_dir))
        .status()
        .unwrap();
    Command::new("ar")
        .args(&["crus", "libc_builtins.a", "c_builtins.o"])
        .current_dir(&Path::new(&out_dir))
        .status()
        .unwrap();

    println!("cargo:rustc-link-search=native={}", out_dir);
    println!("cargo:rustc-link-lib=static=c_builtins");
}