# Make a TAGS file for emacs ``M-x find-tag'' from all source files. # (``make realclean'' first to avoid generated files, or ``make'' first # to get tags from all files.) # # (IZ: to be a happier jumper: install 'imenu-go.el' from # ftp://ftp.math.ohio-state.edu/pub/users/ilya/emacs.) # # (Some tags should probably live in their own subdirs, like those in x2p/, # but I have never been interested in x2p anyway.) # # Hallvard B Furuseth , Aug -96. # # Ilya Zakharevich, Oct 97: minor comments, add CPerl scan; # Use Hallvard's scan for XS files - since he processes the "C" part too - # but with a lot of improvements: now it is no worse than CPerl's one. # Avoid builitin on OS/2: if test ! -z "$OS2_SHELL"; then alias find=gnufind; fi # Insure proper order (.h after .c, .xs before .c in subdirs): topfiles="`echo ' ' *.y *.c *.h ' ' | sed 's/ embed.h / /'`" subdirfiles="`( find ./*/* -name '*.[cy]' -print | sort ; find ./*/* -name '*.[hH]' -print | sort )`" xsfiles="`find . -name '*.xs' -print | sort`" # What is `etags -d'? # These are example lines for global variables and PP-code: ## IEXT SV * Iparsehook; ## IEXT char * Isplitstr IINIT(" "); ## dEXTCONST char rcsid[] = "perl.c\nPatch level: ###\n"; ## PP(pp_const) ## PERLVARI(Grsfp, PerlIO *, Nullfp) ## PERLVAR(cvcache, HV *) set x -d -l c \ -r '/[dI]?EXT\(CONST\)?[ \t*]+\([a-zA-Z_0-9]+[ \t*]+\)*\([a-zA-Z_0-9]+\)[ \t]*\($\|;\|\[\|[ \t]I+NIT[ \t]*(\|\/\*\)/\3/' \ -r '/IEXT[ \t][^\/]*[ \t*]I\([a-zA-Z_][a-zA-Z_0-9]*\)[\[; \t]/\1/' \ -r '/PERLVAR[a-zA-Z_0-9]*[ \t]*([ \t]*[GIT]?\([a-zA-Z_][a-zA-Z_0-9]*\)[ \t]*,/\1/' \ -r '/PP[ \t]*([ \t]*\([^ \t()]*\)[ \t]*)/\1/' shift rm -f TAGS.tmp TAGS.tm2 # Process lines like this: #define MEM_ALIGNBYTES $alignbytes /**/ etags -o TAGS.tmp \ -l none -r '/#\(\$[a-zA-Z_0-9]+\|define\)[ \t]+\([a-zA-Z_0-9]+\)/\2/' \ config_h.SH etags -o TAGS.tmp -a "$@" $topfiles etags -o TAGS.tmp -a -D -l none -r '/#define.*\t\(Perl_.*\)/\1/' embed.h # Add MODULE lines to TAG files (to be postprocessed later), # and BOOT: lines (in DynaLoader processed twice?) # This skips too many XSUBs: # etags -o TAGS.tmp -a -d -l c \ # -r '/MODULE[ \t=]+\(.*PACKAGE[ \t]*=[ \t]*\)?\([^ \t]+\)\([ \t]*PREFIX[ \t]*=[ \t]*\([^ \t]+\)\)?/\2/' \ # -r '/[ \t]*BOOT:/' \ # $xsfiles etags -o TAGS.tmp -a -d -l c \ -r '/MODULE[ \t=]+\(.*PACKAGE[ \t]*=[ \t]*\)?\([^ \t]+\)\([ \t]*PREFIX[ \t]*=[ \t]*\([^ \t]+\)\)?/\2/' \ -r '/[ \t]*BOOT:/' \ -r '/\([_a-zA-Z][a-zA-Z0-9_:]*\)(/' \ $xsfiles # -r '/MODULE[ \t=]+\(.*PACKAGE[ \t]*=[ \t]*\)?\([^ \t]+\)/\2/' \ # -r '/MODULE.*PREFIX[ \t]*=[ \t]*\([^ \t]+\)/\1/' \ # $xsfiles etags -o TAGS.tmp -a "$@" $subdirfiles if ! test -f emacs/cperl-mode.elc ; then ( cd emacs; emacs -batch -q -no-site-file -f batch-byte-compile cperl-mode.el ) fi # This should work with newer Emaxen cp TAGS.tmp TAGS if emacs -batch -q -no-site-file -l emacs/cperl-mode.elc -f cperl-add-tags-recurse-noxs ; then mv TAGS TAGS.tmp fi perl -w014pe ' $update = s/^PP\(\177\d+,\d+\n//gm; $update += s/^(I?EXT.*[ \t])IINIT[ \t]*\((\177)/$1$2/gm; if (/^\n*[^\s,]+\.xs,/s) { $mod = $cmod = $bmod = $pref = ""; s/^(.*\n)\1+/$1/mg; # Remove duplicate lines $_ = join("", map { if (/^MODULE[ \t]*=[ \t]*(\S+)(?:[ \t]+PACKAGE[ \t]*=[ \t]*(\S+))?[ \t\177]/m) { $mod = $+; ($bmod = $mod) =~ tr/:/_/; $cmod = "XS_${bmod}_"; $pref = ""; if (s/[ \t]+PREFIX[ \t]*=[ \t]*([^\s\177]+)(\177)/$+/) { $pref = $1; $pref =~ s/([^\w\s])/\\$1/g; $pref = "(?:$pref)?"; } } elsif ($mod ne "") { # Ref points for Module::subr, XS_Module_subr, subr s/^($pref(\w+)[ \t()]*\177)(\d+,\d+)$/$1${mod}::${2}\01$3\n$1$2\01$3\n$1$cmod$2\01$3/gm; # Ref for Module::bootstrap bootstrap boot_Module s/^([ \t]*BOOT:\177)(\d+,\d+)$/$1${mod}::bootstrap\01$2\n${1}bootstrap\01$2\n${1}boot_$bmod\01$2/gm; } $_; } split(/(\nMODULE[ \t]*=[^\n\177]+\177)/)); $update = 1; } if ($update) { $chars = chomp; s/^((\n.+,)\d+)/ $2 . (length($_) - length($1) - 1) /e; $_ .= ("\f" x $chars); }' TAGS.tmp > TAGS.tm2 rm -f TAGS mv TAGS.tm2 TAGS rm -f TAGS.tmp