Ryan Anderson <[EMAIL PROTECTED]> writes: > +open(F,"-|","git-ls-files") > + or die "Failed to open pipe from git-ls-files: " . $!; > + > [EMAIL PROTECTED] = <F>; > +close(F);
We can afford to handle funny characters in the filename right without pain in Perl, so let's do it right: use vars qw($/); $/ = "\0"; open F, '-|', 'git-ls-files', '-z' or die "Failed to open pipe from git-ls-files: " . $!; @allfiles = map { chomp; $_} <F>; > [EMAIL PROTECTED] = grep /^$src/, @allfiles; > [EMAIL PROTECTED] = @srcfiles; > +s#^$src(/|$)#$dst$1# for @dstfiles; Be careful with these regexps. Perhaps something like this? @dstfiles = @srcfiles = grep /^\Q$src\E/, @allfiles; s#^\Q$src\E(/|$)#$dst$1# for @dstfiles; or perhaps a bit more readable: my $qsrc = quotemeta($src); @dstfiles = @srcfiles = grep /^$qsrc/, @allfiles; for (@dstfiles) { s/^$qsrc(/|$)/$dst$1/; } > +rename($src,$dst) > + or die "rename failed: $!"; Making sure leading directories for $dst exists, perhaps? Otherwise looks good. > +sub usage($) { This is just a style thing, but do you really care to force a scalar contect when "usage" is used? - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html