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