15 releases (stable)

1.0.10 Oct 2, 2023
1.0.9 Jun 16, 2023
1.0.7 Dec 17, 2022
1.0.6 Sep 28, 2022
0.1.0 Apr 26, 2019

#66 in Command line utilities

Download history 13/week @ 2024-07-21 21/week @ 2024-07-28 16/week @ 2024-08-04 13/week @ 2024-08-11 16/week @ 2024-08-18 16/week @ 2024-08-25 15/week @ 2024-09-01 16/week @ 2024-09-08 16/week @ 2024-09-15 27/week @ 2024-09-22 31/week @ 2024-09-29 26/week @ 2024-10-06 18/week @ 2024-10-13 17/week @ 2024-10-20 14/week @ 2024-10-27 11/week @ 2024-11-03

66 downloads per month

MIT/Apache

13KB
223 lines

sha1dir

github crates.io build status

Compute a checksum of a directory tree, for example to validate that a directory was copied successfully to a different machine.

Installation

$ RUSTFLAGS='-C target-cpu=native' cargo install sha1dir

Usage

Run sha1dir to checksum the current directory, or run sha1dir path/to/dir1 path/to/dir2 ... to checksum one or more other directories.

Behavior

The checksum is computed as the bitwise XOR of SHA-1 hashes one per directory entry. The hash for each directory entry is the hash of the following body:

  • For regular files — the one byte 'f', 4 little endian bytes for the path length, the bytes of the path, 4 little endian bytes for the Unix file mode as given by st_mode, and finally the file contents.

  • For symbolic links — the one byte 'l', the path length / path / mode as for regular files, and then the path of the link target.

  • For directories — the one byte 'd', and the path length / path / mode.

The resulting checksum is 160 bits wide like SHA-1.


License

Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~3–8.5MB
~80K SLoC