file_type

Crates.iofile_type
lib.rsfile_type
version
sourcesrc
created_at2025-01-02 20:24:35.846982+00
updated_at2025-04-03 21:31:19.018126+00
descriptionFile type detector
homepage
repositoryhttps://github.com/theseus-rs/file-type
max_upload_size
id1501844
Cargo.toml error:TOML parse error at line 19, column 1 | 19 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include`
size0
Brian Heineman (brianheineman)

documentation

README

file_type

ci Documentation Code Coverage Benchmarks Latest version License Semantic Versioning

Getting Started

File types are determined by examining a file or bytes against known file signatures and file extensions.

Signature, extension and media type data are provided by:

Example

Detect the file type from bytes:

use file_type::FileType;

let file_type = FileType::from_bytes(b"\xCA\xFE\xBA\xBE");
assert_eq!(file_type.extensions(), vec!["class"]);

Retrieve a file type from an extension:

use file_type::FileType;

let file_types = FileType::from_extension("png");
let file_type = file_types.first().expect("file format");
assert_eq!(file_type.media_types(), vec!["image/png"]);

Retrieve a file type from a media type:

use file_type::FileType;

let file_types = FileType::from_media_type("image/png");
let file_type = file_types.first().expect("file format");
assert_eq!(file_type.extensions(), vec!["png"]);

Feature flags

Name Description Default?
httpd Enables Apache HTTPD file types No
iana Enables IANA file types No
linguist Enables Linguist file types No
pronom Enables PRONOM file types No
std Enables support for the Rust standard library Yes
wikidata Enables Wikidata file types Yes

Supported File Types

List of supported file types

Safety

This crate uses #![forbid(unsafe_code)] to ensure everything is implemented in 100% safe Rust.

Performance

Comparative performance determining file type from bytes

theseus-rs/file-type - Bencher

Comparative performance determining file type from extension

theseus-rs/file-type - Bencher

Comparative performance determining file type from media type

theseus-rs/file-type - Bencher

License

Licensed under either of

Data is licensed under the following licenses:

Contribution

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.

VSCode Development Container
GitHub Codespaces
Commit count: 238

cargo fmt