Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@favware/milky-tslint

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@favware/milky-tslint

TypeScript linter Gulp plugin, based on gulp-tslint but updated for modernization

  • 1.1.5
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
15
increased by87.5%
Maintainers
1
Weekly downloads
 
Created
Source

DEPRECATED

TSLint has been deprecated in favor of ESLint. Please see this TSLint issue for more information.


logo

@favware/milky-tslint

TypeScript linter Gulp plugin, based on gulp-tslint but updated for modernization


Project Status

GitHub Codecov

Bundle Sizes

npm bundle size npm bundle size npm

Social Media and Donations

Join Discord server Twitter Follow Patreon Donate PayPal Donate


TypeScript linter plugin for Gulp. Based on gulp-tslint by panuhorsmalahti

Gulp down that milk 🥛!

Install

Install with yarn or npm:

yarn add @favware/milky-tslint tslint

# npm install @favware/milky-tslint tslint

Usage

const tslint = require('tslint');
const ts = require('typescript');
const { milkyLint, milkyReport } = require('milky-tslint');

gulp.task('lint', () => {
  const lintProgram = tslint.Linter.createProgram('./tsconfig.json', '.');
  ts.getPreEmitDiagnostics(lintProgram);

  return gulp
    .src(tsSource)
    .pipe(
      milkyLint({
        formatter: 'stylish',
        program: lintProgram,
        tslint: tslint,
        fix: !!argv.fix
      })
    )
    .pipe(milkyReport());
});

TSLint Type Checking will work if you first use the createProgram function as shown above. You should do this inside the gulp task, otherwise it will get cached and not function in consecutive runs of the task.

tslint.json is attempted to be read from near the input file. It must be available or supplied directly through the options.

The format in which failures are outputted may be controlled by specifying a TSLint formatter.

The default formatter is stylish and the supported formatters are at least:

  • checkstyle - Formats errors as though they were Checkstyle output.
  • codeFrame - Framed formatter which creates a frame of error code.
  • filesList - Lists files containing lint errors.
  • json - Formats errors as simple JSON.
  • junit - Formats errors as though they were JUnit output.
  • msbuild - Formats errors for consumption by msbuild.
  • pmd - Formats errors as though they were PMD output.
  • prose - The default formatter which outputs simple human-readable messages.
  • stylish - Human-readable formatter which creates stylish messages.
  • tap - Formats output as TAP stream.
  • verbose - The human-readable formatter which includes the rule name in messages.
  • vso - Formats output as VSO/TFS logging commands.

For a full list of supported formatters please go to the TSLint core formatters documentation

Custom TSLint formatters may also be used by specifying the formatter and formattersDirectory properties on the options passed to milky-tslint.

If there is at least one failure a PluginError is emitted after execution of the reporters:

[gulp] Error in plugin 'milky-tslint': Failed to lint: input.ts

You can prevent editing the error by setting emitError in report options to false.

gulp.task('lint-noerroremit', () => {
  const lintProgram = tslint.Linter.createProgram('./tsconfig.json', '.');
  ts.getPreEmitDiagnostics(lintProgram);

  return gulp
    .src(tsSource)
    .pipe(
      milkyLint({
        formatter: 'stylish',
        program: lintProgram,
        tslint: tslint,
        fix: !!argv.fix
      })
    )
    .pipe(
      milkyReport({
        emitError: false
      })
    );
});

tslint.json can be supplied as a parameter by setting the configuration property.

gulp.task('tslint-json', () =>
  gulp
    .src('input.ts')
    .pipe(
      milkyLint({
        configuration: {
          rules: {
            'class-name': true
            // ...
          }
        }
      })
    )
    .pipe(milkyReport.report())
);

You can also supply a file path to the configuration option, and the file name doesn't need to be tslint.json.

.pipe(milkyLint({
    // contains rules in the tslint.json format
    configuration: "source/settings.json"
}))

Report limits

You can optionally specify a report limit in the .report options that will turn off reporting for files after the limit has been reached. If the limit is 0 or less, the limit is ignored, which is the default setting.

gulp.task('tslint', () =>
  gulp
    .src(['input.ts'])
    .pipe(
      milkyLint({
        formatter: 'prose'
      })
    )
    .pipe(
      milkyReport.report({
        reportLimit: 2
      })
    )
);

Allowing Warnings

TSLint 5.0 introduced support for a "warning" severity for linting errors. By default, warnings cause milky-tslint to emit an error to maintain backwards-compatibility with previous versions. To let the build succeed in the presence of warnings, use the allowWarnings report option.

gulp.task('tslint', () =>
  gulp
    .src('input.ts')
    .pipe(
      milkyLint({
        formatter: 'prose'
      })
    )
    .pipe(
      milkyReport.report({
        allowWarnings: true
      })
    )
);

All default tslint options

const tslintOptions = {
  configuration: {},
  fix: false,
  formatter: 'stylish',
  formattersDirectory: null,
  rulesDirectory: null,
  tslint: null,
  program: null
};

All default report options

const reportOptions = {
  emitError: false,
  reportLimit: 0,
  summarizeFailureOutput: true,
  allowWarnings: false
};

API Documentation

Keywords

FAQs

Package last updated on 22 Jan 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc