/usr/bin/go-export-graph is in libgo-perl 0.15-5.
This file is owned by root:root, with mode 0o755.
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 | #!/usr/bin/perl
use strict;
use GO::Basic;
use GO::Dotty::Dotty;
use Getopt::Long;
my $w = 'text';
my $use_cache;
my $fmt;
GetOptions("write|w=s"=>\$w,
"use_cache"=>\$use_cache,
"format|parser|p=s"=>\$fmt,
"help|h"=>sub{system("perldoc $0");exit 0},
);
my $graph = parse({format=>$fmt,
use_cache=>$use_cache},shift @ARGV);
my $subgraph = $graph->subgraph({@ARGV});
unless ($subgraph->term_count) {
print STDERR "No matching terms for: @ARGV\n";
exit 1;
}
if ($w eq 'text') {
$subgraph->to_text_output;
}
elsif ($w eq 'obo') {
$subgraph->to_obo;
}
else {
my $graphviz =
GO::Dotty::Dotty::go_graph_to_graphviz( $subgraph,
{node => {shape => 'box'},
});
print $graphviz->as_png;
}
exit 0;
__END__
=head1 NAME
go-export-graph.pl - exports a graph
=head1 SYNOPSIS
go-export-graph.pl -w png ontology/gene_ontology.obo | display -
go-export-graph.pl ontology/gene_ontology.obo 'acc' GO:0007610
go-export-graph.pl ontology/so.obo 'name' 'protein'
=head1 DESCRIPTION
exports a graph as an indented ascii tree, PNG or OBO file
=head1 ARGUMENTS
after the file name you can optionally specify query constraint pairs; eg
acc GO:0007610
name 'cysteine biosynthesis'
=head1 OPTIONS
=head3 -w EXPORT_FORMAT
one of B<text>, B<obo> or B<png>
=head2 -use_cache
If this switch is specified, then caching mode is turned on.
With caching mode, the first time you parse a file, then an additional
file will be exported in a special format that is fast to parse. This
file will have the same filename as the original file, except it will
have the ".cache" suffix.
The next time you parse the file, this program will automatically
check for the existence of the ".cache" file. If it exists, and is
more recent than the file you specified, this is parsed instead. If it
does not exist, it is rebuilt.
=head2 DOCUMENTATION
L<http://www.godatabase.org/dev>
=head2 SEE ALSO
L<go2fmt.pl>
=cut
|