package Code::TidyAll::Plugin::JSBeautify;
use strict;
use warnings;
use IPC::Run3 qw(run3);
use Text::ParseWords qw(shellwords);
use Try::Tiny;
use Moo;
extends 'Code::TidyAll::Plugin';
with 'Code::TidyAll::Role::RunsCommand';
our $VERSION = '0.70';
sub _build_cmd {'js-beautify'}
sub transform_file {
my ( $self, $file ) = @_;
my $output = $self->_run_or_die( '-f', $file );
$file->spew($output);
return;
}
1;
# ABSTRACT: Use js-beautify with tidyall
__END__
=pod
=encoding UTF-8
=head1 NAME
Code::TidyAll::Plugin::JSBeautify - Use js-beautify with tidyall
=head1 VERSION
version 0.70
=head1 SYNOPSIS
In configuration:
[JSBeautify]
select = static/**/*.js
argv = --indent-size 2 --brace-style expand
=head1 DESCRIPTION
Runs L<js-beautify|https://npmjs.org/package/js-beautify>, a JavaScript tidier.
=head1 INSTALLATION
Install L<npm|https://npmjs.org/>, then run
npm install js-beautify -g
Do not confuse this with the C<jsbeautify> command, which is provided by the
L<JavaScript::Beautifier> module.
=head1 CONFIGURATION
This plugin accepts the following configuration options:
=head2 argv
Arguments to pass to C<js-beautify>.
=head2 cmd
The path for the C<js-beautify> command. By default this is just
C<js-beautify>, meaning that the user's C<PATH> will be searched for the
command.
=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 - 2018 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