forked from houseabsolute/perl-code-tidyall
/
PerlTidySweet.pm
81 lines (58 loc) · 1.83 KB
/
PerlTidySweet.pm
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
package Code::TidyAll::Plugin::PerlTidySweet;
use Capture::Tiny qw(capture_merged);
use Perl::Tidy::Sweetened;
use Moo;
extends 'Code::TidyAll::Plugin';
sub transform_source {
my ( $self, $source ) = @_;
# perltidy reports errors in two different ways.
# Argument/profile errors are output and an error_flag is returned.
# Syntax errors are sent to errorfile or stderr, depending on the
# the setting of -se/-nse (aka --standard-error-output). These flags
# might be hidden in other bundles, e.g. -pbp. Be defensive and
# check both.
my ( $output, $error_flag, $errorfile, $stderr, $destination );
$output = capture_merged {
$error_flag = Perl::Tidy::Sweetened::perltidy(
argv => $self->argv,
source => \$source,
destination => \$destination,
stderr => \$stderr,
errorfile => \$errorfile
);
};
die $stderr if $stderr;
die $errorfile if $errorfile;
die $output if $error_flag;
print STDERR $output if defined($output);
return $destination;
}
1;
__END__
=pod
=head1 NAME
Code::TidyAll::Plugin::PerlTidySweet - use perltidy-sweet with tidyall
=head1 SYNOPSIS
# In configuration:
; Configure in-line
;
[PerlTidySweet]
select = lib/**/*.pm
argv = --noll
; or refer to a .perltidyrc in the same directory
;
[PerlTidySweet]
select = lib/**/*.pm
argv = --profile=$ROOT/.perltidyrc
=head1 DESCRIPTION
Runs L<perltidy-sweet>, a Perl tidier based on Perl::Tidy that also
supports new syntactic sugar as provided by L<Method::Signature::Simple>,
L<MooseX::Method::Signatures> and the p5-mop.
=head1 INSTALLATION
Install perltidy-sweet from CPAN.
cpanm Perl::Tidy::Sweet
=head1 CONFIGURATION
=over
=item argv
Arguments to pass to perltidy-sweet
=back