mirror of
				https://github.com/Mbed-TLS/mbedtls.git
				synced 2025-10-27 12:15:33 +03:00 
			
		
		
		
	The official spelling of the trade mark changed from all-lowercase "mbed" to normal proper noun capitalization "Mbed" a few years ago. We've been using the new spelling in new text but still have the old spelling in a lot of text. This commit updates most occurrences of "mbed TLS": ``` sed -i -e 's/mbed TLS/Mbed TLS/g' $(git ls-files ':!ChangeLog' ':!tests/data_files/**' ':!tests/suites/*.data' ':!programs/x509/*' ':!configs/tfm*') ``` Justification for the omissions: * `ChangeLog`: historical text. * `test/data_files/**`, `tests/suites/*.data`, `programs/x509/*`: many occurrences are significant names in certificates and such. Changing the spelling would invalidate many signatures and tests. * `configs/tfm*`: this is an imported file. We'll follow the upstream updates. Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
		
			
				
	
	
		
			134 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			134 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Perl
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env perl
 | |
| #
 | |
| # Copyright The Mbed TLS Contributors
 | |
| # SPDX-License-Identifier: Apache-2.0
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| # not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| # http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| #
 | |
| # Purpose
 | |
| #
 | |
| # This script migrates application source code from the Mbed TLS 1.3 API to the
 | |
| # Mbed TLS 2.0 API.
 | |
| #
 | |
| # The script processes the given source code and renames identifiers - functions
 | |
| # types, enums etc, as
 | |
| #
 | |
| # Usage:  rename.pl [-f datafile] [-s] [--] [filenames...]
 | |
| #
 | |
| 
 | |
| use warnings;
 | |
| use strict;
 | |
| 
 | |
| use utf8;
 | |
| use Path::Class;
 | |
| use open qw(:std utf8);
 | |
| 
 | |
| my $usage = "Usage: $0 [-f datafile] [-s] [--] [filenames...]\n";
 | |
| 
 | |
| (my $datafile = $0) =~ s/rename.pl$/data_files\/rename-1.3-2.0.txt/;
 | |
| my $do_strings = 0;
 | |
| 
 | |
| while( @ARGV && $ARGV[0] =~ /^-/ ) {
 | |
|     my $opt = shift;
 | |
|     if( $opt eq '--' ) {
 | |
|         last;
 | |
|     } elsif( $opt eq '-f' ) {
 | |
|         $datafile = shift;
 | |
|     } elsif( $opt eq '-s' ) {
 | |
|         $do_strings = 1; shift;
 | |
|     } else {
 | |
|         die $usage;
 | |
|     }
 | |
| }
 | |
| 
 | |
| my %subst;
 | |
| open my $nfh, '<', $datafile or die "Could not read $datafile\n";
 | |
| my $ident = qr/[_A-Za-z][_A-Za-z0-9]*/;
 | |
| while( my $line = <$nfh> ) {
 | |
|     chomp $line;
 | |
|     my ( $old, $new ) = ( $line =~ /^($ident)\s+($ident)$/ );
 | |
|     if( ! $old || ! $new ) {
 | |
|         die "$0: $datafile:$.: bad input '$line'\n";
 | |
|     }
 | |
|     $subst{$old} = $new;
 | |
| }
 | |
| close $nfh or die;
 | |
| 
 | |
| my $string = qr/"(?:\\.|[^\\"])*"/;
 | |
| my $space = qr/\s+/;
 | |
| my $idnum = qr/[a-zA-Z0-9_]+/;
 | |
| my $symbols = qr/[-!#\$%&'()*+,.\/:;<=>?@[\\\]^_`{|}~]+|"/;
 | |
| 
 | |
| my $lib_include_dir = dir($0)->parent->parent->subdir('include', 'mbedtls');
 | |
| my $lib_source_dir = dir($0)->parent->parent->subdir('library');
 | |
| 
 | |
| # 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;
 | |
| 
 | |
| # If no files were passed, exit...
 | |
| if ( not defined($ARGV[0]) ){ die $usage; }
 | |
| 
 | |
| while( my $filename = shift )
 | |
| {
 | |
|     print STDERR "$filename... ";
 | |
| 
 | |
|     if( dir($filename)->parent eq $lib_include_dir ||
 | |
|          dir($filename)->parent eq $lib_source_dir )
 | |
|     {
 | |
|         die "Script cannot be executed on the Mbed TLS library itself.";
 | |
|     }
 | |
| 
 | |
|     if( -d $filename ) { print STDERR "skip (directory)\n"; next }
 | |
| 
 | |
|     open my $rfh, '<', $filename or die;
 | |
|     my @lines = <$rfh>;
 | |
|     close $rfh or die;
 | |
| 
 | |
|     my @out;
 | |
|     for my $line (@lines) {
 | |
|         if( $line =~ /#include/ ) {
 | |
|             $line =~ s/polarssl/mbedtls/;
 | |
|             $line =~ s/POLARSSL/MBEDTLS/;
 | |
|             push( @out, $line );
 | |
|             next;
 | |
|         }
 | |
| 
 | |
|         my @words = ($line =~ /$token/g);
 | |
|         my $checkline = join '', @words;
 | |
|         if( $checkline eq $line ) {
 | |
|             my @new = map { exists $subst{$_} ? $subst{$_} : $_ } @words;
 | |
|             push( @out, join '', @new );
 | |
|         } else {
 | |
|             $warnings{$filename} = [] unless $warnings{$filename};
 | |
|             push @{ $warnings{$filename} }, $line;
 | |
|             push( @out, $line );
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     open my $wfh, '>', $filename or die;
 | |
|     print $wfh $_ for @out;
 | |
|     close $wfh or die;
 | |
|     print STDERR "done\n";
 | |
| }
 | |
| 
 | |
| if( %warnings ) {
 | |
|     print "\nWarning: lines skipped due to unexpected characters:\n";
 | |
|     for my $filename (sort keys %warnings) {
 | |
|         print "in $filename:\n";
 | |
|         print for @{ $warnings{$filename} };
 | |
|     }
 | |
| }
 |