summaryrefslogtreecommitdiff
path: root/bin/module-deps.pl
diff options
context:
space:
mode:
authorMichael Meeks <michael.meeks@suse.com>2013-03-04 18:01:19 +0000
committerMichael Meeks <michael.meeks@suse.com>2013-03-05 10:23:17 +0000
commitd614ca7ebe77894e38754576de0969c4086827be (patch)
tree93049ad98c197dd50bb819672afa53dda7dd3d90 /bin/module-deps.pl
parent7cd6f8f7ad868d2c69bd528d21aa0d8190299270 (diff)
initial gnumake module deps dumping.
Diffstat (limited to 'bin/module-deps.pl')
-rwxr-xr-xbin/module-deps.pl79
1 files changed, 79 insertions, 0 deletions
diff --git a/bin/module-deps.pl b/bin/module-deps.pl
new file mode 100755
index 000000000000..453570a5a9c5
--- /dev/null
+++ b/bin/module-deps.pl
@@ -0,0 +1,79 @@
+#!/usr/bin/perl -w
+
+use strict;
+
+my $gnumake;
+my $makefile_build;
+
+sub read_deps()
+{
+ my $p;
+ my $invalid_tolerance = 100;
+ my $line_count = 0;
+ my %deps;
+ open ($p, "ENABLE_PRINT_DEPS=1 $gnumake -n -f $makefile_build all|") || die "can't launch make: $!";
+# open ($p, "/tmp/deps") || die "can't read deps: $!";
+ $|=1;
+ print STDERR "reading deps ";
+ while (<$p>) {
+ my $line = $_;
+ $line_count++;
+ print STDERR '.' if ($line_count % 10 == 0);
+# print STDERR $line;
+ chomp ($line);
+ if ($line =~ m/^LibraryDep:\s+(\S+) links against (.*)$/) {
+# if ($line =~ m/^LibraryDep:\s+(\S+)\s+links against/) {
+ $deps{$1} = ' ' if (!defined $deps{$1});
+ $deps{$1} = $deps{$1} . ' ' . $2;
+ } elsif ($line =~ m/^LibraryDep:\s+links against/) {
+# these need fixing, we call gb_LinkTarget__use_$...
+# and get less than normal data back to gb_LinkTarget_use_libraries
+# print STDERR "ignoring unhelpful external dep\n";
+ } elsif ($invalid_tolerance < 0) {
+# print "read all dependencies to: '$line'\n";
+ last;
+ } else {
+# print "no match '$line'\n";
+ $invalid_tolerance--;
+ }
+ }
+ close ($p);
+ print STDERR " done\n";
+
+ return \%deps;
+}
+
+# first create nodes for each entry
+sub build_tree($)
+{
+ my $deps = shift;
+ for my $name (sort keys %{$deps}) {
+ my $need_str = $deps->{$name};
+ $need_str =~ s/^\s+//g;
+ $need_str =~ s/\s+$//g;
+ my @needs = split /\s+/, $need_str;
+ $name =~ m/^([^_]+)_(\S+)$/ || die "invalid target name: '$name'";
+ my $type = $1;
+ my $target = $2;
+ $type eq 'Executable' || $type eq 'Library' ||
+ $type eq 'CppunitTest' || die "Unknown type '$type'";
+ print "$target ($type): " . join (',', @needs) . "\n";
+ }
+}
+
+while (my $arg = shift @ARGV) {
+ if (!defined $gnumake) {
+ $gnumake = $arg;
+ } elsif (!defined $makefile_build) {
+ $makefile_build = $arg;
+ } else {
+ die "un-needed argument '$arg'";
+ }
+}
+
+$gnumake = 'make' if (!defined $gnumake);
+$makefile_build = 'Makefile.gbuild' if (!defined $makefile_build);
+
+my $deps = read_deps();
+my $tree = build_tree($deps);
+