|  | #!/bin/sh | 
|  | ##===- utils/llvmdo - Counts Lines Of Code -------------------*- Script -*-===## | 
|  | # | 
|  | #                     The LLVM Compiler Infrastructure | 
|  | # | 
|  | # This file is distributed under the University of Illinois Open Source | 
|  | # License. See LICENSE.TXT for details. | 
|  | # | 
|  | ##===----------------------------------------------------------------------===## | 
|  | # | 
|  | # This script is a general purpose "apply" function for the source files in LLVM | 
|  | # It uses "find" to locate all the source files and then applies the user's | 
|  | # command to them. As such, this command is often not used by itself much but | 
|  | # the other find related tools (countloc.sh,llvmgrep,getsrcs.sh,userloc.sh) are | 
|  | # all based on this script.  This script defines "what is a source file" in | 
|  | # LLVM and so should be maintained if new directories, new file extensions, | 
|  | # etc. are used in LLVM as it progresses. | 
|  | # | 
|  | # Usage: | 
|  | #  llvmdo [-topdir DIR] [-dirs "DIRNAMES..."] [-code-only] PROGRAM ARGS... | 
|  | # | 
|  | # The -topdir option allows you to specify the llvm source root directly. If it | 
|  | # is not specified then it will be obtained with llvm-config which must be built | 
|  | # and in your path. | 
|  | # | 
|  | # The -dirs argument allows you to specify the set of directories that are | 
|  | # searched. The default list of directories searched is: | 
|  | #   include lib tools utils runtime autoconf docs test examples projects | 
|  | # Note that you must use quotes around the list of directory names. | 
|  | # | 
|  | # The -code-only option specifies that only those files that are considered | 
|  | # "code" should be visited. HTML documentation is considered code, but things | 
|  | # like README files, etc. are not. | 
|  | # | 
|  | # Finally, you simply specify whatever program you want to run against each | 
|  | # file and the arguments to give it. The PROGRAM will be given the file name | 
|  | # as its last argument. | 
|  | ##===----------------------------------------------------------------------===## | 
|  |  | 
|  | if test $# -lt 1 ; then | 
|  | echo "Usage: llvmdo [-topdir DIR] [-dirs "DIRNAMES..."] [-code-only] PROGRAM ARGS..." | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | if test "$1" = "-topdir" ; then | 
|  | TOPDIR="$2" | 
|  | shift; shift; | 
|  | else | 
|  | TOPDIR=`llvm-config --src-root` | 
|  | fi | 
|  |  | 
|  | if test "$1" = "-dirs" ; then | 
|  | LLVMDO_DIRS="$2" | 
|  | shift ; shift | 
|  | elif test -z "$LLVMDO_DIRS" ; then | 
|  | LLVMDO_DIRS="include lib tools utils runtime autoconf docs test examples projects cmake" | 
|  | fi | 
|  |  | 
|  | if test "$1" = "-code-only" ; then | 
|  | CODE_ONLY="set" | 
|  | shift | 
|  | else | 
|  | CODE_ONLY="" | 
|  | fi | 
|  |  | 
|  | if test "$1" = "" ; then | 
|  | echo "Missing program name to run" | 
|  | exit 1 | 
|  | fi | 
|  |  | 
|  | PROGRAM=`which $1` | 
|  | if test ! -x "$PROGRAM" ; then | 
|  | echo "Can't execute $1" | 
|  | exit 1 | 
|  | fi | 
|  | shift; | 
|  |  | 
|  | paths_to_ignore="\ | 
|  | -path */.svn/ -o \ | 
|  | -path */.svn/* -o \ | 
|  | -path docs/doxygen/* -o \ | 
|  | -path docs/CommandGuide/html/* -o \ | 
|  | -path docs/CommandGuide/man/* -o \ | 
|  | -path docs/CommandGuide/ps/* -o \ | 
|  | -path docs/CommandGuide/man/* -o \ | 
|  | -path docs/HistoricalNotes/* -o \ | 
|  | -path docs/img/* -o \ | 
|  | -path */.libs/* -o \ | 
|  | -path lib/Support/bzip2/* -o \ | 
|  | -path projects/llvm-test/* \ | 
|  | " | 
|  | files_to_match="\ | 
|  | -name *.ac \ | 
|  | -o -name *.b \ | 
|  | -o -name *.c \ | 
|  | -o -name *.cc \ | 
|  | -o -name *.cfg \ | 
|  | -o -name *.cpp \ | 
|  | -o -name *.css \ | 
|  | -o -name *.def \ | 
|  | -o -name *.el \ | 
|  | -o -name *.exp \ | 
|  | -o -name *.footer \ | 
|  | -o -name *.gnuplot' \ | 
|  | -o -name *.h \ | 
|  | -o -name *.header \ | 
|  | -o -name *.html \ | 
|  | -o -name *.in \ | 
|  | -o -name *.inc \ | 
|  | -o -name *.intro \ | 
|  | -o -name *.l \ | 
|  | -o -name *.ll \ | 
|  | -o -name *.lst \ | 
|  | -o -name *.m4 \ | 
|  | -o -name *.pod \ | 
|  | -o -name *.pl \ | 
|  | -o -name *.py \ | 
|  | -o -name *.sh \ | 
|  | -o -name *.schema \ | 
|  | -o -name *.st \ | 
|  | -o -name *.tcl \ | 
|  | -o -name *.td \ | 
|  | -o -name *.tr \ | 
|  | -o -name *.y \ | 
|  | -o -name Make* \ | 
|  | -o -name *.cmake \ | 
|  | -o -name llvmdo \ | 
|  | -o -name llvmgrep \ | 
|  | -o -name check-each-file \ | 
|  | -o -name codgen-diff \ | 
|  | -o -name llvm-native-gcc \ | 
|  | -o -name llvm-native-gxx \ | 
|  | -o -name makellvm \ | 
|  | -o -path include/llvm/ADT/ilist \ | 
|  | -o -path test/\*.ll \ | 
|  | -o -path test/Scripts/not \ | 
|  | -o -path runtime/\*.ll \ | 
|  | " | 
|  | if test -z "$CODE_ONLY" ; then | 
|  | files_to_match="$files_to_match \ | 
|  | -o -name *.txt \ | 
|  | -o -name *.TXT \ | 
|  | -o -name *.vim \ | 
|  | -o -name vimrc \ | 
|  | -o -name README \ | 
|  | -o -name COPYING.LIB \ | 
|  | -o -name LICENSE* " | 
|  | fi | 
|  | files_to_ignore="\ | 
|  | -name \.* \ | 
|  | -o -name *~ \ | 
|  | -o -name #* \ | 
|  | -o -name configure \ | 
|  | -o -name slow.ll \ | 
|  | -o -name *libtool* \ | 
|  | -o -name ltdl* \ | 
|  | -o -name ltdl.m4 \ | 
|  | -o -name ltmain.m4 \ | 
|  | -o -name ltmain.sh \ | 
|  | -o -name aclocal.m4 \ | 
|  | -o -name acinclude.m4 \ | 
|  | -o -name *LoopSimplifyCrash.ll \ | 
|  | -o -name *AST-Remove.ll \ | 
|  | -o -name PPCPerfectShuffle.h \ | 
|  | " | 
|  |  | 
|  | if test -d "$TOPDIR" ; then | 
|  | cd $TOPDIR | 
|  | # Have to use the right "find" on a per-platform basis. Most platforms have | 
|  | # Gnu find as "find", but Solaris does not. | 
|  | case `uname -s` in | 
|  | SunOS) find_prog=gfind ;; | 
|  | *) find_prog=find ;; | 
|  | esac | 
|  | # Turn off file name generation (globbing) so that substitution of the | 
|  | # variables doesn't cause the shell to create lists of file names | 
|  | set -f | 
|  | $find_prog $LLVMDO_DIRS -type f \ | 
|  | \( $paths_to_ignore \) -prune \ | 
|  | -o \( \( $files_to_match \) \! \( $files_to_ignore \) \ | 
|  | -exec $PROGRAM "$@" {} \; \) | 
|  | else | 
|  | echo "Can't find LLVM top directory in $TOPDIR" | 
|  | fi |