annotate cpt_psm_recombine/lib/CPT/Parameter/Int.pm @ 0:b18e8268bf4e draft

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