package Code::TidyAll::Plugin::JSHint;

use strict;
use warnings;

use Specio::Library::String;

use Moo;

extends 'Code::TidyAll::Plugin';

has options => (
    is        => 'ro',
    isa       => t('NonEmptyStr'),
    predicate => '_has_options',

with qw( Code::TidyAll::Role::RunsCommand Code::TidyAll::Role::Tempdir );

our $VERSION = '0.78';

sub _build_cmd {'jshint'}

sub validate_file {
    my ( $self, $file ) = @_;

    my $output = $self->_run_or_die( $self->_config_file_argv, $file );
    if ( $output =~ /\S/ ) {
        $output =~ s/^$file:\s*//gm;
        die "$output\n";


sub _config_file_argv {
    my $self = shift;

    return unless $self->_has_options;

    my $conf_file = $self->_tempdir->child('jshint.json');
        '{ ' . join( ",\n", map {qq["$_": true]} split /\s+/, $self->options ) . ' }' );

    return ( '--config', $conf_file );


# ABSTRACT: Use jshint with tidyall



=encoding UTF-8

=head1 NAME

Code::TidyAll::Plugin::JSHint - Use jshint with tidyall

=head1 VERSION

version 0.78


   In configuration:

   ; With default settings
   select = static/**/*.js

   ; Specify options inline
   select = static/**/*.js
   options = bitwise camelcase latedef

   ; or refer to a jshint.json config file in the same directory
   select = static/**/*.js
   argv = --config $ROOT/jshint.json

   where jshint.json looks like

      "bitwise": true,
      "camelcase": true,
      "latedef": true


Runs L<jshint|>, a JavaScript validator, and dies if any
problems were found.


See installation options at L<jshint|>. One
easy method is to install L<npm|>, then run

    npm install jshint -g


This plugin accepts the following configuration options:

=head2 argv

Arguments to pass to C<jshint>.

=head2 cmd

The path for the C<jshint> command. By default this is just C<jshint>, meaning
that the user's C<PATH> will be searched for the command.

=head2 options

A whitespace separated string of options, as L<documented by
jshint|>. These will be written to a temporary
config file and passed as C<--config> argument.

=head1 SUPPORT

Bugs may be submitted at

I am also usually active on IRC as 'autarch' on C<irc://>.

=head1 SOURCE

The source code repository for Code-TidyAll can be found at

=head1 AUTHORS

=over 4

=item *

Jonathan Swartz <>

=item *

Dave Rolsky <>



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.