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 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131
|
package Code::TidyAll::Plugin::PerlTidySweet;
use strict;
use warnings;
use Capture::Tiny qw(capture_merged);
use Perl::Tidy::Sweetened 1.00;
use Moo;
extends 'Code::TidyAll::Plugin';
our $VERSION = '0.78';
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;
# ABSTRACT: Use perltidy-sweet with tidyall
__END__
=pod
=encoding UTF-8
=head1 NAME
Code::TidyAll::Plugin::PerlTidySweet - Use perltidy-sweet with tidyall
=head1 VERSION
version 0.78
=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
This plugin accepts the following configuration options:
=head2 argv
Arguments to pass to C<perltidy-sweet>.
=head1 SUPPORT
Bugs may be submitted at
L<https://github.com/houseabsolute/perl-code-tidyall/issues>.
I am also usually active on IRC as 'autarch' on C<irc://irc.perl.org>.
=head1 SOURCE
The source code repository for Code-TidyAll can be found at
L<https://github.com/houseabsolute/perl-code-tidyall>.
=head1 AUTHORS
=over 4
=item *
Jonathan Swartz <swartz@pobox.com>
=item *
Dave Rolsky <autarch@urth.org>
=back
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2011 - 2020 by Jonathan Swartz.
This is free software; you can redistribute it and/or modify it under the same
terms as the Perl 5 programming language system itself.
The full text of the license can be found in the F<LICENSE> file included with
this distribution.
=cut
|