| Reid Spencer | a60ff2e | 2004-07-26 22:52:44 +0000 | [diff] [blame] | 1 | #!/bin/sh | 
| Reid Spencer | 33709e5 | 2004-09-20 08:00:09 +0000 | [diff] [blame] | 2 | ##===- utils/llvmdo - Counts Lines Of Code -------------------*- Script -*-===## | 
 | 3 | #  | 
 | 4 | #                     The LLVM Compiler Infrastructure | 
 | 5 | # | 
| Chris Lattner | 3060910 | 2007-12-29 20:37:13 +0000 | [diff] [blame] | 6 | # This file is distributed under the University of Illinois Open Source | 
 | 7 | # License. See LICENSE.TXT for details. | 
| Reid Spencer | 33709e5 | 2004-09-20 08:00:09 +0000 | [diff] [blame] | 8 | #  | 
 | 9 | ##===----------------------------------------------------------------------===## | 
 | 10 | # | 
 | 11 | # This script is a general purpose "apply" function for the source files in LLVM | 
 | 12 | # It uses "find" to locate all the source files and then applies the user's  | 
 | 13 | # command to them. As such, this command is often not used by itself much but | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 14 | # the other find related tools (countloc.sh,llvmgrep,getsrcs.sh,userloc.sh) are | 
 | 15 | # all based on this script.  This script defines "what is a source file" in  | 
 | 16 | # LLVM and so should be maintained if new directories, new file extensions,  | 
 | 17 | # etc. are used in LLVM as it progresses. | 
| Reid Spencer | 33709e5 | 2004-09-20 08:00:09 +0000 | [diff] [blame] | 18 | # | 
 | 19 | # Usage: | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 20 | #  llvmdo [-topdir DIR] [-dirs "DIRNAMES..."] [-code-only] PROGRAM ARGS... | 
 | 21 | # | 
 | 22 | # The -topdir option allows you to specify the llvm source root directly. If it | 
 | 23 | # is not specified then it will be obtained with llvm-config which must be built | 
 | 24 | # and in your path. | 
| Reid Spencer | 33709e5 | 2004-09-20 08:00:09 +0000 | [diff] [blame] | 25 | # | 
 | 26 | # The -dirs argument allows you to specify the set of directories that are  | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 27 | # searched. The default list of directories searched is: | 
 | 28 | #   include lib tools utils runtime autoconf docs test examples projects | 
 | 29 | # Note that you must use quotes around the list of directory names.  | 
 | 30 | # | 
 | 31 | # The -code-only option specifies that only those files that are considered  | 
 | 32 | # "code" should be visited. HTML documentation is considered code, but things  | 
 | 33 | # like README files, etc. are not. | 
 | 34 | # | 
 | 35 | # Finally, you simply specify whatever program you want to run against each  | 
 | 36 | # file and the arguments to give it. The PROGRAM will be given the file name  | 
 | 37 | # as its last argument. | 
| Reid Spencer | 9610fc9 | 2004-09-20 08:04:13 +0000 | [diff] [blame] | 38 | ##===----------------------------------------------------------------------===## | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 39 |  | 
 | 40 | if test $# -lt 1 ; then | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 41 |   echo "Usage: llvmdo [-topdir DIR] [-dirs "DIRNAMES..."] [-code-only] PROGRAM ARGS..." | 
| Reid Spencer | 1e75b7b | 2006-08-11 21:53:27 +0000 | [diff] [blame] | 42 |   exit 1 | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 43 | fi | 
 | 44 |  | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 45 | if test "$1" = "-topdir" ; then | 
 | 46 |   TOPDIR="$2" | 
 | 47 |   shift; shift; | 
 | 48 | else | 
 | 49 |   TOPDIR=`llvm-config --src-root` | 
 | 50 | fi | 
 | 51 |  | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 52 | if test "$1" = "-dirs" ; then | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 53 |   LLVMDO_DIRS="$2" | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 54 |   shift ; shift | 
 | 55 | elif test -z "$LLVMDO_DIRS" ; then | 
| Reid Spencer | 33709e5 | 2004-09-20 08:00:09 +0000 | [diff] [blame] | 56 |   LLVMDO_DIRS="include lib tools utils runtime autoconf docs test examples projects" | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 57 | fi | 
| Reid Spencer | 956dae8 | 2006-08-13 18:28:27 +0000 | [diff] [blame] | 58 |  | 
 | 59 | if test "$1" = "-code-only" ; then | 
 | 60 |   CODE_ONLY="set" | 
 | 61 |   shift | 
 | 62 | else | 
 | 63 |   CODE_ONLY="" | 
 | 64 | fi | 
 | 65 |  | 
