This is a mirror of the GitLab repo! https://gitlab.com/Lynnesbian/fif
Find a file
2021-02-28 21:08:35 +10:00
.idea jetbrains nonsense 2021-02-28 21:08:11 +10:00
src default to WARN logging if RUST_LOG is unspecified 2021-02-28 21:01:22 +10:00
.drone.yml added a python script for testing and a drone config for CI 2021-02-28 21:08:35 +10:00
.gitignore added a python script for testing and a drone config for CI 2021-02-28 21:08:35 +10:00
Cargo.lock tests and more! 2021-02-28 19:47:18 +10:00
Cargo.toml added a python script for testing and a drone config for CI 2021-02-28 21:08:35 +10:00
clippy.sh slightly better readme 2021-02-22 02:08:08 +10:00
Cross.toml windows support! and other stuff 2021-02-20 03:57:36 +10:00
LICENSE better error handling and pattern matching, added license 2021-02-05 15:57:21 +10:00
README.md updated readme uwu! 2021-02-27 12:43:15 +10:00
rusftmt.toml added rustfmt.toml, ran rustfmt 2021-02-18 19:48:55 +10:00
test.py added a python script for testing and a drone config for CI 2021-02-28 21:08:35 +10:00

fif

Crates.io Crates.io Minimum Supported Rust Version

A command-line tool for detecting and optionally correcting files with incorrect extensions.

Installation

Default backend

cargo install --locked fif

Other backends

fif supports using infer or xdg-mime as its backend for looking up file types. By default, xdg-mime will be used on Linux, and infer on all other systems.

xdg-mime should work on any Unixy system with libmagic/file(1) installed, although I've only tested it on Linux. infer should work on any system.

You can override the default backend for your system at compile time like so:

# xdg-mime
cargo install --features=xdg-mime-backend
# infer
cargo install --features=infer-backend

Usage

See fif --help for more.

The basics

The simplest way to use fif looks like this:

fif -E images ~/Pictures

This command will scan all of the files with extensions used by image files (.jpg, .png, etc) in your ~/Pictures directory.

You can also manually specify a set of extensions to use:

fif -e jpeg,jpg,zip,docx ~/Documents

By default, fif will output a bash script that can be used to fix all the files it found with incorrect file extensions. You might find it useful to output this script to a file (rather than to stdout):

fif -E images ~/Pictures > output.sh

More coming soon!