File Coverage

lib/SVG/Estimate/Path/HorizontalLineto.pm
Criterion Covered Total %
statement 17 17 100.0
branch 10 12 83.3
condition n/a
subroutine 2 2 100.0
pod 0 1 0.0
total 29 32 90.6


line stmt bran cond sub pod time code
1             package SVG::Estimate::Path::HorizontalLineto;
2             $SVG::Estimate::Path::HorizontalLineto::VERSION = '1.0113';
3 10     10   1349 use Moo;
  10         18  
  10         50  
4              
5             extends 'SVG::Estimate::Path::Command';
6             with 'SVG::Estimate::Role::Pythagorean';
7              
8             =head1 NAME
9              
10             SVG::Estimate::Path::HorizontalLineto - Handles estimating horizontal lines.
11              
12             =head1 VERSION
13              
14             version 1.0113
15              
16             =head1 SYNOPSIS
17              
18             my $line = SVG::Estimate::Path::HorizontalLineto->new(
19             transformer => $transform,
20             start_point => [13, 19],
21             x => 13,
22             );
23              
24             my $length = $line->length;
25              
26             =head1 INHERITANCE
27              
28             This class extends L and consumes L.
29              
30             =head1 METHODS
31              
32             =head2 new()
33              
34             Constructor.
35              
36             =over
37              
38             =item x
39              
40             A float indicating what to change the x value to.
41              
42             =back
43              
44             =cut
45              
46             has x => (
47             is => 'ro',
48             required => 1,
49             );
50              
51             sub BUILDARGS {
52 34     34 0 8592 my ($class, @args) = @_;
53             ##Upgrade to hashref
54 34 100       93 my $args = @args % 2 ? $args[0] : { @args };
55 34         99 my $end = [$args->{x}, $args->{start_point}[0]];
56 34 100       106 if ($args->{transformer}->has_transforms) {
57 1         6 $end = $args->{transformer}->transform($end);
58             }
59 34         392 $args->{end_point} = [$end->[0], $args->{start_point}[1]];
60 34         93 $args->{y} = $args->{end_point}[1];
61 34         101 $args->{shape_length} = $class->pythagorean($args->{start_point}, $args->{end_point});
62 34         65 $args->{travel_length} = 0;
63 34 100       104 $args->{min_x} = $args->{start_point}[0] < $args->{end_point}->[0] ? $args->{start_point}[0] : $args->{end_point}->[0];
64 34 50       80 $args->{min_y} = $args->{start_point}[1] < $args->{end_point}->[1] ? $args->{start_point}[1] : $args->{end_point}->[1];
65 34 100       85 $args->{max_x} = $args->{start_point}[0] > $args->{end_point}->[0] ? $args->{start_point}[0] : $args->{end_point}->[0];
66 34 50       88 $args->{max_y} = $args->{start_point}[1] > $args->{end_point}->[1] ? $args->{start_point}[1] : $args->{end_point}->[1];
67 34         519 return $args;
68             }
69              
70             1;