| Reid Spencer | 1e75b7b | 2006-08-11 21:53:27 +0000 | [diff] [blame] | 66 | if test "$1" = "" ; then | 
 | 67 |   echo "Missing program name to run" | 
 | 68 |   exit 1 | 
 | 69 | fi | 
 | 70 |  | 
| Reid Spencer | a60ff2e | 2004-07-26 22:52:44 +0000 | [diff] [blame] | 71 | PROGRAM=`which $1` | 
| Reid Spencer | 8141e37 | 2004-09-20 07:21:19 +0000 | [diff] [blame] | 72 | if test ! -x "$PROGRAM" ; then | 
| Reid Spencer | a60ff2e | 2004-07-26 22:52:44 +0000 | [diff] [blame] | 73 |   echo "Can't execute $1" | 
 | 74 |   exit 1 | 
 | 75 | fi | 
 | 76 | shift; | 
| Reid Spencer | 1e75b7b | 2006-08-11 21:53:27 +0000 | [diff] [blame] | 77 |  | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 78 | paths_to_ignore="\ | 
 | 79 |   -path */CVS -o \ | 
 | 80 |   -path */CVS/* -o \ | 
| Reid Spencer | 75f75b9 | 2007-07-04 01:35:32 +0000 | [diff] [blame] | 81 |   -path */.svn/ -o \ | 
 | 82 |   -path */.svn/* -o \ | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 83 |   -path docs/doxygen/* -o \ | 
 | 84 |   -path docs/CommandGuide/html/* -o \ | 
 | 85 |   -path docs/CommandGuide/man/* -o \ | 
 | 86 |   -path docs/CommandGuide/ps/* -o \ | 
 | 87 |   -path docs/CommandGuide/man/* -o \ | 
 | 88 |   -path docs/HistoricalNotes/* -o \ | 
 | 89 |   -path docs/img/* -o \ | 
 | 90 |   -path */.libs/* -o \ | 
 | 91 |   -path lib/Support/bzip2/* -o \ | 
 | 92 |   -path projects/llvm-test/* \ | 
 | 93 | " | 
 | 94 | files_to_match="\ | 
 | 95 |      -name *.ac \ | 
 | 96 |   -o -name *.b \ | 
 | 97 |   -o -name *.c \ | 
 | 98 |   -o -name *.cc \ | 
 | 99 |   -o -name *.cfg \ | 
 | 100 |   -o -name *.cpp \ | 
 | 101 |   -o -name *.css \ | 
 | 102 |   -o -name *.def \ | 
 | 103 |   -o -name *.el \ | 
 | 104 |   -o -name *.exp \ | 
 | 105 |   -o -name *.footer \ | 
 | 106 |   -o -name *.gnuplot' \ | 
 | 107 |   -o -name *.h \ | 
 | 108 |   -o -name *.header \ | 
 | 109 |   -o -name *.html \ | 
 | 110 |   -o -name *.in \ | 
 | 111 |   -o -name *.inc \ | 
 | 112 |   -o -name *.intro \ | 
 | 113 |   -o -name *.l \ | 
 | 114 |   -o -name *.ll \ | 
 | 115 |   -o -name *.llx \ | 
 | 116 |   -o -name *.lst \ | 
 | 117 |   -o -name *.m4 \ | 
 | 118 |   -o -name *.pod \ | 
 | 119 |   -o -name *.pl \ | 
 | 120 |   -o -name *.py \ | 
 | 121 |   -o -name *.sh \ | 
 | 122 |   -o -name *.schema \ | 
 | 123 |   -o -name *.st \ | 
 | 124 |   -o -name *.tcl \ | 
 | 125 |   -o -name *.td \ | 
 | 126 |   -o -name *.tr \ | 
 | 127 |   -o -name *.y \ | 
 | 128 |   -o -name Make* \ | 
 | 129 |   -o -name llvmdo \ | 
 | 130 |   -o -name llvmgrep \ | 
 | 131 |   -o -name check-each-file \ | 
 | 132 |   -o -name codgen-diff \ | 
 | 133 |   -o -name cvsupdate \ | 
 | 134 |   -o -name llvm-native-gcc \ | 
 | 135 |   -o -name llvm-native-gxx \ | 
 | 136 |   -o -name makellvm \ | 
 | 137 |   -o -path include/llvm/ADT/ilist \ | 
 | 138 |   -o -path test/\*.ll \ | 
 | 139 |   -o -path test/Scripts/not \ | 
 | 140 |   -o -path runtime/\*.ll \ | 
 | 141 | " | 
 | 142 | if test -z "$CODE_ONLY" ; then | 
 | 143 |   files_to_match="$files_to_match \ | 
 | 144 |     -o -name *.txt \ | 
 | 145 |     -o -name *.TXT \ | 
 | 146 |     -o -name *.vim \ | 
 | 147 |     -o -name vimrc \ | 
 | 148 |     -o -name README \ | 
 | 149 |     -o -name COPYING.LIB \ | 
 | 150 |     -o -name LICENSE* " | 
 | 151 | fi | 
 | 152 | files_to_ignore="\ | 
 | 153 |      -name \.* \ | 
 | 154 |   -o -name *~ \ | 
 | 155 |   -o -name #* \ | 
 | 156 |   -o -name *.cvs \ | 
 | 157 |   -o -name configure \ | 
 | 158 |   -o -name slow.ll \ | 
 | 159 |   -o -name *libtool* \ | 
 | 160 |   -o -name ltdl* \ | 
 | 161 |   -o -name ltdl.m4 \ | 
 | 162 |   -o -name ltmain.m4 \ | 
 | 163 |   -o -name ltmain.sh \ | 
 | 164 |   -o -name aclocal.m4 \ | 
 | 165 |   -o -name acinclude.m4 \ | 
 | 166 |   -o -name *VerifierIsReallySlow.llx \ | 
 | 167 |   -o -name *LoopSimplifyCrash.ll \ | 
 | 168 |   -o -name *AST-Remove.ll \ | 
 | 169 |   -o -name llvmAsmParser.cpp \ | 
 | 170 |   -o -name llvmAsmParser.h \ | 
 | 171 |   -o -name Lexer.cpp \ | 
 | 172 |   -o -name FileLexer.cpp \ | 
 | 173 |   -o -name FileParser.cpp \ | 
 | 174 |   -o -name FileParser.h \ | 
 | 175 |   -o -name StackerParser.h \ | 
 | 176 |   -o -name StackerParser.cpp \ | 
 | 177 |   -o -name ConfigLexer.cpp \ | 
 | 178 |   -o -name PPCPerfectShuffle.h \ | 
 | 179 | " | 
| Reid Spencer | 1e75b7b | 2006-08-11 21:53:27 +0000 | [diff] [blame] | 180 |  | 
| Reid Spencer | a60ff2e | 2004-07-26 22:52:44 +0000 | [diff] [blame] | 181 | if test -d "$TOPDIR" ; then | 
 | 182 |   cd $TOPDIR | 
| Reid Spencer | ca7592a | 2006-08-14 18:49:05 +0000 | [diff] [blame] | 183 |   # Have to use the right "find" on a per-platform basis. Most platforms have | 
 | 184 |   # Gnu find as "find", but Solaris does not. | 
| Reid Spencer | 054defa | 2004-10-07 16:03:21 +0000 | [diff] [blame] | 185 |   case `uname -s` in | 
 | 186 |     SunOS) find_prog=gfind ;; | 
 | 187 |     *) find_prog=find ;; | 
 | 188 |   esac | 
| Reid Spencer | 956dae8 | 2006-08-13 18:28:27 +0000 | [diff] [blame] | 189 |   # Turn off file name generation (globbing) so that substitution of the | 
 | 190 |   # variables doesn't cause the shell to create lists of file names | 
 | 191 |   set -f | 
| Reid Spencer | 054defa | 2004-10-07 16:03:21 +0000 | [diff] [blame] | 192 |   $find_prog $LLVMDO_DIRS -type f \ | 
| Reid Spencer | 956dae8 | 2006-08-13 18:28:27 +0000 | [diff] [blame] | 193 |     \( $paths_to_ignore \) -prune \ | 
 | 194 |     -o \( \( $files_to_match \) \! \( $files_to_ignore \) \ | 
 | 195 |     -exec $PROGRAM "$@" {} \; \) | 
| Reid Spencer | a60ff2e | 2004-07-26 22:52:44 +0000 | [diff] [blame] | 196 | else | 
 | 197 |   echo "Can't find LLVM top directory in $TOPDIR" | 
 | 198 | fi |