1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
#!/usr/bin/perl -w
use strict;
use feature ':5.10';
use Getopt::Long;
use XML::Simple;
use YAML::Syck;
use IO::All;
use DateTime;
use lib ( 'lib' );
use CPAN::mapcpan;
my $options = GetOptions(
'out=s' => \my $output_gdf,
'dbmap=s' => \my $db_map,
'type=s' => \my $type,
'list=s' => \my $list,
);
print "preparing gexf ... ";
my $dbmap = CPAN::cpanmap->connect( "dbi:SQLite:dbname=" . $db_map, "", "" );
my $struct_graph;
$struct_graph->{ gexf } = { version => "1.0" };
$struct_graph->{ gexf }->{ meta } = { creator => [ 'rtgi' ] };
$struct_graph->{ gexf }->{ graph } = { type => 'dynamic' };
$struct_graph->{ gexf }->{ graph }->{ attributes } = {
class => 'node',
type => 'dynamic',
};
push @{ $struct_graph->{ gexf }->{ graph }->{ attributes }->{ attribute } },
{
id => 0,
title => 'dist',
type => 'string',
};
say "done";
print "creating nodes ... ";
$struct_graph->{ gexf }->{ graph }->{ nodes } = {};
my $packages;
my $id_nodes;
if ( $type && $type eq 'author' ) {
my $author_list = LoadFile( $list );
$packages = $dbmap->resultset( 'packages' )->search(
{ -and => [
author => { 'in', $author_list},
released => { '>', '1970-01-01' }
]
}
);
} else {
$packages = $dbmap->resultset( 'packages' )->search(
{ -and => [
author => { '!=', 'null' },
released => { '>', '1970-01-01' }
]
}
);
}
while ( my $package = $packages->next ) {
my ( $year, $month, $day )
= $package->released =~ /^(\d{4})-(\d{2})-(\d{2})/;
push @{ $struct_graph->{ gexf }->{ graph }->{ nodes }->{ node } }, {
id => $package->id,
label => $package->dist,
author => $package->author,
version => $package->version,
datefrom => join( '-', $year, $month, $day ),
};
$id_nodes->{$package->id}++;
}
say "done";
print "creating edges ... ";
my $id = 0;
my $edges;
if ( $type && $type eq 'author' ) {
$edges = $dbmap->resultset( 'edges' )
->search( { dist_from => { 'in' => [ keys %$id_nodes ] }, } );
} else {
$edges = $dbmap->resultset( 'edges' )->search;
}
while ( my $edge = $edges->next ) {
next unless exists $id_nodes->{ $edge->dist_from };
next unless exists $id_nodes->{ $edge->dist_to };
push @{ $struct_graph->{ gexf }->{ graph }->{ edges }->{ edge } }, {
cardinal => 1,
source => $edge->dist_from,
target => $edge->dist_to,
type => 'dir',
id => ++$id,
};
}
say "done";
print "generating gdf ... ";
my $xml = XMLout(
$struct_graph,
AttrIndent => 1,
#GroupTags => { node => 'attvalue' },
KeepRoot => 1,
);
$xml > io( $output_gdf );
say "done";
|