#!/usr/bin/perl -w # Copyright (C) 2006, 2007, 2008 Apple Inc. All rights reserved. # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions # are met: # # 1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of # its contributors may be used to endorse or promote products derived # from this software without specific prior written permission. # # THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE # DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY # DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES # (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; # LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND # ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF # THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. # Script to do a rename in JavaScriptCore, WebCore, and WebKit. use strict; use File::Find; use FindBin; use Getopt::Long qw(:config pass_through); use lib $FindBin::Bin; use webkitdirs; use VCSUtils; setConfiguration(); chdirWebKit(); my $showHelp; my $verbose; my $programName = basename($0); my $usage = < \$showHelp, 'verbose|v' => \$verbose, ); if (!$getOptionsResult || $showHelp) { print STDERR $usage; exit 1; } my @directoriesToIgnoreList = ( "expected", "icu", ); my %directoriesToIgnore = map { $_ => 1 } @directoriesToIgnoreList; # find all files we want to process my @paths; find(\&wanted, "Source/JavaScriptCore"); find(\&wanted, "Source/WTF"); find(\&wanted, "Source/WebCore"); find(\&wanted, "Source/WebKit"); find(\&wanted, "Source/WebKit2"); find(\&wanted, "Tools/DumpRenderTree"); find(\&wanted, "Tools/TestWebKitAPI"); sub wanted { my $file = $_; # Ignore excluded and hidden files/directories. if ($directoriesToIgnore{$file} or $file =~ /^\../ or $file =~ /^ChangeLog/) { print "Ignoring $File::Find::name\n" if $verbose; $File::Find::prune = 1; return; } return if -d $file; push @paths, $File::Find::name; } # Setting isDOMTypeRename to 1 rather than 0 expands the regexps used # below to handle custom JavaScript bindings. my $isDOMTypeRename = 0; my %renames = ( # Renames go here in the form of: "JSDOMBuild" => "JSDOMConvert", ); my %renamesContemplatedForTheFuture = ( "PassRefPtr" => "DeprecatedPassRefPtr", "HTMLPlugInImageElement" => "HTMLEmbeddedObjectElement", "isPlugInImageElement" => "isEmbeddedObjectElement", "isHTMLPlugInImageElement" => "isHTMLEmbeddedObjectElement", "toHTMLPlugInImageElement" => "toHTMLEmbeddedObjectElement", "DOMObject" => "JSDOMObject", "DateInstance" => "JSDate", "ErrorInstance" => "JSError", "TreeShared" => "TreeRefCounted", "StringImpl" => "SharedString", "RenderView" => "RenderViewport", "ObjcFallbackObjectImp" => "ObjCFallbackObject", "RuntimeObjectImp" => "ForeignObject", "runtime_array" => "BridgedArray", "runtime_method" => "BridgedFunction", "runtime_object" => "BridgedObject", "objc_runtime" => "ObjCBridge", "WTF_UNICODE_H" => "Unicode_h", "WTF_UNICODE_ICU_H" => "UnicodeICU_h", "UnicodeIcu" => "UnicodeICU", "LegacyWebArchive" => "WebArchive", "LegacyWebArchive_h" => "WebArchive_h", "NativeFunctionWrapper_h" => "JSHostFunction_h", "NativeFunctionWrapper" => "JSHostFunction", "nativeFunctionThunk" => "hostFunctionThunk", "nativeFunction" => "hostFunction", "NativeFunction" => "HostFunction", ); # Sort the keys of the renames hash in order of decreasing length. This # handles the case where some of the renames are substrings of others; # i.e., "Foo" => "Bar" and "FooBuffer" => "BarBuffer". my @sortedRenameKeys = sort { length($b) - length($a) } keys %renames; # rename files sub renameFile { my $file = shift; if ($isDOMTypeRename) { # Find the longest key in %renames which matches this more permissive regexp. # (The old regexp would match ".../Foo.cpp" but not ".../JSFooCustom.cpp".) # This handles renaming of custom JavaScript bindings even when some of the # renames are substrings of others. The only reason we don't do this all the # time is to avoid accidental file renamings for short, non-DOM renames. for my $key (@sortedRenameKeys) { my $newFile = ""; $newFile = "$1$renames{$2}$3" if $file =~ /^(.*\/\w*)($key)(\w*\.\w+)$/; if ($newFile ne "") { return $newFile; } } } else { $file = "$1$renames{$2}$3" if $file =~ /^(.*\/)(\w+)(\.\w+)$/ && $renames{$2}; } return $file; } my %newFile; for my $file (sort @paths) { my $f = renameFile($file); if ($f ne $file) { $newFile{$file} = $f; } } for my $file (sort @paths) { if ($newFile{$file}) { my $newFile = $newFile{$file}; print "Renaming $file to $newFile\n"; scmMoveOrRenameFile($file, $newFile); } } # change all file contents for my $file (sort @paths) { $file = $newFile{$file} if $newFile{$file}; my $contents; { local $/; open FILE, $file or die "Failed to open $file"; $contents = ; close FILE; } my $newContents = $contents; if ($isDOMTypeRename) { for my $from (@sortedRenameKeys) { # Handle JavaScript custom bindings. $newContents =~ s/\b(JS|to|)$from/$1$renames{$from}/g; } } else { for my $from (@sortedRenameKeys) { $newContents =~ s/\b$from(?!["\w])/$renames{$from}/g; # this " unconfuses Xcode syntax highlighting } } # Remove the "virtual" keyword from virtual/override lines. # Should be a no-op but also OK to remove this any time, now that we have done it once. $newContents =~ s/^(\s*(\w+EXPORT\w*\s+)?)virtual ([^{;]+ override\b)/$1$3/mg; $newContents =~ s/^(\s*(\w+EXPORT\w*\s+)?)virtual ([^{;]+ final\b)/$1$3/mg; $newContents =~ s/\boverride\s+final\b/final/g; $newContents =~ s/\bfinal\s+override\b/final/g; if ($newContents ne $contents) { open FILE, ">", $file or die "Failed to open $file"; print FILE $newContents; close FILE; } }