sha1dir

Crates.iosha1dir
lib.rssha1dir
version1.0.10
sourcesrc
created_at2019-04-26 06:10:04.369167
updated_at2023-10-02 05:46:42.642707
descriptionChecksum of a directory tree
homepage
repositoryhttps://github.com/dtolnay/sha1dir
max_upload_size
id130258
size36,746
Lanthanum (github:zxtn:lanthanum)

documentation

README

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.
Commit count: 112

cargo fmt