-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathgff2eland.pl
executable file
·104 lines (74 loc) · 2.8 KB
/
gff2eland.pl
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
#!/usr/bin/env perl
use warnings;
use strict;
use Data::Dumper;
use Carp;
use Getopt::Long;
use Pod::Usage;
use version; our $VERSION = qv('0.0.1');
use FindBin;
use lib "$FindBin::Bin/DZLab-Tools/lib";
use DZLab::Tools::RunUtils;
GetOptions(
\%ARGV,
'input|i=s', 'output|o=s', 'error|e=s',
_meta_options( \%ARGV ),
) and (@ARGV or $ARGV{input}) or pod2usage( -verbose => 1 );
my ( $INH, $OUTH, $ERRH ) = _prepare_io( \%ARGV, \@ARGV );
while ( <$INH> ) {
chomp;
my @fields = split /\t/;
my $mismatches = 'NM';
my $target = '';
if ($fields[5] and $fields[7] ne q{.}) {
my @mismatches = (0, 0, 0, 0); $mismatches[$fields[7]] = $fields[5];
$mismatches = join ':', @mismatches;
$target = "$fields[0]:$fields[3]" . ($fields[6] eq q{+} ? 'F' : 'R') . $fields[7];
}
my ($readid, $sequence) = $fields[2] =~ m{^(.+#\d/[12]):(.*)}g;
die $fields[2] unless defined $readid and defined $sequence;
print $OUTH join( "\t", $readid, $sequence, $mismatches, $target), "\n";
}
=head1 NAME
gff2eland.pl - Convert GFF v3 to Eland v3
=head1 SYNOPSIS
gff2eland.pl [OPTION]... [[-i] FILE]...
gff2ekabd,pl your.gff -o your.eland3
=head1 DESCRIPTION
Convert GFF v3 to Eland v3
=head1 OPTIONS
-i, --input <string> input filename (STDIN)
-o, --output <string> output filename (STDOUT)
-e, --error <string> output error filename (STDERR)
--verbose [integer] print increasingly verbose error messages
--quiet print no diagnostic or warning messages
--version print current version
--license print author's contact and copyright information
--help print this information
--manual print the plain old documentation page
=head1 VERSION
0.0.1
=head1 REVISION
$Rev: $:
$Author: $:
$Date: $:
$HeadURL: $:
$Id: $:
=head1 AUTHOR
Pedro Silva <[email protected]/>
Zilberman Lab <http://dzlab.pmb.berkeley.edu/>
Plant and Microbial Biology Department
College of Natural Resources
University of California, Berkeley
=head1 COPYRIGHT
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
=cut