Mercurial > repos > cpt > cpt_psm_plotter
comparison lib/CPT/Bio/DataSource/Chado.pm @ 1:8691c1c61a8e draft default tip
planemo upload commit 94b0cd1fff0826c6db3e7dc0c91c0c5a8be8bb0c
author | cpt |
---|---|
date | Mon, 05 Jun 2023 02:48:47 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
0:54c7a3ea81e2 | 1:8691c1c61a8e |
---|---|
1 package CPT::Bio::DataSource::Chado; | |
2 no warnings; | |
3 use Moose; | |
4 with 'CPT::Bio::DataSource'; | |
5 | |
6 has 'host' => ( is => 'rw', isa => 'Str' ); | |
7 has 'pass' => ( is => 'rw', isa => 'Str' ); | |
8 has 'user' => ( is => 'rw', isa => 'Str' ); | |
9 has 'name' => ( is => 'rw', isa => 'Str' ); | |
10 has 'port' => ( is => 'rw', isa => 'Str' ); | |
11 | |
12 has 'landmark' => ( is => 'rw', isa => 'Str' ); | |
13 has 'organism' => ( is => 'rw', isa => 'Str' ); | |
14 | |
15 | |
16 sub getSeqIO { | |
17 my ($self) = @_; | |
18 require CPT::Chado::GMOD_Conf; | |
19 | |
20 my $db = Bio::DB::Das::Chado->new( | |
21 -dsn => sprintf( 'dbi:Pg:dbname=%s;host=%s;port=%s', $self->name(), $self->host(), $self->port() ), | |
22 -user => $self->user(), | |
23 -pass => $self->pass(), | |
24 -organism => $self->organism(), | |
25 -inferCDS => 1, | |
26 | |
27 ); | |
28 | |
29 # Get a list of "segments". Essentially (seqlen IS NOT NULL) | |
30 my @segments = $db->segment( -name => $self->{'landmark'} ); | |
31 | |
32 # TODO: Need to have a fallback method | |
33 # Should only produce ONE since we specify landmark exactly | |
34 foreach my $segment (@segments) { | |
35 my $stream = $segment->get_feature_stream(); | |
36 use Bio::Seq; | |
37 my $seq_obj = Bio::Seq->new( | |
38 -seq => $segment->seq->seq(), | |
39 -display_id => $segment->id() | |
40 ); | |
41 use Bio::SeqFeature::Generic; | |
42 while ( my $feat = $stream->next_seq ) { | |
43 | |
44 # In an IDEAL world we'd just do $seq_obj->add_SeqFeature($feat); | |
45 # | |
46 # HOWEVER. | |
47 # | |
48 # ------------- EXCEPTION: Bio::Root::NotImplemented ------------- | |
49 # MSG: Abstract method "Bio::DB::Das::Chado::Segment::Feature::attach_seq" is not implemented by package Bio::DB::Das::Chado::Segment::Feature. | |
50 # This is not your fault - author of Bio::DB::Das::Chado::Segment::Feature should be blamed! | |
51 # STACK: Error::throw | |
52 # STACK: Bio::Root::Root::throw /usr/local/share/perl/5.14.2/Bio/Root/Root.pm:472 | |
53 # STACK: Bio::Root::RootI::throw_not_implemented /usr/local/share/perl/5.14.2/Bio/Root/RootI.pm:748 | |
54 # STACK: Bio::DB::Das::Chado::Segment::Feature::attach_seq /usr/local/share/perl/5.14.2/Bio/DB/Das/Chado/Segment/Feature.pm:374 | |
55 # STACK: Bio::Seq::add_SeqFeature /usr/local/share/perl/5.14.2/Bio/Seq.pm:1148 | |
56 # STACK: chado_export.pl:59 | |
57 # ---------------------------------------------------------------- | |
58 | |
59 # BUT WE CAN'T. >_> rageface.tiff | |
60 | |
61 my %keys; | |
62 foreach my $tag ( $feat->get_all_tags() ) { | |
63 my @values = $feat->get_tag_values($tag); | |
64 if ( $tag eq 'Note' ) { | |
65 $tag = 'note'; | |
66 } | |
67 if ( $tag eq 'Dbxref' ) { | |
68 $tag = 'db_xref'; | |
69 | |
70 #@values = map { if($_ ne 'GFF_source:Genbank'){ $_ } } @values; | |
71 @values = grep !/GFF_source:Genbank/, @values; | |
72 } | |
73 $keys{$tag} = \@values; | |
74 } | |
75 | |
76 #print $feat->gff_string(),"\n"; | |
77 my $new_feat = new Bio::SeqFeature::Generic( | |
78 -start => $feat->start(), | |
79 -end => $feat->end(), | |
80 -strand => $feat->strand(), | |
81 -primary_tag => $feat->primary_tag(), | |
82 -tag => \%keys, | |
83 ); | |
84 $seq_obj->add_SeqFeature($new_feat); | |
85 } | |
86 | |
87 return $seq_obj; | |
88 } | |
89 | |
90 } | |
91 | |
92 no Moose; | |
93 1; | |
94 | |
95 __END__ | |
96 | |
97 =pod | |
98 | |
99 =encoding UTF-8 | |
100 | |
101 =head1 NAME | |
102 | |
103 CPT::Bio::DataSource::Chado | |
104 | |
105 =head1 VERSION | |
106 | |
107 version 1.99.4 | |
108 | |
109 =head2 getSeqIO | |
110 | |
111 supposed to get a seqIO object from a chado DB. not fully implemented | |
112 | |
113 =head1 AUTHOR | |
114 | |
115 Eric Rasche <rasche.eric@yandex.ru> | |
116 | |
117 =head1 COPYRIGHT AND LICENSE | |
118 | |
119 This software is Copyright (c) 2014 by Eric Rasche. | |
120 | |
121 This is free software, licensed under: | |
122 | |
123 The GNU General Public License, Version 3, June 2007 | |
124 | |
125 =cut |