File Coverage

Bio/SeqIO/tigrxml.pm
Criterion Covered Total %
statement 199 257 77.4
branch 78 128 60.9
condition 12 21 57.1
subroutine 21 21 100.0
pod 6 7 85.7
total 316 434 72.8


line stmt bran cond sub pod time code
1             #
2             # BioPerl module for Bio::SeqIO::tigrxml
3             #
4             # Please direct questions and support issues to
5             #
6             # Cared for by Jason Stajich
7             #
8             # Copyright Jason Stajich
9             #
10             # You may distribute this module under the same terms as perl itself
11              
12             # POD documentation - main docs before the code
13              
14             =head1 NAME
15              
16             Bio::SeqIO::tigrxml - Parse TIGR (new) XML
17              
18             =head1 SYNOPSIS
19              
20             use Bio::SeqIO;
21             my $in = Bio::SeqIO->new(-format => 'tigrcoordset',
22             -file => 'file.xml');
23              
24             while( my $seq = $in->next_seq ) {
25             # do something...
26             }
27              
28             =head1 DESCRIPTION
29              
30             This is a parser for TIGR Coordset XML for their in-progress
31             annotation dbs.
32              
33             =head1 FEEDBACK
34              
35             =head2 Mailing Lists
36              
37             User feedback is an integral part of the evolution of this and other
38             Bioperl modules. Send your comments and suggestions preferably to
39             the Bioperl mailing list. Your participation is much appreciated.
40              
41             bioperl-l@bioperl.org - General discussion
42             http://bioperl.org/wiki/Mailing_lists - About the mailing lists
43              
44             =head2 Support
45              
46             Please direct usage questions or support issues to the mailing list:
47              
48             I
49              
50             rather than to the module maintainer directly. Many experienced and
51             reponsive experts will be able look at the problem and quickly
52             address it. Please include a thorough description of the problem
53             with code and data examples if at all possible.
54              
55             =head2 Reporting Bugs
56              
57             Report bugs to the Bioperl bug tracking system to help us keep track
58             of the bugs and their resolution. Bug reports can be submitted via the
59             web:
60              
61             https://github.com/bioperl/bioperl-live/issues
62              
63             =head1 AUTHOR - Jason Stajich
64              
65             Email jason-at-bioperl-dot-org
66              
67             =head1 APPENDIX
68              
69             The rest of the documentation details each of the object methods.
70             Internal methods are usually preceded with a _
71              
72             =cut
73              
74              
75             # Let the code begin...
76              
77              
78             package Bio::SeqIO::tigrxml;
79 1     1   504 use vars qw($Default_Source);
  1         1  
  1         34  
80 1     1   4 use strict;
  1         1  
  1         30  
81 1     1   3 use XML::SAX;
  1         1  
  1         43  
82 1     1   3 use XML::SAX::Writer;
  1         1  
  1         27  
83 1     1   3 use Data::Dumper;
  1         1  
  1         41  
84 1     1   243 use Bio::Seq::SeqFactory;
  1         2  
  1         31  
85 1     1   262 use Bio::Species;
  1         2  
  1         30  
86 1     1   414 use Bio::SeqFeature::Generic;
  1         3  
  1         27  
87 1     1   295 use Bio::Annotation::Reference;
  1         2  
  1         27  
88 1     1   282 use Bio::Annotation::Comment;
  1         2  
  1         21  
89 1     1   5 use Bio::Annotation::DBLink;
  1         1  
  1         19  
90 1     1   4 use List::Util qw(min max);
  1         1  
  1         90  
91              
92 1     1   5 use base qw(Bio::SeqIO XML::SAX::Base);
  1         1  
  1         333  
