#find #largest #file #smallest

bin+lib lrg

A utility to help find the largest file(s) in a directory

3 releases (breaking)

0.3.0 Dec 25, 2018
0.2.0 Nov 18, 2018
0.1.0 Nov 17, 2018

#1691 in Filesystem

MIT license

25KB
286 lines

lrg

A utility to help find the largest file(s) in a directory

Linux build status Coverage Status

Requirements

Building the binary (only tested on macOS and linux)

# First clone the repo:
git clone git@github.com:noahrinehart/lrg.git
# cd into it:
cd lrg
# Build it:
cargo build --release
# The binary will be in ./target/release/lrg

Examples

Check https://docs.rs/lrg/ for the full docs

Using the binary

To find the largest files in the current directory (by default, it searches the current directory, and only fetches the top 5):

./lrg

To search another directory (such as the home directory):

./lrg $HOME

To only search in the current directory and not recurse through others:

./lrg -r

Full Usage

lrg 0.3.0
Noah Rinehart <rinehart.noah@gmail.com>
A utility to help find the largest file(s) in a directory

USAGE:
    lrg [FLAGS] [OPTIONS] [FILEPATH]

FLAGS:
    -b, --absolute        outputs files' absolute path (default: false)
    -a, --ascending       sort the results in ascending order (default: false)
    -i, --directories     include directories in search (default: false)
    -l, --follow-links    will follow links of files (default: false)
    -r, --no-recursion    will only visit files in specified directory, takes precedence over max-depth (default: false)
    -h, --help            Prints help information
    -V, --version         Prints version information

OPTIONS:
    -d, --max-depth <MAX_DEPTH>    sets the maximum depth of folders to search, unless --no-recursion specified
                                   (default: max possible)
    -n, --number <NUM_ENTRIES>     sets the number of files to list (default: 5)
    -u, --units <UNITS>            sets the units to display: decimal for 1000KB, binary for 1024KiB, conventional for
                                   1024KB (default: conventional)

ARGS:
    <FILEPATH>    the path to search in

Using the library

First, add the crate to your project (check for which version you would like to use, or just put * to use the latest):

# Cargo.toml
lrg = "0.3.0"

Then, add extern create lrg at the top of your project.

To find the largest files in a directory:

use std::path::Path;
use lrg::{Lrg, LrgOptions, DirEntry, SortBy};
// Get a path to some directory (or file)
let path = Path::new("./some/path");
// Create the Lrg object to store the entries
let mut lrg: Lrg = Lrg::new(path, &LrgOptions::default());
// Sort and get the entries
let mut entries: Vec<DirEntry> = lrg.sort_by(SortBy::Descending).get_entries();
// You can also call `sort_descending`
entries = lrg.sort_descending().get_entries();
// These calls mutate the underlying struct, so calling:
entries = lrg.get_entries();
// Will give you the same as the call before it

To find the smallest files in a directory:

let path = Path::new("./some/other/path");
let mut lrg: Lrg = Lrg::new(path, &LrgOptions::default());
let entries: Vec<DirEntry> = lrg.sort_ascending().get_entries();

To search using a custom function:

let path = Path::new("./another/path");
let mut lrg: Lrg = Lrg::new(path, &LrgOptions::default());
// Sort by filename (note: not the full path)
lrg.sort_by_custom(|a: &DirEntry, b: &DirEntry| {
    a.file_name().cmp(b.file_name())
});
let entries: Vec<DirEntry> = lrg.get_entries();

Dependencies

~4–12MB
~125K SLoC