File Coverage

blib/lib/Protocol/DBus/Pack.pm
Criterion Covered Total %
statement 33 33 100.0
branch 6 6 100.0
condition 3 3 100.0
subroutine 9 9 100.0
pod 0 2 0.0
total 51 53 96.2


line stmt bran cond sub pod time code
1             package Protocol::DBus::Pack;
2              
3 6     6   35 use strict;
  6         9  
  6         141  
4 6     6   25 use warnings;
  6         8  
  6         206  
5              
6 6     6   26 use constant CAN_64 => eval { !!pack 'q' };
  6         9  
  6         11  
  6         458  
7              
8 6         375 use constant NUMERIC => {
9             y => 'C', # uint8
10             b => 'L', # boolean (uint32)
11             n => 's', # int16
12             q => 'S', # uint16
13             i => 'l', # int32
14             u => 'L', # uint32
15             x => 'q', # int64
16             t => 'Q', # uint64
17             d => 'd', # double float (?)
18             h => 'L', # unix fd, uint32
19 6     6   33 };
  6         12  
20              
21 6         706 use constant STRING => {
22             s => 'L/a x',
23             o => 'L/a x',
24             g => 'C/a x',
25 6     6   37 };
  6         8  
26              
27             use constant WIDTH => {
28              
29             # Accommodate 32-bit Perls:
30 60 100 100     235 (map { $_ => ($_ eq 'x' || $_ eq 't') ? 8 : length pack NUMERIC()->{$_} } keys %{ NUMERIC() }),
  6         25  
31 6         12 (map { $_ => length pack STRING()->{$_} } keys %{ STRING() }),
  18         590  
  6         18  
32 6     6   57 };
  6         11  
33              
34             use constant ALIGNMENT => {
35 6         25 %{ WIDTH() },
36 6         13 map { $_ => length pack( substr( STRING()->{$_}, 0, 1 ) ) } keys %{ STRING() },
  18         936  
  6         14  
37 6     6   38 };
  6         19  
38              
39             # Increments the 1st arg in-place to align on a boundary of the 2nd arg.
40             # ex. align( 7, 8 ) will change the $_[0] to be 8.
41             sub align {
42 1789 100   1789 0 3731 if ($_[0] % $_[1]) {
43 222         442 $_[0] += ($_[1] - ($_[0] % $_[1]));
44             }
45             }
46              
47             sub align_str {
48 207 100   207 0 451 if (my $mod = length($_[0]) % $_[1]) {
49 31         86 $_[0] .= "\0" x ($_[1] - $mod);
50             }
51             }
52              
53             1;