diff options
Diffstat (limited to '')
-rwxr-xr-x | tools/update/ampolish | 105 | ||||
-rwxr-xr-x | tools/update/rtems-polish.sh | 30 |
2 files changed, 135 insertions, 0 deletions
diff --git a/tools/update/ampolish b/tools/update/ampolish new file mode 100755 index 0000000000..c105f9e7b5 --- /dev/null +++ b/tools/update/ampolish @@ -0,0 +1,105 @@ +#!/usr/bin/perl + +# +# Perl script to beautify and enhance RTEMS automake Makefile.ams +# +# Reads from stdin and writes to stdout +# +# usage: +# <path-to>/ampolish <Makefile.am >Makefile.am~ +# mv Makefile.am~ Makefile.am +# +# ATTENTION: This file contains embedded tabs + +my $subdirs_seen = "" ; + +# find a relative up-path to a file $file, starting at directory $pre +sub find_file +{ + my $pre = $_[0] ; + my $file= $_[1] ; + + my $top = "." ; + if (not "$pre") { $pre = "." ; } + + for ( $str = "$pre" . "/" . "$top" ; + ( -d "$str" ) ; + $str = "$pre" . "/" . "$top" ) + { + if ( -f "${str}/${file}" ) + { + return $top ; + } + if ( "$top" eq "." ) + { + $top = ".." ; + } + else + { + $top .= "/.." ; + } + } ; + die "Can't find file ${file}\n" ; +} + +# find relative up-path to configure.in +my $rtems_cfg = find_file(".","configure.in"); + +# find relative up-path from configure.in to VERSION +my $rtems_top = find_file("$rtems_cfg","VERSION"); + +my $nl_seen = 0 ; + +while( <> ) +{ # consume header + last if ( /^[^#].*$/ ) ; + print "$_" ; +} + +print "\nAUTOMAKE_OPTIONS = foreign\n"; +if ( "$rtems_cfg" eq "." ) +{ + print "ACLOCAL = \@ACLOCAL\@ -I \$(RTEMS_TOPdir)/aclocal\n" +} + +while( <> ) +{ + if ( /^[ ]*$/o ) + { + $nl_seen = $nl_seen+1; + } + + if ( /^[ ]*AUTOMAKE_OPTIONS.*$/o ) + { # remove the line + } + elsif ( /^[ ]*ACLOCAL[ ]*=[ ]*\@ACLOCAL\@.*$/o ) + { # remove the line + } + elsif ( /^[ ]*include[ ]*\$\(top_srcdir\)[\.\/]*automake\/(.*)\.am$/o ) + { + # remove the line + } + elsif ( /^[ ]*SUBDIRS.*$/o ) + { + $subdirs_seen = "yes" ; + print "$_" ; + $nl_seen = 0 ; + } + elsif ( /^[ ]*$/o ) + { + print "$_" if $nl_seen < 2 ; + } + else + { + print "$_" ; + $nl_seen = 0; + } +} # while + +if ( "$subdirs_seen" ) +{ + print "include \$(top_srcdir)/${rtems_top}/automake/subdirs.am\n" ; +} +print "include \$(top_srcdir)/${rtems_top}/automake/local.am\n" ; + +;1 diff --git a/tools/update/rtems-polish.sh b/tools/update/rtems-polish.sh new file mode 100755 index 0000000000..fe8604e972 --- /dev/null +++ b/tools/update/rtems-polish.sh @@ -0,0 +1,30 @@ +#!/bin/sh + +pwd=`pwd`; + +ac_files=`find . -name Makefile.in`; +for f in $ac_files; do + i=`dirname $f` + dest="$i" + if test ! -f $dest/Makefile.am; then + echo "polishing : $dest/Makefile.in" + ( cd $dest; + mv Makefile.in Makefile.in~; + $pwd/c/update-tools/acpolish <Makefile.in~ >Makefile.in + rm Makefile.in~ + ) + fi +done + +am_files=`find . -name Makefile.am`; +for f in $am_files; do + i=`dirname $f` + dest="$i" + echo "polishing : $dest/Makefile.am" + ( cd $dest; + mv Makefile.am Makefile.am~; + $pwd/c/update-tools/ampolish <Makefile.am~ >Makefile.am + rm Makefile.am~ + ) +done + |