X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=Debian%2FDgit.pm;h=a453f352718b33a5567e040cdd9302973c40b279;hb=37e3be3b6a61e26f9836d3575531ba716818b134;hp=d66b712bc86af9ba104a88cc0bbac06e375d2370;hpb=d6be829bf56e699d27d388026d4af7ab710ba328;p=dgit.git diff --git a/Debian/Dgit.pm b/Debian/Dgit.pm index d66b712b..a453f352 100644 --- a/Debian/Dgit.pm +++ b/Debian/Dgit.pm @@ -26,7 +26,7 @@ BEGIN { initdebug enabledebug enabledebuglevel printdebug debugcmd $debugprefix *debuglevel *DEBUG - shellquote printcmd); + shellquote printcmd messagequote); # implicitly uses $main::us %EXPORT_TAGS = ( policyflags => [qw(NOFFCHECK FRESHREPO)] ); @EXPORT_OK = @{ $EXPORT_TAGS{policyflags} }; @@ -81,12 +81,22 @@ sub printdebug { print DEBUG $debugprefix, @_ or die $! if $debuglevel>0; } +sub messagequote ($) { + local ($_) = @_; + s{\\}{\\\\}g; + s{\n}{\\n}g; + s{\x08}{\\b}g; + s{\t}{\\t}g; + s{[\000-\037\177]}{ sprintf "\\x%02x", ord $& }ge; + $_; +} + sub shellquote { my @out; local $_; foreach my $a (@_) { $_ = $a; - if (!length || m{[^-=_./0-9a-z]}i) { + if (!length || m{[^-=_./:0-9a-z]}i) { s{['\\]}{'\\$&'}g; push @out, "'$_'"; } else {