aboutsummaryrefslogtreecommitdiff
path: root/SBO-Lib/lib
diff options
context:
space:
mode:
authorJ Pipkin <j@dawnrazor.net>2013-01-06 01:21:59 -0600
committerJ Pipkin <j@dawnrazor.net>2013-01-06 01:21:59 -0600
commit93e96ae1435e6539defa72011fff9031fb16af86 (patch)
tree3d2108705a595db42732818f6a3b01456adc1620 /SBO-Lib/lib
parent93b0b024bebe84f4dd84c6eaf1bb2c25cb2142f2 (diff)
parent6ab8aecc0a9e01b970ceed7a2b2e3dd9f68b1012 (diff)
downloadsbotools2-93e96ae1435e6539defa72011fff9031fb16af86.tar.xz
Merge branch 'cpan_fix', fixes #23
Diffstat (limited to 'SBO-Lib/lib')
-rw-r--r--SBO-Lib/lib/SBO/Lib.pm27
1 files changed, 27 insertions, 0 deletions
diff --git a/SBO-Lib/lib/SBO/Lib.pm b/SBO-Lib/lib/SBO/Lib.pm
index 6a8b4db..67c7e3e 100644
--- a/SBO-Lib/lib/SBO/Lib.pm
+++ b/SBO-Lib/lib/SBO/Lib.pm
@@ -42,6 +42,7 @@ our @EXPORT = qw(
get_arch
get_build_queue
merge_queues
+ get_installed_cpans
$tempdir
$conf_dir
$conf_file
@@ -884,3 +885,29 @@ sub get_readme_contents($) {
close $fh;
return $readme;
}
+
+# return a list of perl modules installed via the CPAN
+sub get_installed_cpans() {
+ my @locals;
+ for my $dir (@INC) {
+ push @locals, "$dir/perllocal.pod" if -f "$dir/perllocal.pod";
+ }
+ my @contents;
+ for my $file (@locals) {
+ my $fh = open_read $file;
+# push @contents, grep {/Module|VERSION/} <$fh>;
+ push @contents, grep {/Module/} <$fh>;
+ close $fh;
+ }
+ my $mod_regex = qr/C<Module>\s+L<([^\|]+)/;
+# my $ver_regex = qr/C<VERSION:\s+([^>]+)>/;
+ my (@mods, @vers);
+ for my $line (@contents) {
+ push @mods, ($line =~ $mod_regex)[0];
+# push @vers, ($line =~ $ver_regex)[0];
+ }
+ return \@mods;
+# my %cpans;
+# $cpans{$mods[$_]} = $vers[$_] for keys @mods;
+# return \%cpans;
+}