annotate variant_effect_predictor/Bio/Ontology/InterProTerm.pm @ 0:2bc9b66ada89 draft default tip

Uploaded
author mahtabm
date Thu, 11 Apr 2013 06:29:17 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
1 # $Id: InterProTerm.pm,v 1.4.2.2 2003/03/25 12:32:16 heikki Exp $
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
2 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
3 # BioPerl module for Bio::Ontology::InterProTerm
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
4 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
5 # Cared for by Peter Dimitrov <dimitrov@gnf.org>
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
6 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
7 # Copyright Peter Dimitrov
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
8 # (c) Peter Dimitrov, dimitrov@gnf.org, 2002.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
9 # (c) GNF, Genomics Institute of the Novartis Research Foundation, 2002.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
10 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
11 # You may distribute this module under the same terms as perl itself.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
12 # Refer to the Perl Artistic License (see the license accompanying this
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
13 # software package, or see http://www.perl.com/language/misc/Artistic.html)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
14 # for the terms under which you may use, modify, and redistribute this module.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
15 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
16 # THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
17 # WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
18 # MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
19 #
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
20 # POD documentation - main docs before the code
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
21
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
22 =head1 NAME
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
23
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
24 InterProTerm - Implementation of InterProI term interface
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
25
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
26 =head1 SYNOPSIS
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
27
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
28 my $term = Bio::Ontology::InterProTerm->new( -interpro_id => "IPR000001",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
29 -name => "Kringle",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
30 -definition => "Kringles are autonomous structural domains ...",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
31 -ontology => "Domain"
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
32 );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
33 print $term->interpro_id(), "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
34 print $term->name(), "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
35 print $term->definition(), "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
36 print $term->is_obsolete(), "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
37 print $term->ontology->name(), "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
38
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
39 =head1 DESCRIPTION
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
40
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
41 This is a simple extension of L<Bio::Ontology::Term> for InterPro terms.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
42
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
43 =head1 FEEDBACK
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
44
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
45 =head2 Mailing Lists
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
46
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
47 User feedback is an integral part of the evolution of this and other
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
48 Bioperl modules. Send your comments and suggestions preferably to
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
49 the Bioperl mailing list. Your participation is much appreciated.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
50
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
51 bioperl-l@bioperl.org - General discussion
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
52 http://bioperl.org/MailList.shtml - About the mailing lists
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
53
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
54 =head2 Reporting Bugs
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
55
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
56 Report bugs to the Bioperl bug tracking system to help us keep track
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
57 of the bugs and their resolution. Bug reports can be submitted via
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
58 email or the web:
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
59
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
60 bioperl-bugs@bioperl.org
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
61 http://bugzilla.bioperl.org/
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
62
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
63 =head1 AUTHOR - Peter Dimitrov
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
64
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
65 Email dimitrov@gnf.org
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
66
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
67 =head1 CONTRIBUTORS
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
68
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
69 Additional contributors names and emails here
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
70
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
71 =head1 APPENDIX
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
72
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
73 The rest of the documentation details each of the object methods.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
74 Internal methods are usually preceded with a _
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
75
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
76 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
77
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
78
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
79 # Let the code begin...
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
80
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
81
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
82 package Bio::Ontology::InterProTerm;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
83 use vars qw(@ISA);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
84 use strict;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
85
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
86 use Bio::Ontology::Term;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
87 use Bio::Annotation::Reference;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
88
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
89 use constant INTERPRO_ID_DEFAULT => "IPR000000";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
90
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
91 @ISA = qw( Bio::Ontology::Term );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
92
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
93 =head2 new
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
94
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
95 Title : new
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
96 Usage : $term = Bio::Ontology::InterProTerm->new( -interpro_id => "IPR000002",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
97 -name => "Cdc20/Fizzy",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
98 -definition => "The Cdc20/Fizzy region is almost always ...",
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
99 -ontology => "Domain"
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
100 );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
101
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
102 Function: Creates a new Bio::Ontology::InterProTerm.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
103 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
104 Returns : A new Bio::Ontology::InterProTerm object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
105 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
106 -interpro_id => the InterPro ID of the term. Has the form IPRdddddd, where dddddd is a zero-padded six digit number
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
107 -name => the name of this InterPro term [scalar]
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
108 -definition => the definition/abstract of this InterPro term [scalar]
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
109 -ontology => ontology of InterPro terms [Bio::Ontology::OntologyI]
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
110 -comment => a comment [scalar]
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
111
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
112 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
113
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
114 sub new{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
115 my ($class, @args) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
116 my $self = $class->SUPER::new(@args);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
117
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
118 my ( $interpro_id,
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
119 $short_name)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
120 = $self->_rearrange( [qw( INTERPRO_ID
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
121 SHORT_NAME
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
122 )
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
123 ], @args );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
124
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
125 $interpro_id && $self->interpro_id( $interpro_id );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
126 $short_name && $self->short_name( $short_name );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
127
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
128 return $self;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
129 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
130
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
131 =head2 init
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
132
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
133 Title : init
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
134 Usage : $term->init();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
135 Function: Initializes this InterProTerm to all "" and empty lists.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
136 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
137 Returns :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
138 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
139
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
140
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
141 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
142
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
143 sub init{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
144 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
145
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
146 # first call the inherited version to properly chain up the hierarchy
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
147 $self->SUPER::init(@_);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
148
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
149 # then only initialize what we implement ourselves here
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
150 $self->interpro_id( INTERPRO_ID_DEFAULT );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
151 $self->short_name("");
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
152
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
153 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
154
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
155 =head2 _check_interpro_id
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
156
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
157 Title : _check_interpro_id
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
158 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
159 Function: Performs simple check in order to validate that its argument has the form IPRdddddd, where dddddd is a zero-padded six digit number.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
160 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
161 Returns : Returns its argument if valid, otherwise throws exception.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
162 Args : String
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
163
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
164
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
165 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
166
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
167 sub _check_interpro_id{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
168 my ($self, $value) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
169
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
170 $self->throw( "InterPro ID ".$value." is incorrect\n" )
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
171 unless ( $value =~ /^IPR\d{6}$/ ||
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
172 $value eq INTERPRO_ID_DEFAULT );
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
173
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
174 return $value;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
175 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
176
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
177 =head2 interpro_id
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
178
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
179 Title : interpro_id
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
180 Usage : $obj->interpro_id($newval)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
181 Function: Set/get for the interpro_id of this InterProTerm
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
182 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
183 Returns : value of interpro_id (a scalar)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
184 Args : new value (a scalar, optional)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
185
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
186
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
187 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
188
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
189 sub interpro_id{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
190 my ($self, $value) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
191
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
192 if( defined $value) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
193 $value = $self->_check_interpro_id($value);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
194 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
195
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
196 return $self->identifier($value);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
197 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
198
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
199 =head2 short_name
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
200
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
201 Title : short_name
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
202 Usage : $obj->short_name($newval)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
203 Function: Set/get for the short name of this InterProTerm.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
204 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
205 Returns : value of short_name (a scalar)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
206 Args : new value (a scalar, optional)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
207
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
208
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
209 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
210
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
211 sub short_name{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
212 my ($self, $value) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
213
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
214 if( defined $value) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
215 $self->{'short_name'} = $value ? $value : undef;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
216 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
217
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
218 return $self->{'short_name'};
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
219 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
220
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
221 =head2 protein_count
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
222
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
223 Title : protein_count
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
224 Usage : $obj->protein_count($newval)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
225 Function: Set/get for the protein count of this InterProTerm.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
226 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
227 Returns : value of protein_count (a scalar)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
228 Args : new value (a scalar, optional)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
229
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
230
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
231 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
232
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
233 sub protein_count{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
234 my ($self,$value) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
235
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
236 if( defined $value) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
237 $self->{'protein_count'} = $value ? $value : undef;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
238 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
239
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
240 return $self->{'protein_count'};
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
241 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
242
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
243 =head2 get_references
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
244
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
245 Title : get_references
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
246 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
247 Function: Get the references for this InterPro term.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
248 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
249 Returns : An array of L<Bio::Annotation::Reference> objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
250 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
251
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
252
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
253 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
254
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
255 sub get_references{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
256 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
257
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
258 return @{$self->{"_references"}} if exists($self->{"_references"});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
259 return ();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
260 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
261
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
262 =head2 add_reference
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
263
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
264 Title : add_reference
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
265 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
266 Function: Add one or more references to this InterPro term.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
267 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
268 Returns :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
269 Args : One or more L<Bio::Annotation::Reference> objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
270
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
271
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
272 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
273
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
274 sub add_reference{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
275 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
276
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
277 $self->{"_references"} = [] unless exists($self->{"_references"});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
278 push(@{$self->{"_references"}}, @_);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
279 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
280
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
281 =head2 remove_references
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
282
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
283 Title : remove_references
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
284 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
285 Function: Remove all references for this InterPro term.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
286 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
287 Returns : The list of previous references as an array of
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
288 L<Bio::Annotation::Reference> objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
289 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
290
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
291
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
292 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
293
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
294 sub remove_references{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
295 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
296
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
297 my @arr = $self->get_references();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
298 $self->{"_references"} = [];
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
299 return @arr;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
300 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
301
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
302 =head2 get_members
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
303
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
304 Title : get_members
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
305 Usage : @arr = get_members()
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
306 Function: Get the list of member(s) for this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
307 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
308 Returns : An array of Bio::Annotation::DBLink objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
309 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
310
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
311
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
312 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
313
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
314 sub get_members{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
315 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
316
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
317 return @{$self->{'_members'}} if exists($self->{'_members'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
318 return ();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
319 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
320
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
321 =head2 add_member
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
322
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
323 Title : add_member
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
324 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
325 Function: Add one or more member(s) to this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
326 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
327 Returns :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
328 Args : One or more Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
329
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
330
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
331 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
332
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
333 sub add_member{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
334 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
335
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
336 $self->{'_members'} = [] unless exists($self->{'_members'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
337 push(@{$self->{'_members'}}, @_);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
338 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
339
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
340 =head2 remove_members
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
341
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
342 Title : remove_members
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
343 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
344 Function: Remove all members for this class.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
345 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
346 Returns : The list of previous members as an array of
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
347 Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
348 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
349
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
350
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
351 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
352
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
353 sub remove_members{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
354 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
355
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
356 my @arr = $self->get_members();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
357 $self->{'_members'} = [];
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
358 return @arr;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
359 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
360
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
361 =head2 get_examples
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
362
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
363 Title : get_examples
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
364 Usage : @arr = get_examples()
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
365 Function: Get the list of example(s) for this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
366
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
367 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
368
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
369 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
370 Returns : An array of Bio::Annotation::DBLink objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
371 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
372
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
373
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
374 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
375
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
376 sub get_examples{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
377 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
378
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
379 return @{$self->{'_examples'}} if exists($self->{'_examples'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
380 return ();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
381 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
382
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
383 =head2 add_example
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
384
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
385 Title : add_example
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
386 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
387 Function: Add one or more example(s) to this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
388
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
389 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
390
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
391 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
392 Returns :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
393 Args : One or more Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
394
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
395
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
396 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
397
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
398 sub add_example{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
399 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
400
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
401 $self->{'_examples'} = [] unless exists($self->{'_examples'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
402 push(@{$self->{'_examples'}}, @_);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
403 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
404
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
405 =head2 remove_examples
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
406
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
407 Title : remove_examples
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
408 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
409 Function: Remove all examples for this class.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
410
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
411 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
412
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
413 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
414 Returns : The list of previous examples as an array of
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
415 Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
416 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
417
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
418
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
419 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
420
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
421 sub remove_examples{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
422 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
423
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
424 my @arr = $self->get_examples();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
425 $self->{'_examples'} = [];
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
426 return @arr;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
427 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
428
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
429 =head2 get_external_documents
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
430
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
431 Title : get_external_documents
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
432 Usage : @arr = get_external_documents()
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
433 Function: Get the list of external_document(s) for this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
434
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
435 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
436
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
437 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
438 Returns : An array of Bio::Annotation::DBLink objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
439 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
440
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
441
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
442 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
443
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
444 sub get_external_documents{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
445 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
446
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
447 return @{$self->{'_external_documents'}} if exists($self->{'_external_documents'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
448 return ();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
449 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
450
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
451 =head2 add_external_document
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
452
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
453 Title : add_external_document
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
454 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
455 Function: Add one or more external_document(s) to this object.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
456
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
457 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
458
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
459 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
460 Returns :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
461 Args : One or more Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
462
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
463
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
464 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
465
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
466 sub add_external_document{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
467 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
468
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
469 $self->{'_external_documents'} = [] unless exists($self->{'_external_documents'});
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
470 push(@{$self->{'_external_documents'}}, @_);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
471 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
472
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
473 =head2 remove_external_documents
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
474
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
475 Title : remove_external_documents
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
476 Usage :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
477 Function: Remove all external_documents for this class.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
478
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
479 This is an element of the InterPro xml schema.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
480
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
481 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
482 Returns : The list of previous external_documents as an array of
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
483 Bio::Annotation::DBLink objects.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
484 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
485
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
486
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
487 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
488
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
489 sub remove_external_documents{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
490 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
491
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
492 my @arr = $self->get_external_documents();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
493 $self->{'_external_documents'} = [];
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
494 return @arr;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
495 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
496
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
497 =head2 class_list
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
498
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
499 Title : class_list
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
500 Usage : $obj->class_list($newval)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
501 Function: Set/get for class list element of the InterPro xml schema
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
502 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
503 Returns : reference to an array of Bio::Annotation::DBLink objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
504 Args : reference to an array of Bio::Annotation::DBLink objects
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
505
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
506
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
507 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
508
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
509 sub class_list{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
510 my ($self, $value) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
511
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
512 if( defined $value) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
513 $self->{'class_list'} = $value;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
514 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
515
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
516 return $self->{'class_list'};
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
517 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
518
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
519 =head2 to_string
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
520
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
521 Title : to_string()
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
522 Usage : print $term->to_string();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
523 Function: to_string method for InterPro terms.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
524 Returns : A string representation of this InterPro term.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
525 Args :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
526
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
527 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
528
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
529 sub to_string {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
530 my($self) = @_;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
531 my $s = "";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
532
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
533 $s .= "-- InterPro id:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
534 $s .= $self->interpro_id()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
535 if (defined $self->name) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
536 $s .= "-- Name:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
537 $s .= $self->name()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
538 $s .= "-- Definition:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
539 $s .= $self->definition()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
540 $s .= "-- Category:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
541 if ( defined( $self->ontology() ) ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
542 $s .= $self->ontology()->name()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
543 } else {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
544 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
545 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
546 $s .= "-- Version:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
547 $s .= $self->version()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
548 $s .= "-- Is obsolete:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
549 $s .= $self->is_obsolete()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
550 $s .= "-- Comment:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
551 $s .= $self->comment()."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
552 if (defined $self->references) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
553 $s .= "-- References:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
554 foreach my $ref ( @{$self->references} ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
555 $s .= $ref->authors."\n".$ref->title."\n".$ref->location."\n\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
556 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
557 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
558 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
559 if (defined $self->member_list) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
560 $s .= "-- Member List:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
561 foreach my $ref ( @{$self->member_list} ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
562 $s .= $ref->database."\t".$ref->primary_id."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
563 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
564 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
565 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
566 if (defined $self->external_doc_list) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
567 $s .= "-- External Document List:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
568 foreach my $ref ( @{$self->external_doc_list} ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
569 $s .= $ref->database."\t".$ref->primary_id."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
570 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
571 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
572 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
573 if (defined $self->examples) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
574 $s .= "-- Examples:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
575 foreach my $ref ( @{$self->examples} ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
576 $s .= $ref->database."\t".$ref->primary_id."\t".$ref->comment."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
577 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
578 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
579 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
580 if (defined $self->class_list) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
581 $s .= "-- Class List:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
582 foreach my $ref ( @{$self->class_list} ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
583 $s .= $ref->primary_id."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
584 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
585 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
586 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
587 if ($self->get_secondary_ids) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
588 $s .= "-- Secondary IDs:\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
589 foreach my $ref ( $self->get_secondary_ids() ) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
590 $s .= $ref."\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
591 };
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
592 $s .= "\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
593 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
594 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
595 else {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
596 $s .= "InterPro term not fully instantiated\n";
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
597 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
598 return $s;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
599 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
600
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
601 =head1 Deprecated methods
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
602
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
603 These are here for backwards compatibility.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
604
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
605 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
606
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
607 =head2 secondary_ids
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
608
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
609 Title : secondary_ids
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
610 Usage : $obj->secondary_ids($newval)
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
611 Function: This is deprecated. Use get_secondary_ids() or
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
612 add_secondary_id() instead.
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
613 Example :
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
614 Returns : reference to an array of strings
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
615 Args : reference to an array of strings
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
616
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
617
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
618 =cut
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
619
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
620 sub secondary_ids{
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
621 my $self = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
622 my @ids;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
623
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
624 $self->warn("secondary_ids is deprecated. Use ".
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
625 "get_secondary_ids/add_secondary_id instead.");
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
626
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
627 # set mode?
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
628 if(@_) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
629 my $sids = shift;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
630 if($sids) {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
631 $self->add_secondary_id(@$sids);
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
632 @ids = @$sids;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
633 } else {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
634 # we interpret setting to undef as removing the array
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
635 $self->remove_secondary_ids();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
636 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
637 } else {
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
638 # no; get mode
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
639 @ids = $self->get_secondary_ids();
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
640 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
641 return \@ids;
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
642 }
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
643
2bc9b66ada89 Uploaded
mahtabm
parents:
diff changeset
644 1;