File Coverage

blib/lib/VoiceXML/Client/Item/Prompt.pm
Criterion Covered Total %
statement 22 32 68.7
branch 4 10 40.0
condition 2 6 33.3
subroutine 5 6 83.3
pod 1 2 50.0
total 34 56 60.7


line stmt bran cond sub pod time code
1              
2             package VoiceXML::Client::Item::Prompt;
3              
4              
5 3     3   18 use base qw (VoiceXML::Client::Item);
  3         5  
  3         271  
6 3     3   16 use VoiceXML::Client::Util;
  3         6  
  3         83  
7              
8              
9             =head1 COPYRIGHT AND LICENSE
10              
11            
12             Copyright (C) 2007,2008 by Pat Deegan.
13             All rights reserved
14             http://voicexml.psychogenic.com
15              
16             This library is released under the terms of the GNU GPL version 3, making it available only for
17             free programs ("free" here being used in the sense of the GPL, see http://www.gnu.org for more details).
18             Anyone wishing to use this library within a proprietary or otherwise non-GPLed program MUST contact psychogenic.com to
19             acquire a distinct license for their application. This approach encourages the use of free software
20             while allowing for proprietary solutions that support further development.
21              
22              
23             This file is part of VoiceXML::Client.
24              
25            
26            
27             VoiceXML::Client is free software: you can redistribute it and/or modify
28             it under the terms of the GNU General Public License as published by
29             the Free Software Foundation, either version 3 of the License, or
30             (at your option) any later version.
31              
32             VoiceXML::Client is distributed in the hope that it will be useful,
33             but WITHOUT ANY WARRANTY; without even the implied warranty of
34             MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
35             GNU General Public License for more details.
36              
37             You should have received a copy of the GNU General Public License
38             along with VoiceXML::Client. If not, see .
39              
40              
41             =cut
42              
43              
44              
45 3     3   14 use strict;
  3         5  
  3         105  
46              
47              
48 3         1208 use vars qw{
49             $VERSION
50             $DefaultTimeoutSeconds
51 3     3   13 };
  3         5  
52              
53             $VERSION = $VoiceXML::Client::Item::VERSION;
54              
55             $DefaultTimeoutSeconds = 7;
56              
57             sub init {
58 4     4 1 8 my $self = shift;
59            
60 4   66     15 my $timeout = $self->{'XMLElement'}->attribute('timeout') || $DefaultTimeoutSeconds;
61            
62 4 100       81 if ($timeout =~ m/^\s*(\d+)(\w+)/)
63             {
64 1         5 my $timeVal = $1;
65 1         4 my $timeUnit = $2;
66 1 50       3 if ($timeUnit eq 's')
    0          
67             {
68 1         4 $timeout = $1;
69             } elsif ($timeUnit eq 'ms')
70             {
71 0         0 $timeout = int($timeVal / 1000);
72            
73             } else {
74 0         0 VoiceXML::Client::Util::log_msg("Invalid prompt timeout time unit $timeUnit -- defaulting to $DefaultTimeoutSeconds seconds");
75 0         0 $timeout = $DefaultTimeoutSeconds;
76             }
77            
78 1 50       5 if ($timeout < 1)
79             {
80 0         0 VoiceXML::Client::Util::log_msg("Timeout for prompt too small ($timeout) -- defaulting to 1s");
81 0         0 $timeout = 1;
82             }
83             }
84            
85 4         11 $self->{'timeoutseconds'} = $timeout;
86              
87            
88 4         13 return 1;
89            
90             }
91              
92             sub timeoutSeconds {
93 0     0 0   my $self = shift;
94 0           my $setTo = shift;
95            
96 0 0 0       if (defined $setTo && $setTo =~ m/^\d+$/)
97             {
98 0           $self->{'timeoutseconds'} = $setTo;
99             }
100            
101 0           return $self->{'timeoutseconds'};
102             }
103              
104             1;