cross-plat-dev-utils/build_all.pl
changeset 2 39c28ec933dd
child 6 787612182dd0
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/cross-plat-dev-utils/build_all.pl	Mon May 10 19:54:49 2010 +0100
@@ -0,0 +1,131 @@
+#!/usr/bin/perl
+# Copyright (c) 2010 Symbian Foundation Ltd
+# This component and the accompanying materials are made available
+# under the terms of the License "Eclipse Public License v1.0"
+# which accompanies this distribution, and is available
+# at the URL "http://www.eclipse.org/legal/epl-v10.html".
+#
+# Initial Contributors:
+# Mike Kinghan, mikek@symbian.org, for Symbian Foundation Ltd - initial contribution.
+
+# Script to build all tools2 targets with Raptor, except Raptor itself
+# and any that were broken upstream when last checked.
+
+use strict;
+use perl_run;
+use set_epocroot;
+use check_os;
+my $keepgoing = 0;
+my @built = ();
+my @failed = ();
+my @skipped = ();
+
+sub build($)
+{
+	my $targ = shift;
+	return, if (is_built($targ));
+	print ">>> Building target $targ\n";
+	my $rc = perl_run("build_target.pl $targ");
+	if ($rc) {
+		print "*** Failed to build target $targ ***";
+		if ($keepgoing) {
+			push(@failed,$targ);
+		} else {
+			exit $rc;
+		}
+	} else { 
+		push(@built,$targ);
+	}
+}
+
+sub is_built($)
+{
+	my $targ = shift;
+	return grep(/$targ/,@built) != 0;
+}
+
+if (@ARGV) {
+    if (grep(/$ARGV[0]/,("-h","--help"))) {
+        print "This script cleans all TOOLS2 targets with Raptor, " .
+			"except Raptor itself and any that were broken upstream when last checked.\n";
+        print "Valid arguments are -h, --help; -k, --keepgoing, or none.\n";
+		print "-k, --keepgoing makes the script carry on after a failed clean,\n";
+		exit 0;  
+	} elsif (grep(/$ARGV[0]/,("-k","--keepgoing"))) {
+		$keepgoing = 1;
+	} else {
+	    print "Valid arguments are -h, --help; -k, --keepgoing, or none.\n".
+        exit 1;
+    }         
+}
+set_epocroot();
+my $epocroot = $ENV{'EPOCROOT'};
+my @targ_lines = perl_slurp("list_targets.pl");
+open DEPS,"<deps.txt" or die $!;
+my @deps = <DEPS>;
+close DEPS;
+while (@deps and $deps[0] =~ /^\s*#/) {
+	shift @deps;
+}
+foreach my $dep (@deps) {
+	chomp $dep;
+}
+my $start_time = time();
+foreach my $line (@targ_lines) {
+	chomp $line;
+	next, if ($line =~ /^>>>/);
+	if ($line =~ /(\*\*\*.*\*\*\*)/) {
+		my $reason = $1;
+		my @words = split(/ /,$line);
+		print ">>> Skipping target $words[0]: \"$reason\"\n";
+		push (@skipped,[$words[0],$reason]);
+	} else {
+		foreach my $dep (@deps) {
+			my ($targ,$prereq) = split(/ /,$dep);
+			if (os_is_windows()) {
+                $targ =~ s/\./\\/g;
+                $prereq =~ s/\./\\/g;                
+            } else {
+                $targ =~ s/\./\//g;
+                $prereq =~ s/\./\//g;                            
+            }
+			next, unless ($targ eq $line);
+			build($prereq);
+		}
+		build($line);
+	}
+}
+if (@built) {
+	if (@failed == 0) {
+		print ">>> Built all eligible targets:-\n";
+	} else {
+		print ">>> Built eligible targets:-\n";
+	}
+	foreach my $targ (@built) {
+		print "+++ $targ\n";
+	}
+}
+if (@failed) {
+	print ">>> Failed to build eligible targets:-\n";
+	foreach my $targ (@failed) {
+		print "+++ $targ\n";
+	}
+} 
+if (@skipped) {
+	print ">>> Skipped targets:-\n";
+	foreach my $skipped (@skipped) {
+		print "+++ " . $skipped->[0] . ' ' . $skipped->[1] . "\n";
+	}
+}
+my $end_time = time();
+use integer;
+my $elapsed_time = $end_time - $start_time;
+my $hours = $elapsed_time / 3600;
+$elapsed_time -= ($hours * 3600);
+my $mins = $elapsed_time / 60;
+my $secs = ($elapsed_time - ($mins * 60));
+print ">>> Runtime ";
+print "$hours hrs ", if ($hours);
+print "$mins mins $secs secs\n";
+exit 0;
+