diff options
author | jmmv <jmmv@pkgsrc.org> | 2012-10-13 15:31:23 +0000 |
---|---|---|
committer | jmmv <jmmv@pkgsrc.org> | 2012-10-13 15:31:23 +0000 |
commit | a95d3bd5efa293647cec67c66f414ef746394e5c (patch) | |
tree | a2f49df80baad85e6e5890ae951bc309e65a339d | |
parent | 361625efbe828a8014d872d7eb221192b7588114 (diff) | |
download | pkgsrc-a95d3bd5efa293647cec67c66f414ef746394e5c.tar.gz |
Speed up the algorithm to determine the files left to check.
This change modifies the algorithm used to keep track of the files that
have not yet been checksummed to use a simple loop instead of shell pattern
matching.
For packages with few distinfo entries, either way yields the same result
as the list of files to check is very short. But for those packages with
hundreds of distinfo entries (vim, I'm looking at you), the difference is
huge. In my old macppc machine, the checksum of vim used to take around
40 minutes and now it takes ~35 seconds. The difference is also clearly
visible in my faster amd64 machine (although I haven't bothered to time it).
-rwxr-xr-x | mk/checksum/checksum | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/mk/checksum/checksum b/mk/checksum/checksum index ba0ad67faf2..6bba786bd60 100755 --- a/mk/checksum/checksum +++ b/mk/checksum/checksum @@ -1,6 +1,6 @@ #!/bin/sh # -# $NetBSD: checksum,v 1.12 2007/08/15 13:56:24 jlam Exp $ +# $NetBSD: checksum,v 1.13 2012/10/13 15:31:23 jmmv Exp $ # # Copyright (c) 2006, 2007 The NetBSD Foundation, Inc. # All rights reserved. @@ -156,17 +156,12 @@ fi ${TEST} -z "$patch" || sfile="${sfile##*/}" ${TEST} "$d_file" = "($sfile)" || continue - case "$files_left" in - "$file"|"$file "*) pre= ;; - *" $file") pre="${files_left%% $file}" ;; - *) pre="${files_left%% $file *} " ;; - esac - case "$files_left" in - "$file"|*" $file") post= ;; - "$file "*) post="${files_left##$file }" ;; - *) post="${files_left##* $file }" ;; - esac - files_left="${pre}${post}" + new_files_left= + for file_left in $files_left; do + ${TEST} "${file_left}" = "${file}" || \ + new_files_left="${new_files_left} ${file_left}" + done + files_left="${new_files_left}" if ${TEST} "$d_checksum" = "IGNORE"; then ${ECHO} 1>&2 "$self: Ignoring checksum for $sfile" |