annotate variant_effect_predictor/Bio/Seq/SeqBuilder.pm @ 2:a5976b2dce6f

changing defualt values for ensembl database
author mahtabm
date Thu, 11 Apr 2013 17:15:42 +1000
parents 1f6dce3d34e0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
1 # $Id: SeqBuilder.pm,v 1.6 2002/10/22 07:45:20 lapp Exp $
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
2 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
3 # BioPerl module for Bio::Seq::SeqBuilder
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
4 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
5 # Cared for by Hilmar Lapp <hlapp at gmx.net>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
6 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
7 # Copyright Hilmar Lapp
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
8 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
9 # You may distribute this module under the same terms as perl itself
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
10
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
11 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
12 # (c) Hilmar Lapp, hlapp at gmx.net, 2002.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
13 # (c) GNF, Genomics Institute of the Novartis Research Foundation, 2002.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
14 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
15 # You may distribute this module under the same terms as perl itself.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
16 # Refer to the Perl Artistic License (see the license accompanying this
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
17 # software package, or see http://www.perl.com/language/misc/Artistic.html)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
18 # for the terms under which you may use, modify, and redistribute this module.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
19 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
20 # THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR IMPLIED
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
21 # WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
22 # MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
23 #
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
24
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
25 # POD documentation - main docs before the code
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
26
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
27 =head1 NAME
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
28
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
29 Bio::Seq::SeqBuilder - Configurable object builder for sequence stream parsers
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
30
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
31 =head1 SYNOPSIS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
32
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
33 use Bio::SeqIO;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
34
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
35 # usually you won't instantiate this yourself -- a SeqIO object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
36 # will have one already
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
37 my $seqin = Bio::SeqIO->new(-fh => \*STDIN, -format => "genbank");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
38 my $builder = $seqin->sequence_builder();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
39
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
40 # if you need only sequence, id, and description (e.g. for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
41 # conversion to FASTA format):
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
42 $builder->want_none();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
43 $builder->add_wanted_slot('display_id','desc','seq');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
44
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
45 # if you want everything except the sequence and features
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
46 $builder->want_all(1); # this is the default if it's untouched
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
47 $builder->add_unwanted_slot('seq','features');
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
48
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
49 # if you want only human sequences shorter than 5kb and skip all
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
50 # others
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
51 $builder->add_object_condition(sub {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
52 my $h = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
53 return 0 if $h->{'-length'} > 5000;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
54 return 0 if exists($h->{'-species'}) &&
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
55 ($h->{'-species'}->binomial() ne "Homo sapiens");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
56 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
57 });
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
58
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
59 # when you are finished with configuring the builder, just use
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
60 # the SeqIO API as you would normally
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
61 while(my $seq = $seqin->next_seq()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
62 # do something
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
63 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
64
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
65 =head1 DESCRIPTION
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
66
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
67 This is an implementation of L<Bio::Factory::ObjectBuilderI> used by
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
68 parsers of rich sequence streams. It provides for a relatively
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
69 easy-to-use configurator of the parsing flow.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
70
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
71 Configuring the parsing process may be for you if you need much less
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
72 information, or much less sequences, than the stream actually
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
73 contains. Configuration can in both cases speed up the parsing time
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
74 considerably, because unwanted sections or the rest of unwanted
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
75 sequences are skipped over by the parser.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
76
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
77 See the methods of the class-specific implementation section for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
78 further documentation of what can be configured.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
79
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
80 =head1 FEEDBACK
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
81
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
82 =head2 Mailing Lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
83
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
84 User feedback is an integral part of the evolution of this and other
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
85 Bioperl modules. Send your comments and suggestions preferably to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
86 the Bioperl mailing list. Your participation is much appreciated.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
87
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
88 bioperl-l@bioperl.org - General discussion
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
89 http://bioperl.org/MailList.shtml - About the mailing lists
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
90
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
91 =head2 Reporting Bugs
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
92
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
93 Report bugs to the Bioperl bug tracking system to help us keep track
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
94 of the bugs and their resolution. Bug reports can be submitted via
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
95 email or the web:
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
96
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
97 bioperl-bugs@bioperl.org
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
98 http://bugzilla.bioperl.org/
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
99
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
100 =head1 AUTHOR - Hilmar Lapp
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
101
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
102 Email hlapp at gmx.net
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
103
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
104 =head1 CONTRIBUTORS
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
105
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
106 Additional contributors names and emails here
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
107
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
108 =head1 APPENDIX
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
109
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
110 The rest of the documentation details each of the object methods.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
111 Internal methods are usually preceded with a _
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
112
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
113 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
114
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
115
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
116 # Let the code begin...
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
117
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
118
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
119 package Bio::Seq::SeqBuilder;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
120 use vars qw(@ISA);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
121 use strict;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
122
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
123 # Object preamble - inherits from Bio::Root::Root
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
124
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
125 use Bio::Root::Root;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
126 use Bio::Factory::ObjectBuilderI;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
127
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
128 @ISA = qw(Bio::Root::Root Bio::Factory::ObjectBuilderI);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
129
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
130 my %slot_param_map = ("add_SeqFeature" => "features",
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
131 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
132 my %param_slot_map = ("features" => "add_SeqFeature",
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
133 );
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
134
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
135 =head2 new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
136
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
137 Title : new
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
138 Usage : my $obj = new Bio::Seq::SeqBuilder();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
139 Function: Builds a new Bio::Seq::SeqBuilder object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
140 Returns : an instance of Bio::Seq::SeqBuilder
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
141 Args :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
142
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
143
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
144 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
145
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
146 sub new {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
147 my($class,@args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
148
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
149 my $self = $class->SUPER::new(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
150
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
151 $self->{'wanted_slots'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
152 $self->{'unwanted_slots'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
153 $self->{'object_conds'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
154 $self->{'_objhash'} = {};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
155 $self->want_all(1);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
156
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
157 return $self;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
158 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
159
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
160 =head1 Methods for implementing L<Bio::Factory::ObjectBuilderI>
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
161
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
162 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
163
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
164 =head2 want_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
165
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
166 Title : want_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
167 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
168 Function: Whether or not the object builder wants to populate the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
169 specified slot of the object to be built.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
170
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
171 The slot can be specified either as the name of the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
172 respective method, or the initialization parameter that
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
173 would be otherwise passed to new() of the object to be
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
174 built.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
175
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
176 Note that usually only the parser will call this
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
177 method. Use add_wanted_slots and add_unwanted_slots for
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
178 configuration.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
179
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
180 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
181 Returns : TRUE if the object builder wants to populate the slot, and
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
182 FALSE otherwise.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
183 Args : the name of the slot (a string)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
184
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
185
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
186 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
187
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
188 sub want_slot{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
189 my ($self,$slot) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
190 my $ok = 0;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
191
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
192 $slot = substr($slot,1) if substr($slot,0,1) eq '-';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
193 if($self->want_all()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
194 foreach ($self->get_unwanted_slots()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
195 # this always overrides in want-all mode
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
196 return 0 if($slot eq $_);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
197 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
198 if(! exists($self->{'_objskel'})) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
199 $self->{'_objskel'} = $self->sequence_factory->create_object();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
200 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
201 if(exists($param_slot_map{$slot})) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
202 $ok = $self->{'_objskel'}->can($param_slot_map{$slot});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
203 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
204 $ok = $self->{'_objskel'}->can($slot);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
205 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
206 return $ok if $ok;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
207 # even if the object 'cannot' do this slot, it might have been
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
208 # added to the list of wanted slot, so carry on
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
209 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
210 foreach ($self->get_wanted_slots()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
211 if($slot eq $_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
212 $ok = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
213 last;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
214 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
215 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
216 return $ok;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
217 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
218
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
219 =head2 add_slot_value
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
220
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
221 Title : add_slot_value
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
222 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
223 Function: Adds one or more values to the specified slot of the object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
224 to be built.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
225
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
226 Naming the slot is the same as for want_slot().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
227
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
228 The object builder may further filter the content to be
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
229 set, or even completely ignore the request.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
230
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
231 If this method reports failure, the caller should not add
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
232 more values to the same slot. In addition, the caller may
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
233 find it appropriate to abandon the object being built
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
234 altogether.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
235
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
236 This implementation will allow the caller to overwrite the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
237 return value from want_slot(), because the slot is not
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
238 checked against want_slot().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
239
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
240 Note that usually only the parser will call this method,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
241 but you may call it from anywhere if you know what you are
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
242 doing. A derived class may be used to further manipulate
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
243 the value to be added.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
244
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
245 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
246 Returns : TRUE on success, and FALSE otherwise
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
247 Args : the name of the slot (a string)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
248 parameters determining the value to be set
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
249
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
250 OR
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
251
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
252 alternatively, a list of slotname/value pairs in the style
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
253 of named parameters as they would be passed to new(), where
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
254 each element at an even index is the parameter (slot) name
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
255 starting with a dash, and each element at an odd index is
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
256 the value of the preceding name.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
257
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
258
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
259 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
260
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
261 sub add_slot_value{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
262 my ($self,$slot,@args) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
263
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
264 my $h = $self->{'_objhash'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
265 return unless $h;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
266 # multiple named parameter variant of calling?
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
267 if((@args > 1) && (@args % 2) && (substr($slot,0,1) eq '-')) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
268 unshift(@args, $slot);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
269 while(@args) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
270 my $key = shift(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
271 $h->{$key} = shift(@args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
272 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
273 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
274 if($slot eq 'add_SeqFeature') {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
275 $slot = '-'.$slot_param_map{$slot};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
276 $h->{$slot} = [] unless $h->{$slot};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
277 push(@{$h->{$slot}}, @args);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
278 } else {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
279 $slot = '-'.$slot unless substr($slot,0,1) eq '-';
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
280 $h->{$slot} = $args[0];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
281 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
282 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
283 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
284 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
285
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
286 =head2 want_object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
287
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
288 Title : want_object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
289 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
290 Function: Whether or not the object builder is still interested in
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
291 continuing with the object being built.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
292
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
293 If this method returns FALSE, the caller should not add any
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
294 more values to slots, or otherwise risks that the builder
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
295 throws an exception. In addition, make_object() is likely
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
296 to return undef after this method returned FALSE.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
297
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
298 Note that usually only the parser will call this
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
299 method. Use add_object_condition for configuration.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
300
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
301 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
302 Returns : TRUE if the object builder wants to continue building
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
303 the present object, and FALSE otherwise.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
304 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
305
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
306
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
307 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
308
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
309 sub want_object{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
310 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
311
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
312 my $ok = 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
313 foreach my $cond ($self->get_object_conditions()) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
314 $ok = &$cond($self->{'_objhash'});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
315 last unless $ok;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
316 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
317 delete $self->{'_objhash'} unless $ok;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
318 return $ok;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
319 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
320
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
321 =head2 make_object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
322
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
323 Title : make_object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
324 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
325 Function: Get the built object.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
326
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
327 This method is allowed to return undef if no value has ever
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
328 been added since the last call to make_object(), or if
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
329 want_object() returned FALSE (or would have returned FALSE)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
330 before calling this method.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
331
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
332 For an implementation that allows consecutive building of
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
333 objects, a caller must call this method once, and only
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
334 once, between subsequent objects to be built. I.e., a call
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
335 to make_object implies 'end_object.'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
336
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
337 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
338 Returns : the object that was built
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
339 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
340
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
341
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
342 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
343
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
344 sub make_object{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
345 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
346
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
347 my $obj;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
348 if(exists($self->{'_objhash'}) && %{$self->{'_objhash'}}) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
349 $obj = $self->sequence_factory->create_object(%{$self->{'_objhash'}});
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
350 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
351 $self->{'_objhash'} = {}; # reset
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
352 return $obj;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
353 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
354
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
355 =head1 Implementation specific methods
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
356
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
357 These methods allow to conveniently configure this sequence object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
358 builder as to which slots are desired, and under which circumstances a
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
359 sequence object should be abandoned altogether. The default mode is
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
360 want_all(1), which means the builder will report all slots as wanted
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
361 that the object created by the sequence factory supports.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
362
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
363 You can add specific slots you want through add_wanted_slots(). In
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
364 most cases, you will want to call want_none() before in order to relax
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
365 zero acceptance through a list of wanted slots.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
366
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
367 Alternatively, you can add specific unwanted slots through
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
368 add_unwanted_slots(). In this case, you will usually want to call
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
369 want_all(1) before (which is the default if you never touched the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
370 builder) to restrict unrestricted acceptance.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
371
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
372 I.e., want_all(1) means want all slots except for the unwanted, and
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
373 want_none() means only those explicitly wanted.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
374
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
375 If a slot is in both the unwanted and the wanted list, the following
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
376 rules hold. In want-all mode, the unwanted list overrules. In
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
377 want-none mode, the wanted list overrides the unwanted list. If this
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
378 is confusing to you, just try to avoid having slots at the same time
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
379 in the wanted and the unwanted lists.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
380
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
381 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
382
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
383 =head2 get_wanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
384
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
385 Title : get_wanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
386 Usage : $obj->get_wanted_slots($newval)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
387 Function: Get the list of wanted slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
388 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
389 Returns : a list of strings
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
390 Args :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
391
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
392
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
393 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
394
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
395 sub get_wanted_slots{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
396 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
397
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
398 return @{$self->{'wanted_slots'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
399 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
400
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
401 =head2 add_wanted_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
402
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
403 Title : add_wanted_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
404 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
405 Function: Adds the specified slots to the list of wanted slots.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
406 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
407 Returns : TRUE
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
408 Args : an array of slot names (strings)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
409
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
410
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
411 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
412
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
413 sub add_wanted_slot{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
414 my ($self,@slots) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
415
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
416 my $myslots = $self->{'wanted_slots'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
417 foreach my $slot (@slots) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
418 if(! grep { $slot eq $_; } @$myslots) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
419 push(@$myslots, $slot);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
420 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
421 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
422 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
423 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
424
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
425 =head2 remove_wanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
426
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
427 Title : remove_wanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
428 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
429 Function: Removes all wanted slots added previously through
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
430 add_wanted_slots().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
431 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
432 Returns : the previous list of wanted slot names
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
433 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
434
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
435
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
436 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
437
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
438 sub remove_wanted_slots{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
439 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
440 my @slots = $self->get_wanted_slots();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
441 $self->{'wanted_slots'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
442 return @slots;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
443 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
444
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
445 =head2 get_unwanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
446
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
447 Title : get_unwanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
448 Usage : $obj->get_unwanted_slots($newval)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
449 Function: Get the list of unwanted slots.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
450 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
451 Returns : a list of strings
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
452 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
453
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
454
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
455 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
456
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
457 sub get_unwanted_slots{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
458 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
459
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
460 return @{$self->{'unwanted_slots'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
461 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
462
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
463 =head2 add_unwanted_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
464
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
465 Title : add_unwanted_slot
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
466 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
467 Function: Adds the specified slots to the list of unwanted slots.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
468 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
469 Returns : TRUE
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
470 Args : an array of slot names (strings)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
471
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
472
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
473 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
474
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
475 sub add_unwanted_slot{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
476 my ($self,@slots) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
477
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
478 my $myslots = $self->{'unwanted_slots'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
479 foreach my $slot (@slots) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
480 if(! grep { $slot eq $_; } @$myslots) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
481 push(@$myslots, $slot);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
482 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
483 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
484 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
485 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
486
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
487 =head2 remove_unwanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
488
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
489 Title : remove_unwanted_slots
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
490 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
491 Function: Removes the list of unwanted slots added previously through
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
492 add_unwanted_slots().
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
493 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
494 Returns : the previous list of unwanted slot names
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
495 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
496
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
497
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
498 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
499
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
500 sub remove_unwanted_slots{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
501 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
502 my @slots = $self->get_unwanted_slots();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
503 $self->{'unwanted_slots'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
504 return @slots;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
505 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
506
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
507 =head2 want_none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
508
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
509 Title : want_none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
510 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
511 Function: Disables all slots. After calling this method, want_slot()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
512 will return FALSE regardless of slot name.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
513
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
514 This is different from removed_wanted_slots() in that it
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
515 also sets want_all() to FALSE. Note that it also resets the
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
516 list of unwanted slots in order to avoid slots being in
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
517 both lists.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
518
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
519 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
520 Returns : TRUE
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
521 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
522
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
523
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
524 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
525
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
526 sub want_none{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
527 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
528
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
529 $self->want_all(0);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
530 $self->remove_wanted_slots();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
531 $self->remove_unwanted_slots();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
532 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
533 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
534
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
535 =head2 want_all
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
536
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
537 Title : want_all
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
538 Usage : $obj->want_all($newval)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
539 Function: Whether or not this sequence object builder wants to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
540 populate all slots that the object has. Whether an object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
541 supports a slot is generally determined by what can()
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
542 returns. You can add additional 'virtual' slots by calling
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
543 add_wanted_slot.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
544
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
545 This will be ON by default. Call $obj->want_none() to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
546 disable all slots.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
547
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
548 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
549 Returns : TRUE if this builder wants to populate all slots, and
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
550 FALSE otherwise.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
551 Args : on set, new value (a scalar or undef, optional)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
552
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
553
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
554 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
555
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
556 sub want_all{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
557 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
558
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
559 return $self->{'want_all'} = shift if @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
560 return $self->{'want_all'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
561 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
562
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
563 =head2 get_object_conditions
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
564
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
565 Title : get_object_conditions
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
566 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
567 Function: Get the list of conditions an object must meet in order to
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
568 be 'wanted.' See want_object() for where this is used.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
569
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
570 Conditions in this implementation are closures (anonymous
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
571 functions) which are passed one parameter, a hash reference
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
572 the keys of which are equal to initialization
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
573 paramaters. The closure must return TRUE to make the object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
574 'wanted.'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
575
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
576 Conditions will be implicitly ANDed.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
577
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
578 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
579 Returns : a list of closures
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
580 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
581
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
582
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
583 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
584
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
585 sub get_object_conditions{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
586 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
587
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
588 return @{$self->{'object_conds'}};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
589 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
590
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
591 =head2 add_object_condition
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
592
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
593 Title : add_object_condition
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
594 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
595 Function: Adds a condition an object must meet in order to be 'wanted.'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
596 See want_object() for where this is used.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
597
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
598 Conditions in this implementation must be closures
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
599 (anonymous functions). These will be passed one parameter,
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
600 which is a hash reference with the sequence object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
601 initialization paramters being the keys.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
602
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
603 Conditions are implicitly ANDed. If you want other
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
604 operators, perform those tests inside of one closure
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
605 instead of multiple. This will also be more efficient.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
606
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
607 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
608 Returns : TRUE
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
609 Args : the list of conditions
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
610
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
611
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
612 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
613
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
614 sub add_object_condition{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
615 my ($self,@conds) = @_;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
616
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
617 if(grep { ref($_) ne 'CODE'; } @conds) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
618 $self->throw("conditions against which to validate an object ".
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
619 "must be anonymous code blocks");
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
620 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
621 push(@{$self->{'object_conds'}}, @conds);
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
622 return 1;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
623 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
624
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
625 =head2 remove_object_conditions
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
626
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
627 Title : remove_object_conditions
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
628 Usage :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
629 Function: Removes the conditions an object must meet in order to be
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
630 'wanted.'
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
631 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
632 Returns : The list of previously set conditions (an array of closures)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
633 Args : none
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
634
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
635
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
636 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
637
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
638 sub remove_object_conditions{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
639 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
640 my @conds = $self->get_object_conditions();
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
641 $self->{'object_conds'} = [];
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
642 return @conds;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
643 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
644
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
645 =head1 Methods to control what type of object is built
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
646
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
647 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
648
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
649 =head2 sequence_factory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
650
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
651 Title : sequence_factory
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
652 Usage : $obj->sequence_factory($newval)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
653 Function: Get/set the sequence factory to be used by this object
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
654 builder.
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
655 Example :
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
656 Returns : the Bio::Factory::SequenceFactoryI implementing object to use
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
657 Args : on set, new value (a Bio::Factory::SequenceFactoryI
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
658 implementing object or undef, optional)
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
659
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
660
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
661 =cut
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
662
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
663 sub sequence_factory{
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
664 my $self = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
665
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
666 if(@_) {
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
667 delete $self->{'_objskel'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
668 return $self->{'sequence_factory'} = shift;
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
669 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
670 return $self->{'sequence_factory'};
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
671 }
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
672
1f6dce3d34e0 Uploaded
mahtabm
parents:
diff changeset
673 1;