annotate cpt_psm_prep/lib/CPT/Parameter/Float.pm @ 0:e4de0a0e90c8 draft

Uploaded
author cpt
date Tue, 05 Jul 2022 05:38:34 +0000
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
1 package CPT::Parameter::Float;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
2 use Scalar::Util qw(looks_like_number);
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
3 use Moose;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
4 with 'CPT::Parameter';
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
5
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
6 has 'min' => ( is => 'rw', isa => 'Num' );
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
7 has 'max' => ( is => 'rw', isa => 'Num' );
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
8
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
9
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
10 sub galaxy_input {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
11 my ( $self, $xml_writer ) = @_;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
12 $self->handle_possible_galaxy_input_repeat_start($xml_writer);
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
13 my %params = $self->get_default_input_parameters('float');
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
14
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
15 if(defined $self->min()){
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
16 $params{min} = $self->min();
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
17 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
18 if(defined $self->max()){
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
19 $params{max} = $self->max();
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
20 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
21
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
22 $xml_writer->startTag(
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
23 'param',
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
24 %params
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
25 );
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
26 $xml_writer->endTag('param');
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
27 $self->handle_possible_galaxy_input_repeat_end($xml_writer);
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
28 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
29
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
30
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
31 sub galaxy_output {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
32
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
33 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
34
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
35
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
36 sub validate_individual {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
37 my ($self, $value) = @_;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
38 if ( looks_like_number( $value ) ) {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
39 # Check bounds
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
40 if ( defined $self->max() && $value > $self->max() ) {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
41 push(@{$self->errors()}, sprintf( "Value passed with %s was greater than the allowable upper bound. [%s > %s]", $self->name(), $value, $self->max() ));
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
42 return 0;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
43 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
44 if ( defined $self->min() && $value < $self->min() ) {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
45 push(@{$self->errors()}, sprintf( "Value passed with %s was smaller than the allowable minimum bound. [%s < %s]", $self->name(), $value, $self->min() ));
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
46 return 0;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
47 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
48 return 1;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
49 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
50 else {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
51 push(@{$self->errors()}, sprintf( "Value passed with %s does not look like a float [%s]", $self->name(), $value ));
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
52 return 0;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
53 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
54 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
55
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
56
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
57 sub getopt_format {
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
58 return '=s';
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
59 }
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
60
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
61 no Moose;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
62 1;
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
63
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
64 __END__
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
65
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
66 =pod
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
67
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
68 =encoding UTF-8
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
69
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
70 =head1 NAME
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
71
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
72 CPT::Parameter::Float
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
73
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
74 =head1 VERSION
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
75
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
76 version 1.99.4
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
77
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
78 =head2 galaxy_input
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
79
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
80 $file_param->galaxy_input($xml_writer); # where $file_param is a CPT::Parameter::*
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
81
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
82 Utilises the $xml_writer to add a <data> block in the <output> section
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
83
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
84 =head2 galaxy_output
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
85
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
86 $file_param->galaxy_output($xml_writer); # where $file_param is a CPT::Parameter::*
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
87
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
88 Utilises the $xml_writer to add a <data> block in the <output> section
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
89
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
90 =head2 getopt_format
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
91
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
92 Returns the format character for a given CPT::Parameter::* type
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
93
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
94 =head1 AUTHOR
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
95
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
96 Eric Rasche <rasche.eric@yandex.ru>
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
97
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
98 =head1 COPYRIGHT AND LICENSE
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
99
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
100 This software is Copyright (c) 2014 by Eric Rasche.
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
101
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
102 This is free software, licensed under:
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
103
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
104 The GNU General Public License, Version 3, June 2007
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
105
e4de0a0e90c8 Uploaded
cpt
parents:
diff changeset
106 =cut