As pointed out in the chatterbox, you could gain much by storing MD5 sums and file size + modification date, and on subsequent runs only recalculate it if size or modification time changes.

Additionally the construct md5_hex(<IN>) is not optimal, because it reads the file line by line (even though there is no reason to split it up into lines at all), and loads the whole thing into memory before starting to process. Using $ctx->addfile(*IN) (as described in the Digest::MD5 documentation) instead should be a lot faster.

Finally you should probably set binmode on the IN file handle.

Perl 6 - links to (nearly) everything that is Perl 6.

In reply to Re: Digest::MD5 seems to slow down script by moritz
in thread Digest::MD5 seems to slow down script by PerlScholar

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.