From 88323c70e87331951982b1168c9edc9a25a2fd6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Manuel=20P=C3=A9gouri=C3=A9-Gonnard?= Date: Fri, 3 Apr 2015 14:38:02 +0200 Subject: [PATCH] Add option to replace inside strings for programs --- tmp/invoke-rename.sh | 9 +++++---- tmp/rename.pl | 14 ++++++++++++-- 2 files changed, 17 insertions(+), 6 deletions(-) diff --git a/tmp/invoke-rename.sh b/tmp/invoke-rename.sh index c0615f221..d27ba876d 100755 --- a/tmp/invoke-rename.sh +++ b/tmp/invoke-rename.sh @@ -2,11 +2,12 @@ # test result with: # make all check -# ggrep -i --exclude-dir=mpg --exclude=.travis.yml --exclude=ChangeLog --exclude=extra-names --exclude=public-names polarssl . --exclude-dir=tmp G -v 'include|OU?=PolarSSL|PolarSSLTes' | cut -d':' -f1 | sort -u +# ggrep -i --exclude-dir=mpg --exclude=.travis.yml --exclude=ChangeLog --exclude=extra-names --exclude=public-names polarssl . --exclude-dir=tmp G -v 'OU?=PolarSSL|PolarSSLTes' | cut -d':' -f1 | sort -u set -eu -FILES='include/mbedtls/*.h library/*.c programs/*.c programs/*/*.c tests/suites/* configs/*.h scripts/data_files/*.fmt scripts/* tests/scripts/*' +tmp/analyze-names.sh +tmp/makelist.pl public-names extra-names > old2new -tmp/rename.pl old2new $FILES -# re-invoke on programs including strings +tmp/rename.pl old2new include/mbedtls/*.h library/*.c tests/suites/* configs/*.h scripts/data_files/*.fmt scripts/* tests/scripts/* +tmp/rename.pl old2new programs/*.c programs/*/*.c diff --git a/tmp/rename.pl b/tmp/rename.pl index 56f2ce2ab..6fa22b379 100755 --- a/tmp/rename.pl +++ b/tmp/rename.pl @@ -9,7 +9,13 @@ use open qw(:std utf8); # apply substitutions from the table in the first arg to files # expected usage: via invoke-rename.pl -die "Usage: $0 names-file [filenames...]\n" if( @ARGV < 1 or ! -r $ARGV[0] ); +my $do_strings = 0; +if( $ARGV[0] eq "-s" ) { + shift; + $do_strings = 1; +} + +die "Usage: $0 [-s] names-file [filenames...]\n" if( @ARGV < 1 or ! -r $ARGV[0] ); open my $nfh, '<', shift or die; my @names = <$nfh>; @@ -27,6 +33,10 @@ my $space = qr/\s+/; my $idnum = qr/[a-zA-Z0-9_]+/; my $symbols = qr/[!#%&'()*+,-.:;<=>?@^_`{|}~\$\/\[\\\]]+|"/; +# if we replace inside strings, we don't consider them a token +my $token = $do_strings ? qr/$space|$idnum|$symbols/ + : qr/$string|$space|$idnum|$symbols/; + my %warnings; while( my $filename = shift ) @@ -40,7 +50,7 @@ while( my $filename = shift ) my @out; for my $line (@lines) { - my @words = ($line =~ /$string|$space|$idnum|$symbols/g); + my @words = ($line =~ /$token/g); my $checkline = join '', @words; if( $checkline eq $line ) { my @new = map { exists $subst{$_} ? $subst{$_} : $_ } @words;