Skip to content
This repository has been archived by the owner on Sep 28, 2020. It is now read-only.

fix: try load official formatter #285

Merged
merged 4 commits into from
Jul 4, 2019
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 6 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -107,11 +107,11 @@ This can either be a `boolean` value or the cache directory path(ex: `'./.eslint
If `cache: true` is used, the cache file is written to the `./node_modules/.cache` directory.
This is the recommended usage.

#### `formatter` (default: eslint stylish formatter)
#### `formatter` (default: "stylish")

Loader accepts a function that will have one argument: an array of eslint messages (object).
The function must return the output as a string.
You can use official eslint formatters.
You can use official [eslint formatters](https://eslint.org/docs/user-guide/formatters/).

```js
module.exports = {
Expand All @@ -126,7 +126,7 @@ module.exports = {
// several examples !

// default value
formatter: require("eslint/lib/formatters/stylish"),
formatter: "stylish",

// community formatter
formatter: require("eslint-friendly-formatter"),
Expand Down Expand Up @@ -287,7 +287,7 @@ module.exports = {
options: {
outputReport: {
filePath: "checkstyle.xml",
formatter: require("eslint/lib/formatters/checkstyle")
formatter: "checkstyle"
}
}
}
Expand Down Expand Up @@ -316,7 +316,9 @@ See [#129](https://github.com/webpack-contrib/eslint-loader/issues/129).
---

## Changelog

[Changelog](CHANGELOG.md)

## License

[MIT](./LICENSE)
44 changes: 25 additions & 19 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -195,21 +195,6 @@ module.exports = function(input, map) {
userOptions
);

if (typeof config.formatter === "string") {
try {
config.formatter = require(config.formatter);
if (
config.formatter &&
typeof config.formatter !== "function" &&
typeof config.formatter.default === "function"
) {
config.formatter = config.formatter.default;
}
} catch (_) {
// ignored
}
}

var cacheDirectory = config.cache;
var cacheIdentifier = config.cacheIdentifier;

Expand All @@ -221,15 +206,36 @@ module.exports = function(input, map) {
if (!engines[configHash]) {
var eslint = require(config.eslintPath);
engines[configHash] = new eslint.CLIEngine(config);
}

var engine = engines[configHash];
if (config.formatter == null || typeof config.formatter !== "function") {
config.formatter = engine.getFormatter("stylish");
// Try to get oficial formatter
if (typeof config.formatter === "string") {
try {
config.formatter = engines[configHash].getFormatter(config.formatter);
} catch (_) {
try {
config.formatter = require(config.formatter);
if (
config.formatter &&
typeof config.formatter !== "function" &&
typeof config.formatter.default === "function"
) {
config.formatter = config.formatter.default;
}
} catch (_) {
// ignored
}
}
}
ricardogobbosouza marked this conversation as resolved.
Show resolved Hide resolved

// Get default formatter `stylish` when not defined
if (config.formatter == null || typeof config.formatter !== "function") {
config.formatter = engines[configHash].getFormatter("stylish");
}
}

webpack.cacheable();

var engine = engines[configHash];
var resourcePath = webpack.resourcePath;
var cwd = process.cwd();

Expand Down
37 changes: 37 additions & 0 deletions test/formatter-oficial.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
/* eslint-disable no-console */
ricardogobbosouza marked this conversation as resolved.
Show resolved Hide resolved
var test = require("ava");
var webpack = require("webpack");

var conf = require("./utils/conf");

test.cb("eslint-loader can use oficial formatter", function(t) {
t.plan(1);
webpack(
conf(
{
entry: "./test/fixtures/error.js"
},
{
formatter: "table"
}
),
function(err, stats) {
if (err) {
throw err;
}

// console.log("### Here is a example of oficial formatter")
// console.log(
// "# " +
// stats.compilation.errors[0].message
// .split("\n")
// .join("\n# ")
// )
ricardogobbosouza marked this conversation as resolved.
Show resolved Hide resolved
t.truthy(
stats.compilation.errors[0].message,
"webpack have some output with oficial formatter"
ricardogobbosouza marked this conversation as resolved.
Show resolved Hide resolved
);
t.end();
}
);
});