filemagic-rs

Build Status Documentation

filemagic is a Rust wrapper for libmagic, the library that supports the file command on most Unix systems. The package provides a simple Rust API for identifying files using the extensive database of magic strings that ships with libmagic. It can also load a custom database of magic strings.

Requirements

Usage

Adding dependency to your Cargo.toml file ```toml filemagic = { git = "https://github.com/marirs/filemagic-rs", branch = "master" }

```

Using Macros

fn main() { let testfilepath = "/path/to/file"; let magic = magic!().expect("error");

println!("{}", magic.file(&testfilepath).expect("error")); } ```

fn main() { let testfilepath = "/path/to/file"; let databases = vec!["data/db-images-png"];

let magic = magic!(,&databases).expect("error");

println!("{}", magic.file(&testfilepath).expect("error")); } ```


Using the function

fn main() { let testfilepath = "/path/to/file"; // Create a new default configuration let cookie = Magic::open(Default::default()).expect("error"); cookie.load::(&[]).expect("error"); let magic = cookie.file(&testfilepath).expect("error in magic"); println!("magic= {}", magic); } ```

fn main() { // Create a new default configuration let cookie = Magic::open(Default::default()).expect("error"); // Load one specific magic database let databases = vec!["data/db-images-png"]; assert!(cookie.load(&databases).is_ok());

// Recognize the magic of a test file
let test_file_path = "data/rust-logo-128x128-blk.png";
let expected_magic = "PNG image data, 128 x 128, 8-bit/color RGBA, non-interlaced";
assert_eq!(cookie.file(&test_file_path).unwrap(), expected_magic);

} ```


To generate the docs

bash cargo doc --release


References: - robo9k rust-magic & rust-magic-sys - Aaron Iles