1#!/usr/bin/perl -w 2 3# Copyright (C) 2005 Apple Computer, Inc. All rights reserved. 4# 5# Redistribution and use in source and binary forms, with or without 6# modification, are permitted provided that the following conditions 7# are met: 8# 9# 1. Redistributions of source code must retain the above copyright 10# notice, this list of conditions and the following disclaimer. 11# 2. Redistributions in binary form must reproduce the above copyright 12# notice, this list of conditions and the following disclaimer in the 13# documentation and/or other materials provided with the distribution. 14# 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of 15# its contributors may be used to endorse or promote products derived 16# from this software without specific prior written permission. 17# 18# THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY 19# EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 20# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 21# DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY 22# DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 23# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 24# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 25# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 27# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 29# "find-extra-includes" script for WebKit Open Source Project 30 31use strict; 32use File::Find; 33 34find(\&wanted, @ARGV ? @ARGV : "."); 35 36my %paths; 37my %includes; 38 39sub wanted 40{ 41 my $file = $_; 42 43 if ($file eq "icu") { 44 $File::Find::prune = 1; 45 return; 46 } 47 48 if ($file !~ /^\./ && $file =~ /\.(h|cpp|c|mm|m)$/) { 49 $paths{$file} = $File::Find::name; 50 open FILE, $file or die; 51 while (<FILE>) { 52 if (m-^\s*#\s*(include|import)\s+["<]((\S+/)*)(\S+)[">]-) { 53 my $include = ($2 eq "sys/" ? $2 : "") . $4; 54 $includes{$file}{$include}++; 55 } 56 } 57 close FILE; 58 } 59} 60 61my %totalIncludes; 62 63sub fillOut 64{ 65 my ($file) = @_; 66 67 return if defined $totalIncludes{$file}; 68 69 for my $include (keys %{ $includes{$file} }) { 70 $totalIncludes{$file}{$include} = 1; 71 fillOut($include); 72 for my $i (keys %{ $totalIncludes{$include} }) { 73 $totalIncludes{$file}{$i} = 1; 74 } 75 } 76} 77 78sub check 79{ 80 my ($file) = @_; 81 82 for my $include (keys %{ $includes{$file} }) { 83 fillOut($include); 84 } 85 for my $i1 (sort keys %{ $includes{$file} }) { 86 for my $i2 (keys %{ $includes{$file} }) { 87 next if $i1 eq $i2; 88 if ($totalIncludes{$i2}{$i1}) { 89 my $b1 = $i1; 90 my $b2 = $file; 91 $b1 =~ s/\..+$//; 92 $b2 =~ s/\..+$//; 93 print "$paths{$file} does not need to include $i1, because $i2 does\n" if $b1 ne $b2; 94 last; 95 } 96 } 97 } 98} 99 100for my $file (sort keys %includes) { 101 check($file); 102} 103