| #!/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 |