Skip to content

Latest commit

 

History

History
83 lines (65 loc) · 1.98 KB

README.md

File metadata and controls

83 lines (65 loc) · 1.98 KB

gulp-solium

gulp plugin for solium. I refered to gulp-eslint.

Installation

npm install gulp-solium --save-dev

Usage

const gulp = require("gulp");
const solium = require("gulp-solium");

gulp.task("solium", () => {
    // gulp-solium don't honor .soliumignore file.
    // Instead of .soliumignore, please use !path.
    return gulp.src(["contracts/**/*.sol","!node_modules/**"])
        // if you don't pass settings, gulp-solium use .soliumrc.json or default settings.
        .pipe(solium())
        .pipe(solium.failAfterError());
});

gulp.task("default", ["solium"], () => {
    // This will only run if the lint task is successful...
});

API

solium()

A .soliumrc.json file may be resolved relative to each linted file. If there isn't .soliumrc.json file, gulp-solium use following settings:

{
    "extends": "solium:recommended",
    "options": { "returnInternalIssues": true }
}

solium(options)

Set object of rules.

{
  "extends": "solium:recommended",
  "rules": {
    "quotes": ["error", "double"],
    "indentation": ["error", 4]
  }
}

solium.results(action)

Call a function once for all Solium file results before a stream finishes. No returned value is expected.

gulp.src(["contracts/**/*.sol","!node_modules/**"])
	.pipe(solium())
	.pipe(solium.results((results) => {
    	// Called once for all ESLint results.
	    console.log(`Total Results: ${results.length}`);
	    console.log(`Total Warnings: ${results.warningCount}`);
	    console.log(`Total Errors: ${results.errorCount}`);
	}));

solium.failAfterError()

Stop a task/stream if an Solium error has been reported for any file, but wait for all of them to be processed first.

gulp.src(["contracts/**/*.sol","!node_modules/**"])
	.pipe(eslint())
	.pipe(eslint.failAfterError());

Lisence

MIT