This file is indexed.

/usr/share/perl5/Graph/D3.pm is in libgraph-d3-perl 0.03-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package Graph::D3;

use strict;
use 5.008_005;
our $VERSION = '0.03';

use Moo;
use JSON;
use Graph;

has graph => (
    is => 'ro',
    required => 1
);

has type => (
    is => 'ro',
    default => sub { 'ref' },
);

# https://gist.github.com/mbostock/4062045
# http://bl.ocks.org/mbostock/4062045
sub force_directed_graph {
    my $self = shift;
    my @nodes;
    my %nodes;
    my $counter = 0;
    for my $vertex ($self->graph->vertices) {
        my $group = $self->graph->get_vertex_attribute($vertex, 'group');
        $group = 1 unless (defined $group);
        push @nodes, { name => $vertex, group => $group };
        $nodes{$vertex} = $counter;
        $counter++;
    }
    my @links;
    for my $edges ($self->graph->edges) {
        my ($n1, $n2) = @$edges;
        my $value = $self->graph->get_edge_attribute($n1, $n2, 'value');
        $value = 1 unless (defined $value);
        push @links, {source => $nodes{$n1}, target => $nodes{$n2}, value => $value};
    }
    my $output =  { nodes => \@nodes, links => \@links };
    return $self->type eq 'json' ? encode_json $output : $output;
}

# http://mbostock.github.io/d3/talk/20111116/bundle.html
sub hierarchical_edge_bundling {
    my $self = shift;
    my @bundle;
    for my $vertex ($self->graph->vertices) {
        my $size = $self->graph->get_vertex_attribute($vertex, 'size');
        $size = 1 unless (defined $size);
        my @imports = $self->graph->predecessors($vertex);
        push @bundle, {name => $vertex, size => $size, imports => \@imports };
    }
    return $self->type eq 'json' ? encode_json \@bundle : \@bundle;
}


1;
__END__

=encoding utf-8

=head1 NAME

Graph::D3 - Create ref/json to show node-edge graph with D3.js 

=head1 SYNOPSIS

  use Graph;
  use Graph::D3;
  my $g = new Graph(
      vertices => [qw/1 2 3 4 5/], 
      edges => [[qw/1 2/], [qw/2 3/], [qw/3 5/], [qw/4 1/]] 
  );
  my $d3 = new Graph::D3(graph => $g);
  my $output = $d3->force_directed_graph(); #output is hash reference
  $output = $d3->hierarchical_edge_bundling(); #output is hash reference

  $d3 = new Graph::D3(graph => $g, type => json); 
  my $json = $d3->force_directed_graph(); # output is json format
  $json = $d3->hierarchical_edge_bundling(); # output is json format

=head1 DESCRIPTION

Graph::D3 is a moudle to covert Graph object to the format which is used in d3.js(http://d3js.org/).
This module simply supports node-edge graph in the example.

=head1 METHODS

=head2 force_directed_graph 

This outputs the format which is used for Force Directed Graph described below.

https://gist.github.com/mbostock/4062045,http://bl.ocks.org/mbostock/4062045

The input graph should be directed grpah.
Node in Graph can have 'group' attribute (Default is all 1) to have different node color.
Also Edge in Graph can have 'value' attribe(defalut is all 1).

=head2 hierarchical_edge_bundling 

http://mbostock.github.io/d3/talk/20111116/bundle.html

The input graph shoudl be directed graph.
Node in Graph can have 'size' attribute (Default is all 1). 

=head1 AUTHOR

Shohei Kameda E<lt>shoheik@cpan.orgE<gt>

=head1 COPYRIGHT

Copyright 2013- Shohei Kameda

=head1 LICENSE

This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.

=head1 SEE ALSO

=cut