blob: 8998f7675e8d4c75e3bfc036185a64302c942bb7 [file] [log] [blame]
#!/usr/bin/env perl
# 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 warnings;
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 = <<EOF;
Usage: $programName [options]
-h|--help Show this help message
-v|--verbose More verbose output
EOF
my $getOptionsResult = GetOptions(
'help|h' => \$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/WebKitLegacy");
find(\&wanted, "Source/WebKit");
find(\&wanted, "Tools/gdb");
find(\&wanted, "Tools/lldb");
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:
"AtomicString" => "AtomString",
"AtomicStringCreationFromLiteral" => "AtomStringCreationFromLiteral",
"AtomicStringCreationFromLiteralUniqueness" => "AtomStringCreationFromLiteralUniqueness",
"AtomicStringExistingHash" => "AtomStringExistingHash",
"AtomicStringFromLiteralCannotOverflow" => "AtomStringFromLiteralCannotOverflow",
"AtomicStringFromLiteralNotEmpty" => "AtomStringFromLiteralNotEmpty",
"AtomicStringHash" => "AtomStringHash",
"AtomicStringImpl" => "AtomStringImpl",
"AtomicStringImplCF" => "AtomStringImplCF",
"AtomicStringNumberDouble" => "AtomStringNumberDouble",
"AtomicStringTable" => "AtomStringTable",
"AtomicStringTable" => "AtomStringTable",
"AtomicStringTableLocker" => "AtomStringTableLocker",
"AtomicString_h" => "AtomString_h",
"IDLAtomicStringAdaptor" => "IDLAtomStringAdaptor",
"IDLRequiresExistingAtomicStringAdaptor" => "IDLRequiresExistingAtomStringAdaptor",
"RequiresExistingAtomicString" => "RequiresExistingAtomString",
"StringImplNullSymbolToAtomicString" => "StringImplNullSymbolToAtomString",
"StringImplStaticToAtomicString" => "StringImplStaticToAtomString",
"StringImplSymbolToAtomicString" => "StringImplSymbolToAtomString",
"ToAtomicString" => "ToAtomString",
"ToAtomicStringOnEmpty" => "ToAtomStringOnEmpty",
"TokenAtomicStringInitializer" => "TokenAtomStringInitializer",
"WTFAtomicStringPrinter" => "WTFAtomStringPrinter",
"WTFAtomicString_SummaryProvider" => "WTFAtomString_SummaryProvider",
"atomicString" => "atomString",
"atomicString1" => "atomString1",
"atomicString2" => "atomString2",
"atomicStringTable" => "atomStringTable",
"atomicStringWithTemplate" => "atomStringWithTemplate",
"atomicStrings" => "atomStrings",
"checkCurrentAtomicStringTable" => "checkCurrentAtomStringTable",
"existingAtomicString" => "existingAtomString",
"existingEntryAtomicStringTable" => "existingEntryAtomStringTable",
"getPropertyNameAtomicString" => "getPropertyNameAtomString",
"getValueNameAtomicString" => "getValueNameAtomString",
"isAtomic" => "isAtom",
"isAtomicString" => "isAtomString",
"isInAtomicStringTable" => "isInAtomStringTable",
"m_atomicStringTable" => "m_atomStringTable",
"m_currentAtomicStringTable" => "m_currentAtomStringTable",
"m_defaultAtomicStringTable" => "m_defaultAtomStringTable",
"m_entryAtomicStringTable" => "m_entryAtomStringTable",
"oldAtomicStringTable" => "oldAtomStringTable",
"propertyNameToAtomicString" => "propertyNameToAtomString",
"resolveRopeToAtomicString" => "resolveRopeToAtomString",
"resolveRopeToExistingAtomicString" => "resolveRopeToExistingAtomString",
"setCurrentAtomicStringTable" => "setCurrentAtomStringTable",
"shouldUseAtomicString" => "shouldUseAtomString",
"testAtomicStringNumber" => "testAtomStringNumber",
"toAtomicString" => "toAtomString",
"toExistingAtomicString" => "toExistingAtomString",
"useAtomicString" => "useAtomString",
);
my %renamesContemplatedForTheFuture = (
"setDOMException" => "propagateException",
"setDOMExceptionSlow" => "propagateExceptionSlowPath",
"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 = <FILE>;
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\b/$renames{$from}/g; # this " unconfuses Xcode syntax highlighting
}
}
if ($newContents ne $contents) {
open FILE, ">", $file or die "Failed to open $file";
print FILE $newContents;
close FILE;
}
}