File: MyLargePrimarySeq.pm

package info (click to toggle)
libchado-perl 1.23-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 23,976 kB
  • ctags: 10,378
  • sloc: xml: 192,540; sql: 165,945; perl: 28,339; sh: 101; python: 73; makefile: 46
file content (61 lines) | stat: -rw-r--r-- 1,468 bytes parent folder | download | duplicates (5)
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
package Bio::GMOD::Bulkfiles::MyLargePrimarySeq;
use strict;

=head1 Bio::GMOD::Bulkfiles::MyLargePrimarySeq

  patch to use Bio::Seq::LargePrimarySeq to read
  feature locations from dna.raw files.
   
  my $dnaseq= Bio::GMOD::Bulkfiles::MyLargePrimarySeq->new( -file => $dnafile);
  
  $loc= new Bio::Location::something(...);
  $bases= $dnaseq->subseq($loc);   
  
=cut


use Bio::Seq::LargePrimarySeq;
use base qw(Bio::Seq::LargePrimarySeq);
#use vars qw(@ISA); BEGIN{ @ISA = qw(Bio::Seq::LargePrimarySeq); }

sub new {
  my ($class, %params) = @_;
  my $dnafile = delete $params{'-file'} ;
  my $self = $class->SUPER::new(%params);
  $self->dnafile($dnafile);
  if( $dnafile && -e $dnafile ) {  
    ## $self->_filename($dnafile); # don't change to our name in case StUPER wants to unlink it   
    my $fh= new FileHandle($dnafile);
    $fh->seek(0,2);
    my $flen= $fh->tell();
    $fh->seek(0,0);
    $self->_fh($fh);
    $self->length($flen);
    }
  
  return $self;
}

sub dnafile {
  my $self = shift;  
  if (@_) {  $self->{dnafile}= shift; }
  return $self->{dnafile};
}

## dang this nasty -- DONT unlink
sub DESTROY {
  my $self = shift;
  my $fh = $self->_fh();
  close($fh) if( defined $fh );
  $self->_filename(''); # is unlink '' bad ?    
  
  # this should be handled by Tempfile removal, but we'll unlink anyways.
  ##unlink $self->_filename() if defined $self->_filename() && -e $self->_filename;
  ##$self->SUPER::DESTROY();
}


#-------

1;