The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

App::rshasum - recursive shasum.

VERSION

version 0.10.0

SYNOPSIS

    rshasum --digest=SHA-256
    rshasum --digest=SHA-256 --skip='\.sw[a-zA-Z]*\z' --skip='~\z'
    rshasum --digest=SHA-256 --start-path='/home/random-j-user'

DESCRIPTION

A recursive digest calculator that prints digests for all files in a directory tree, as well as a total, summary, digest of the output.

FLAGS

--digest

The digest algorithm to use. Required. E.g:

    --digest=SHA-256
    --digest=SHA-512
    --digest=MD5

--skip

Perl 5 regexes which when matched against the relative paths, skip and prune them.

Can be specified more than one time.

--start-path

The start path for the traversal. Defaults to "." (the current working directory).

METHODS

run

Runs the app.

DEMO

    ~/progs/rshasum/App-rshasum/ rshasum --digest=MD5 --start .
    0556790e903a2fc303667096f90c6315  .tidyallrc
    931a4f3fc883b18717e6ef03dee71d74  Changes
    87181bcf0b5931d00583c4fa551a44d7  MANIFEST.SKIP
    033802795280cbc3651ee7fca1ee1609  bin/rshasum
    b1bf159fafba49e433c9daa6527889cf  dist.ini
    7ec9c5217c0c0883c8d35718840e5ee1  inc/Test/Run/Builder.pm
    ef6115acd4410c0a31f7cbf170b368d3  lib/App/rshasum.pm
    ab9cbcab840eda9a13d6b0c9234cb9b0  t/argv.t
    6f8db599de986fab7a21625b7916589c  t/data/1/0.txt
    2dae34ccf201ecf9a998b6cbac7d0170  t/data/1/2.txt
    d41d8cd98f00b204e9800998ecf8427e  t/data/1/foo/empty
    d41d8cd98f00b204e9800998ecf8427e  t/data/1/zempty
    0b79ca3f5ce0d456e864f0734edb9f93  t/run.t
    5463d4de034510c60218c60e48096797  weaver.ini
    b1e9362662fc9aea954284e694213352  -

( WARNING: do not use MD5 in production. )

SEE ALSO

https://github.com/rhash/RHash - "recursive hash". Seems to emit the tree in an unpredictable, not-always-sorted, order.

https://www.shlomifish.org/open-source/projects/File-Dir-Dumper/ - also on CPAN. Dumps metadata and supports caching the digests.

https://github.com/gokyle/rshasum - written in golang, but slurps entire files into memory (see https://github.com/gokyle/rshasum/issues/1 ).

SUPPORT

Websites

The following websites have more information about this module, and may be of help to you. As always, in addition to those websites please use your favorite search engine to discover more resources.

Bugs / Feature Requests

Please report any bugs or feature requests by email to bug-app-rshasum at rt.cpan.org, or through the web interface at https://rt.cpan.org/Public/Bug/Report.html?Queue=App-rshasum. You will be automatically notified of any progress on the request by the system.

Source Code

The code is open to the world, and available for you to hack on. Please feel free to browse it and play with it, or whatever. If you want to contribute patches, please send me a diff or prod me to pull from your repository :)

https://github.com/shlomif/rshasum

  git clone https://github.com/shlomif/rshasum.git

AUTHOR

Shlomi Fish <shlomif@cpan.org>

BUGS

Please report any bugs or feature requests on the bugtracker website https://github.com/shlomif/rshasum/issues

When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.

COPYRIGHT AND LICENSE

This software is Copyright (c) 2019 by Shlomi Fish.

This is free software, licensed under:

  The MIT (X11) License