grunt-lint-pattern

0.1.4 • Public • Published

grunt-lint-pattern

Find a pattern in files. Error if any match.

Getting Started

This plugin requires Grunt ~0.4.1

If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:

npm install grunt-lint-pattern --save-dev

Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:

grunt.loadNpmTasks('grunt-lint-pattern');

The "lint_pattern" task

Overview

In your project's Gruntfile, add a section named lint_pattern to the data object passed into grunt.initConfig().

grunt.initConfig({
  lint_pattern: {
    your_first_target: {
      options: {
        rules: [
          {
            pattern: /console\./,
            message: 'Do not call "console".'
          },
        ],
      },
      files: {
        '**.js',
      },
    },
    your_second_target: {
      options: {
        rules: [
          {
            pattern: /moz-border-radius/,
            message: 'Do not use vendor prefixes for the border-radius property.'
          },
          {
            pattern: /!important/,
            message: 'Do not use "!important".'
          },
          {
            pattern: /@import\s+/,
            message: 'Do not use import statements',
            filter: function(src) {
 
            }
          },
        ],
      },
      files: {
        '**.css',
      },
    },
  },
})

Options

options.rules

Type: Array Required

An array of "rules" that will be used to test files. Rules have the form:

pattern

Type: RegExp Required

A RegExp that will be used to test files.

pattern

Type: string Optional

A message that will print when pattern is found.

filter

Type: function Optional

If present, this function will be called once for each matching file to decide whether to test this rule. Return true to allow checking this file. Return false to skip checking this file.

This is particularly useful if you are checking a large list of rules over a large list of files and a small number of files that should be excluded by certain rules. The advantage of filtering out the few exclusions compared to creating multiple targets is that the files need only be read from disk once if there's a single target.

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint and test your code using Grunt.

Release History

  • 0.1.0 Initial release
  • 0.1.4 add filter option

Readme

Keywords

none

Package Sidebar

Install

npm i grunt-lint-pattern

Weekly Downloads

16

Version

0.1.4

License

none

Last publish

Collaborators

  • chrisdanford