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 8     8   42 use strict;
  8         15  
  8         178  
4 8     8   32 use warnings;
  8         10  
  8         272  
5              
6 8     8   35 use constant CAN_64 => eval { !!pack 'q' };
  8         15  
  8         15  
  8         670  
7              
8 8         516 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 8     8   48 };
  8         13  
20              
21 8         857 use constant STRING => {
22             s => 'L/a x',
23             o => 'L/a x',
24             g => 'C/a x',
25 8     8   37 };
  8         15  
26              
27             use constant WIDTH => {
28              
29             # Accommodate 32-bit Perls:
30 80 100 100     379 (map { $_ => ($_ eq 'x' || $_ eq 't') ? 8 : length pack NUMERIC()->{$_} } keys %{ NUMERIC() }),
  8         33  
31 8         15 (map { $_ => length pack STRING()->{$_} } keys %{ STRING() }),
  24         822  
  8         34  
32 8     8   77 };
  8         27  
33              
34             use constant ALIGNMENT => {
35 8         32 %{ WIDTH() },
36 8         10 map { $_ => length pack( substr( STRING()->{$_}, 0, 1 ) ) } keys %{ STRING() },
  24         1204  
  8         18  
37 8     8   50 };
  8         15  
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 1942 100   1942 0 3182 if ($_[0] % $_[1]) {
43 240         390 $_[0] += ($_[1] - ($_[0] % $_[1]));
44             }
45             }
46              
47             sub align_str {
48 295 100   295 0 568 if (my $mod = length($_[0]) % $_[1]) {
49 44         125 $_[0] .= "\0" x ($_[1] - $mod);
50             }
51             }
52              
53             1;