SorteryLib

A fast file-sorting library based on the Sortery command-line file sorter. Along with fast sorting, SorteryLib comes with an easy-to-use File type, which is compatible with many other types, such as String, str, std::path::Path, std::path::PathBuf, and of course File.

Basic Usage

For more in-depth usage information, see the SorteryLib Docs. Here is a basic usage example:

```rust use sorterylib::prelude::*; // Import all the stuff needed for basic operation

fn main() { // The fields for initializing the Sorter struct let source = File::new("/path/to/source/dir/"); let target = File::new("/path/to/target/dir/"); let dateformat = String::from("%Y"); let datetype = String::from("m"); let preservename = true; let excludetype = vec![String::from("txt")]; let only_type = Vec::new();

// Create the Sorter instance
let sorter = Sorter {
    source: source.copy(), // The directory from which to get all the files to sort
    target: target.copy(), // The directory to sort all the files into
    date_format: date_format, // The date format to rename the files using.
    date_type: date_type, // The date type to sort the files by
    preserve_name: preserve_name, // Whether to include the old file name in the new name
    exclude_type: exclude_type, // File type(s) to exclude
    only_type: only_type // File type(s) to exclusively sort. Overrides `exclude_type`
};

// Run the sorting algorithm
sorter.sort(false);

} ```