File Coverage

blib/lib/Protocol/DBus/Signature.pm
Criterion Covered Total %
statement 29 29 100.0
branch 11 12 91.6
condition 3 3 100.0
subroutine 4 4 100.0
pod 0 2 0.0
total 47 50 94.0


line stmt bran cond sub pod time code
1             package Protocol::DBus::Signature;
2              
3 9     9   869 use strict;
  9         11  
  9         217  
4 9     9   36 use warnings;
  9         16  
  9         2175  
5              
6             # Returns a list of single complete types (SCTs).
7              
8             sub split {
9 231     231 0 280 my ($sig) = @_;
10              
11 231         237 my @scts;
12              
13 231         345 while (length($sig)) {
14 296         353 my $next_sct_len = Protocol::DBus::Signature::get_sct_length($sig, 0);
15 296         630 push @scts, substr( $sig, 0, $next_sct_len, q<> );
16             }
17              
18 231         470 return @scts;
19             }
20              
21             # Returns the length of the single complete type at $sct_offset.
22              
23             sub get_sct_length {
24 831     831 0 4749 my ($sig, $sct_offset) = @_;
25              
26 831         833 my $start = $sct_offset;
27              
28 831         970 my $next = substr($sig, $sct_offset, 1);
29              
30 831 100       1147 if ($next eq 'a') {
31              
32             # “{ }” only happens after “a”
33 111         167 my $next_2nd = substr($sig, 1 + $sct_offset, 1);
34 111 100       207 if ($next_2nd eq '{') {
35              
36             # 4 for the “a”, “{”, key type, and “}”.
37             # We assume that the signature is well-formed.
38 43         92 return 4 + get_sct_length($sig, 3 + $sct_offset);
39             }
40              
41 68         99 return 1 + get_sct_length($sig, 1 + $sct_offset);
42             }
43              
44 720 100       962 if ($next eq '(') {
45 39         43 while (1) {
46 121         124 $sct_offset++;
47              
48 121 50       165 last if $sct_offset >= length($sig);
49              
50 121         152 my $next_in_struct = substr($sig, $sct_offset, 1);
51              
52 121 100 100     311 if ($next_in_struct eq '(' || $next_in_struct eq 'a') {
    100          
53 15         34 $sct_offset += get_sct_length($sig, $sct_offset) - 1;
54             }
55             elsif ($next_in_struct eq ')') {
56 39         48 last;
57             }
58             }
59             }
60              
61 720         1116 return 1 + ($sct_offset - $start);
62             }
63              
64             1;