summaryrefslogtreecommitdiff
path: root/utils/hstags/hstags.prl
diff options
context:
space:
mode:
Diffstat (limited to 'utils/hstags/hstags.prl')
-rw-r--r--utils/hstags/hstags.prl94
1 files changed, 94 insertions, 0 deletions
diff --git a/utils/hstags/hstags.prl b/utils/hstags/hstags.prl
new file mode 100644
index 0000000000..16e770bd8a
--- /dev/null
+++ b/utils/hstags/hstags.prl
@@ -0,0 +1,94 @@
+#
+# To fully function, this script needs the following variables
+# set:
+#
+# INSTALLING
+# DEFAULT_TMPDIR
+# TOP_PWD
+# libdir
+# libexecdir
+# ProjectVersionInt
+# HSP_IMPORTS
+
+if ( $ENV{'TMPDIR'} ) { # where to make tmp file names
+ $tmp = $ENV{'TMPDIR'} . "/$$.eht";
+} else {
+ $tmp ="${DEFAULT_TMPDIR}/$$.eht";
+ $ENV{'TMPDIR'} = ${DEFAULT_TMPDIR}; # set the env var as well
+}
+
+$TopPwd = "${TOP_PWD}"; # *Only* needed when using it in-situ (i.e., INSTALLING=0).
+$InstLibDirGhc = "${libdir}";
+$InstLibExecDirGhc = "${libexecdir}";
+
+$Unlit = ( $INSTALLING ?
+ "${InstLibExecDirGhc}/unlit" :
+ "${TopPwd}/ghc/utils/unlit/unlit" );
+# but this is re-set to "cat" (after options) if -cpp not seen
+$HsCpp = ( $INSTALLING ?
+ "${InstLibDirGhc}/hscpp" :
+ "${TopPwd}/ghc/utils/hscpp/hscpp" );
+$HsP = ( $INSTALLING ?
+ "${InstLibExecDirGhc}/hsp" :
+ "${TopPwd}/ghc/compiler/hsp" );
+$HsTagsHelp =
+ ( $INSTALLING ?
+ "${InstLibExecDirGhc}/hstags-help" :
+ "${TopPwd}/ghc/utils/hstags/hstags-help" );
+
+$Verbose = 0;
+$Append = '>';
+$DoCpp = 0;
+$Cpp_opts = '';
+$HsP_opts = '';
+@Files = ();
+
+while ($ARGV[0] =~ /^-./) {
+ $_ = shift(@ARGV);
+ /^--/ && last;
+ /^-v/ && ($Verbose = 1, next);
+ /^-a$/ && ($Append = '>>', next);
+ /^-fglasgow-exts/ && ($HsP_opts .= ' -N', next);
+ /^-optP(.*)/ && ($Cpp_opts .= " $1", next);
+ /^-[UDI]/ && ($Cpp_opts .= " $_", next);
+ /^-cpp/ && ($DoCpp = 1, next);
+ /^-/ && next; # ignore the rest
+ push(@Files, $_);
+}
+
+$DoHsCpp = ( ! $DoCpp ) ? 'cat'
+ : "$HsCpp -D__HASKELL1__=2 -D__GLASGOW_HASKELL__=$ProjectVersionInt $Cpp_opts";
+
+# to find Prelude.hi and friends.
+$HsP_opts .= ( $INSTALLING ?
+ "-J${InstLibDirGhc}/imports" :
+ ( '-J' . join(' -J',split(/:/,${HSP_IMPORTS})) ));
+
+open(STDOUT, "$Append TAGS") || die "can't create TAGS";
+
+foreach $f ( @ARGV ) {
+ # if file is in a dir && we are CPPing, then we add its dir to the -I list.
+ if ( $DoCpp && $f =~ /(.+)\/[^\/]+$/ ) {
+ $Idir = "-I$1";
+ } else {
+ $Idir = '';
+ }
+
+ if ( $f =~ /\.lhs$/ ) {
+ $ToDo = "$Unlit $f - | $DoHsCpp $Idir | $HsP -E $HsP_opts | $HsTagsHelp $f > $tmp";
+ } else {
+ $ToDo = "$DoHsCpp $Idir < $f | $HsP -E $HsP_opts | $HsTagsHelp $f > $tmp";
+ }
+ print STDERR "$ToDo\n" if $Verbose;
+ system($ToDo);
+ $return_val = $?;
+ die "Fatal error $return_val\n" if $return_val != 0;
+
+ ($dev,$ino,$mode,$nlink,$uid,$gid,$rdev,$size,
+ $atime,$mtime, $ctime,$blksize,$blocks) = stat("$tmp");
+
+ print STDOUT "\f\n$f,${size}\n";
+ print STDOUT `cat $tmp`;
+}
+
+unlink $tmp;