93              
94              
95             $Default_Source = 'TIGR';
96              
97             sub _initialize {
98 1     1   2 my ($self) = shift;
99 1         5 $self->SUPER::_initialize(@_);
100 1         8 $self->{'_parser'} = XML::SAX::ParserFactory->parser('Handler' => $self);
101 1 50       18419 if( ! defined $self->sequence_factory ) {
102 1         7 $self->sequence_factory(Bio::Seq::SeqFactory->new
103             (-verbose => $self->verbose(),
104             -type => 'Bio::Seq::RichSeq'));
105             }
106 1         2 return;
107             }
108              
109             sub next_seq {
110 1     1 1 4 my $self = shift;
111 1 50 33     2 if( @{$self->{'_seendata'}->{'_seqs'} || []} ||
  1 50       13  
112             eof($self->_fh)) {
113 0         0 return shift @{$self->{'_seendata'}->{'_seqs'}};
  0         0  
114             }
115 1         5 $self->{'_parser'}->parse_file($self->_fh);
116 1         35 return shift @{$self->{'_seendata'}->{'_seqs'}};
  1         10  
117             }
118              
119             # XML::SAX::Base methods
120              
121             sub start_document {
122 1     1 1 223 my ($self,$doc) = @_;
123 1         5 $self->{'_seendata'} = {'_seqs' => [],
124             '_authors' => [],
125             '_feats' => [] };
126 1         10 $self->SUPER::start_document($doc);
127             }
128              
129             sub end_document {
130 1     1 1 180 my ($self,$doc) = @_;
131 1         25 $self->SUPER::end_document($doc);
132             }
133              
134             sub start_element {
135 26     26 1 21024 my ($self,$ele) = @_;
136             # attributes
137 26         53 my $name = uc $ele->{'LocalName'};
138 26         29 my $attr = $ele->{'Attributes'};
139             my $seqid = defined $self->{'_seendata'}->{'_seqs'}->[-1] ?
140 26 100       104 $self->{'_seendata'}->{'_seqs'}->[-1]->display_id : undef;
141            
142             # we're going to try and be SO-nice here
143 26 100       143 if( $name eq 'ASSEMBLY' ) { # New sequence
    100          
    100          
    100          
    100          
    100          
    100          
    100          
    100          
    50          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
    0          
144 1         8 my ($len) = $attr->{'{}COORDS'}->{'Value'} =~ /\d+\-(\d+)/;
145 1         7 push @{$self->{'_seendata'}->{'_seqs'}},
146             $self->sequence_factory->create
147             (
148 1         1 -display_id => $attr->{'{}ASMBL_ID'}->{'Value'},
149             -length => $len,
150             );
151             } elsif( $name eq 'HEADER' ) {
152             } elsif( $name eq 'CLONE_NAME' ) {
153             } elsif( $name eq 'ORGANISM' ) {
154             } elsif( $name eq 'AUTHOR_LIST' ) {
155 1         4 $self->{'_seendata'}->{'_authors'} = [];
156             } elsif( $name eq 'TU' ) { # gene feature
157 2         14 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
158 2         4 my $strand = 1;
159 2 100       10 if( $s > $e) {
160 1         4 ($s,$e,$strand) = ( $e,$s,-1);
161             }
162 2         4 my $fname = $attr->{'{}FEAT_NAME'}->{'Value'};
163             my $f = Bio::SeqFeature::Generic->new
164             (-seq_id => $seqid,
165             -start => $s,
166             -end => $e,
167             -strand => $strand,
168             -primary_tag => 'gene', # what does this really map to?
169             -source_tag => $Default_Source,
170             -tag => {
171             'Note' => $attr->{'{}COM_NAME'}->{'Value'},
172             'ID' => $fname,
173             'locus' => $attr->{'{}LOCUS'}->{'Value'},
174             'pub_locus' => $attr->{'{}PUB_LOCUS'}->{'Value'},
175             'alt_locus' => $attr->{'{}ALT_LOCUS'}->{'Value'},
176 2         35 'pub_comment' => $attr->{'{}PUB_COMMENT'}->{'Value'},
177             }
178             );
179 2         6 push @{$self->{'_seendata'}->{'_feats'}}, $f;
  2         5  
180             # add this feature to the current sequence
181 2         11 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
182             } elsif( $name eq 'MODEL' ) { # mRNA/transcript
183             # reset the UTRs
184 2         4 $self->{'_seendata'}->{"five_prime_UTR"}= undef;
185 2         3 $self->{'_seendata'}->{"three_prime_UTR"} = undef;
186 2         14 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
187 2         3 my $strand = 1;
188 2 100       7 if( $s > $e) {
189 1         3 ($s,$e,$strand) = ( $e,$s,-1);
190             }
191 2         3 my $parent = $self->{'_seendata'}->{'_feats'}->[-1];
192 2         7 my ($parentid) = $parent->get_tag_values('ID');
193             my $f = Bio::SeqFeature::Generic->new
194             (-primary_tag => 'transcript',
195             -source_tag => $Default_Source,
196             -start => $s, # we use parent start/stop because 'MODEL' means CDS start/stop
197             -end => $e, # but we want to reflect
198             -strand => $strand,
199             -seq_id => $seqid,
200             -tag => {
201             'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
202             'Parent' => $parentid,
203 2         27 'Note' => $attr->{'{}COMMENT'}->{'Value'},
204             });
205 2         10 $parent->add_SeqFeature($f);
206 2         3 push @{$self->{'_seendata'}->{'_feats'}}, $f;
  2         5  
207 2         7 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
208             } elsif( $name eq 'EXON' ) { # exon feature
209 8         42 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
210 8         11 my $strand = 1;
211 8 100       18 if( $s > $e) {
212 6         12 ($s,$e,$strand) = ( $e,$s,-1);
213             }
214 8         14 my $parent = $self->{'_seendata'}->{'_feats'}->[-1];
215            
216 8         13 my ($parentid) = $parent->get_tag_values('ID');
217              
218             my $f = Bio::SeqFeature::Generic->new
219             (-primary_tag => 'exon',
220             -source_tag => $Default_Source,
221             -seq_id => $seqid,
222             -start => $s,
223             -end => $e,
224             -strand => $strand,
225             -tag => {
226 8         50 'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
227             'Parent' => $parentid,
228             });
229 8         24 $parent->add_SeqFeature($f,'EXPAND');
230 8         27 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
231             # we'll still just add exons to the transcript
232             } elsif( $name eq 'PROTEIN_SEQ' ) {
233            
234             } elsif( $name eq 'CDS' ) {
235             # CDS will be the translation of the transcript
236 7         33 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
237 7         273 my $strand = 1;
238 7 100       22 if( $s > $e) {
239 6         11 ($s,$e,$strand) = ( $e,$s,-1);
240             }
241 7         11 my $parent = $self->{'_seendata'}->{'_feats'}->[-1];
242 7         17 my ($parentid) = $parent->get_tag_values('ID');
243 7         16 $self->assert($parent->primary_tag eq 'transcript', 'Testing for primary tag equivalent to mRNA');
244 7   33     13 $self->assert($parent->strand == $strand || abs($s-$e) == 0, 'Testing that parent feature and current feature strand are equal '. $parentid. ' '.$attr->{'{}FEAT_NAME'}->{'Value'});
245             my $f = Bio::SeqFeature::Generic->new
246             (-primary_tag => 'CDS',
247             -source_tag => $Default_Source,
248             -seq_id => $seqid,
249             -start => $s,
250             -end => $e,
251             -strand => $parent->strand,
252             -tag => {
253 7         19 'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
254             'Parent' => $parentid, # should be the mRNA
255             });
256 7         25 $parent->add_SeqFeature($f);
257 7         23 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
258             } elsif( $name eq 'RNA-EXON' ) {
259              
260 0         0 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
261 0         0 my $strand = 1;
262 0 0       0 if( $s > $e) {
263 0         0 ($s,$e,$strand) = ( $e,$s,-1);
264             }
265 0         0 my $parent = $self->{'_seendata'}->{'_feats'}->[-1];
266 0         0 my ($parentid) = $parent->get_tag_values('ID');
267             my $f = Bio::SeqFeature::Generic->new
268             (-primary_tag => 'tRNA_exon', # tRNA_exon?
269             -source_tag => $Default_Source,
270             -seq_id => $seqid,
271             -start => $s,
272             -end => $e,
273             -strand => $strand,
274             -tag => {
275 0         0 'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
276             'Parent' => $parentid,
277             }
278             );
279 0         0 $parent->add_SeqFeature($f);
280 0         0 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
281             } elsif( $name eq 'PRE-TRNA' ) { # tRNA gene
282 0         0 my ($s,$e) = ( $attr->{'{}COORDS'}->{'Value'} =~/(\d+)\-(\d+)/);
283 0         0 my $strand = 1;
284 0 0       0 if( $s > $e) {
285 0         0 ($s,$e,$strand) = ( $e,$s,-1);
286             }
287             my $f = Bio::SeqFeature::Generic->new
288             ( -primary_tag => 'tRNA_coding_gene',
289             -source_tag => $Default_Source,
290             -seq_id => $seqid,
291             -start => $s,
292             -end => $e,
293             -strand => $strand,
294 0         0 -tag => {'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
295             }
296             );
297 0         0 push @{$self->{'_seendata'}->{'_feats'}}, $f;
  0         0  
298 0         0 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
299             } elsif( $name eq 'TRNA' ) { # tRNA transcript
300 0         0 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
301 0         0 my $strand = 1;
302 0 0       0 if( $s > $e) {
303 0         0 ($s,$e,$strand) = ( $e,$s,-1);
304             }
305 0         0 my $parent = $self->{'_seendata'}->{'_feats'}->[-1];
306 0         0 my ($parentid) = $parent->get_tag_values('ID');
307             my $f = Bio::SeqFeature::Generic->new
308             (-primary_tag => 'tRNA_primary_transcript',
309             -source_tag => $Default_Source,
310             -start => $s,
311             -end => $e,
312             -strand => $strand,
313             -seq_id => $seqid,
314             -tag => {
315             'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
316             'Parent' => $parentid,
317             'Note' => $attr->{'{}COM_NAME'}->{'Value'},
318             'anticodon' => $attr->{'{}ANTICODON'}->{'Value'},
319 0         0 'pub_locus' => $attr->{'{}PUB_LOCUS'}->{'Value'},
320              
321             });
322 0         0 $parent->add_SeqFeature($f);
323 0         0 push @{$self->{'_seendata'}->{'_feats'}}, $f;
  0         0  
324 0         0 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
325             } elsif( $name eq 'REPEAT_LIST' ) {
326             } elsif( $name eq 'REPEAT' ) {
327 0         0 my ($s,$e) = ($attr->{'{}COORDS'}->{'Value'} =~ /(\d+)\-(\d+)/);
328 0         0 my $strand = 1;
329 0 0       0 if( $s > $e) {
330 0         0 ($s,$e,$strand) = ( $e,$s,-1);
331             }
332             my $f = Bio::SeqFeature::Generic->new
333             (-primary_tag => 'simple_repeat',
334             -source_tag => $Default_Source,
335             -seq_id => $seqid,
336             -start => $s,
337             -end => $e,
338             -stand => $strand,
339             -tag => {
340 0         0 'ID' => $attr->{'{}FEAT_NAME'}->{'Value'},
341             });
342              
343 0         0 push @{$self->{'_seendata'}->{'_feats'}}, $f;
  0         0  
344 0         0 $self->{'_seendata'}->{'_seqs'}->[-1]->add_SeqFeature($f);
345             } elsif ( $name eq 'AUTHOR' ) {
346             } elsif( $name eq 'GB_DESCRIPTION' ) {
347            
348             } elsif( $name eq 'GB_COMMENT' ) {
349             } elsif( $name eq 'LINEAGE' ) {
350            
351             } else {
352 0         0 $self->warn("Unknown element $name, ignored\n");
353             }
354 26         23 push @{$self->{'_state'}}, $name;
  26         43  
355 26         80 $self->SUPER::start_element($ele);
356             }
357              
358             sub end_element {
359 26     26 1 2485 my ($self,$ele) = @_;
360 26         20 pop @{$self->{'_state'}};
  26         39  
361 26         36 my $name = $ele->{'LocalName'};
362 26         31 my $curseq = $self->{'_seendata'}->{'_seqs'}->[-1];
363 26 100 66     211 if( $name eq 'AUTHOR_LIST' ) {
    100 66        
    100 33        
    100          
364 1 50       22 if( $curseq->can('annotation') ) {
365             $curseq->annotation->add_Annotation
366             ('reference',Bio::Annotation::Reference->new
367 1         5 (-authors => join(',',@{$self->{'_seendata'}->{'_authors'}}))
  1         9  
368             );
369             }
370 1         4 $self->{'_seendata'}->{'_authors'} = [];
371             } elsif( $name eq 'ASSEMBLY' ) {
372 1 50       2 if( @{$self->{'_seendata'}->{'_feats'} || []} ) {
  1 50       8  
373 0         0 $self->warn("Leftover features which were not finished!");
374             }
375 1         3 $self->debug("end element for ASSEMBLY ". $curseq->display_id. "\n");
376             } elsif( $name eq 'TU' ||
377             $name eq 'TRNA' || $name eq 'PRE-TRNA' ||
378             $name eq 'REPEAT' ) {
379 2         3 pop @{$self->{'_seendata'}->{'_feats'}};
  2         3  
380             } elsif( $name eq 'MODEL' ) {
381             # This is all to for adding UTRs
382              
383 2         2 my $model = pop @{$self->{'_seendata'}->{'_feats'}};
  2         6  
384 2         3 my $curseq = $self->{'_seendata'}->{'_seqs'}->[-1];
385             # sort smallest to largest, don't forget about
386             # strandedness
387 2         8 my ($parentid) = $model->get_tag_values('Parent');
388              
389 2         6 my @features = $model->get_SeqFeatures();
390 8         13 my @exons = sort { $a->start <=> $b->start }
391 2         4 grep { $_->primary_tag eq 'exon' } @features;
  15         18  
392            
393 7         10 my @cdsexons = sort { $a->start <=> $b->start }
394 2         5 grep { $_->primary_tag eq 'CDS' } @features;
  15         22  
395            
396             # look at the exons, find those which come after the model start
397 2         5 my $cdsexon = shift @cdsexons;
398 2         2 my $exon = shift @exons; # first exon
399 2 50       11 if( ! defined $cdsexon ) {
    50          
400 0         0 $self->warn( "no CDS exons $parentid!");
401 0         0 return;
402             } elsif( ! defined $exon ) {
403 0         0 $self->warn("no exons $parentid!" );
404 0         0 return;
405             }
406 2         4 my $utrct = 1;
407 2   100     12 while( defined $exon && $exon->start < $cdsexon->start ) {
408 3         7 my ($pid) = $exon->get_tag_values('Parent');
409 3         13 $self->debug("LeftPhase: tu-id $parentid mrna-id $pid exon is ".
410             $exon->location->to_FTstring.
411             " CDSexon is ".$cdsexon->location->to_FTstring."\n");
412            
413 3 100       12 my $utr = Bio::SeqFeature::Generic->new
414             (-seq_id => $exon->seq_id,
415             -strand => $exon->strand,
416             -primary_tag => $exon->strand > 0 ? "five_prime_UTR" : "three_prime_UTR",
417             -source_tag => $Default_Source,
418             -tag => {
419             'ID' => "$pid.UTR".$utrct++,
420             'Parent' => $pid },
421             );
422 3         8 my ($ns,$ne);
423 3 100       5 if( $utr->primary_tag eq 'five_prime_UTR' ) {
424 2         4 $ns = $exon->start;
425 2         4 $ne = min ( $exon->end, $cdsexon->start - 1);
426             } else {
427 1         3 $ne = min( $exon->end, $cdsexon->start - 1);
428 1         3 $ns = $exon->start;
429             }
430 3         6 $utr->start($ns); $utr->end($ne);
  3         7  
431 3         8 $model->add_SeqFeature($utr);
432 3         7 $curseq->add_SeqFeature($utr);
433 3         10 $exon = shift @exons;
434             }
435 8         12 @exons = sort { $a->start <=> $b->start }
436 2         3 grep {$_->primary_tag eq 'exon' } @features;
  15         20  
437 7         10 @cdsexons = sort { $a->start <=> $b->start }
438 2         4 grep { $_->primary_tag eq 'CDS' } @features;
  15         16  
439            
440 2         4 $cdsexon = pop @cdsexons;
441 2         2 $exon = pop @exons;
442 2 50       7 if( ! defined $cdsexon ) {
    50          
443 0         0 $self->warn( "no CDS exons $parentid!");
444 0         0 return;
445             } elsif( ! defined $exon ) {
446 0         0 $self->warn("no exons $parentid!" );
447 0         0 return;
448             }
449 2         4 $utrct = 1;
450 2   66     7 while( defined $exon &&$exon->end > $cdsexon->end ) {
451 2         5 my ($pid) = $exon->get_tag_values('Parent');
452 2         10 $self->debug("RightPhase: tu-id $parentid mrna-id $pid exon is ".
453             $exon->location->to_FTstring.
454             " CDSexon is ".$cdsexon->location->to_FTstring."\n");
455            
456 2 100       6 my $utr = Bio::SeqFeature::Generic->new
457             (-seq_id => $exon->seq_id,
458             -strand => $exon->strand,
459             -primary_tag => $exon->strand < 0 ? "five_prime_UTR" : "three_prime_UTR",
460             -source_tag => $Default_Source,
461             -tag => {
462             'Parent' => $pid,
463             'ID' => "$pid.UTR".$utrct++,
464             }
465             );
466 2         5 my ($ns,$ne);
467 2 100       6 if( $utr->primary_tag eq 'three_prime_UTR' ) {
468 1         2 $ns = max ( $exon->start, $cdsexon->end + 1);
469 1         2 $ne = $exon->end;
470             } else {
471 1         4 $ns = $cdsexon->end+1;
472 1         6 $ne = max ( $exon->end, $cdsexon->start + 1);
473             }
474 2         6 $utr->start($ns); $utr->end($ne);
  2         4  
475            
476 2         6 $model->add_SeqFeature($utr);
477 2         6 $curseq->add_SeqFeature($utr);
478 2         6 $exon = pop @exons;
479             }
480             }
481 26         63 $self->SUPER::end_element($ele);
482             }
483              
484             sub characters {
485 44     44 1 2523 my ($self,$data) = @_;
486 44 50       39 if( ! @{$self->{'_state'}} ) {
  44         78  
487 0         0 $self->warn("Calling characters with no previous start_element call. Ignoring data");
488             } else {
489 44         49 my $curseq = $self->{'_seendata'}->{'_seqs'}->[-1];
490 44         43 my $curfeat = $self->{'_seendata'}->{'_feats'}->[-1];
491 44         49 my $name = $self->{'_state'}->[-1];
492 44 50       72 if( defined $curseq ) {
493 44 100       132 if( $name eq 'CLONE_NAME' ) {
    100          
    50          
    50          
494 1         9 $self->debug("Clone name is ",$data->{'Data'}, "\n");
495 1         3 $curseq->display_id($data->{'Data'});
496             } elsif( $name eq 'ORGANISM' ) {
497 1         8 my ($genus,$species,$subspec) = split(/\s+/,$data->{Data},3);
498 1         13 $curseq->species(Bio::Species->new(
499             -classification =>
500             [$species,$genus],
501             -sub_species => $species));
502             } elsif( $name eq 'LINEAGE' ) {
503             $curseq->species->classification(
504             [
505             $curseq->species->species,
506             $curseq->species->genus,
507 0         0 reverse (map { s/^\s+//;
508 0         0 s/\s+$//; $_; }
  0         0  
509 0         0 split /[;\.]+/,$data->{'Data'} ),
510             ]
511             );
512             } elsif( $name eq 'AUTHOR' ) {
513 0         0 push @{$self->{'_seendata'}->{'_authors'}}, $data->{'Data'};
  0         0  
514             }
515             }
516 44 100       60 if( defined $curfeat ) {
517 33 100       120 if( $name eq 'EXON' ) { # exon feature
    50          
    100          
    50          
    50          
    50          
    50          
    50          
    50          
    50          
518             } elsif( $name eq 'RNA-EXON' ) {
519            
520             } elsif( $name eq 'PROTEIN_SEQ' ) {
521 2         7 $curfeat->add_tag_value('translation',$data->{'Data'});
522             } elsif( $name eq 'CDS' ) {
523             } elsif( $name eq 'PRE-TRNA' ) { # tRNA gene
524             } elsif( $name eq 'TRNA' ) { # tRNA transcript
525             } elsif( $name eq 'REPEAT_LIST' ) {
526             } elsif( $name eq 'REPEAT' ) {
527 0         0 $curfeat->add_tag_value('Note',$data->{'Data'});
528             } elsif( $name eq 'GB_COMMENT' ) {
529             $curseq->annotation->add_Annotation
530             ('comment',
531 0         0 Bio::Annotation::Comment->new(-text => $data->{'Data'}));
532             } elsif( $name eq 'GB_DESCRIPTION' ) {
533 0         0 $curseq->description($data->{'Data'});
534             }
535             }
536             }
537 44         101 $self->SUPER::characters($data);
538             }
539              
540              
541             sub assert {
542 14     14 0 13 my ($self,$test,$msg) = @_;
543 14 50       23 $self->throw($msg) unless $test;
544             }
545             1;