/format-webpack-stats-errors-warnings

A normalized format for webpack's errors and warnings

Primary LanguageJavaScriptMIT LicenseMIT

About this

A normalized format for webpack's errors and warnings.

Webpack's error output is very verbose. However, I found it is diffcult to match it when I was using vscode. So I create this package to reformat the webpack's errors and warnings.

Install

npm install --save-dev format-webpack-stats-errors-warnings

How to use:

It is really simple, just use it in your webpack's callback function. Here is an example:

webpack(webpackConfig, function (err, stats) {
    if (err) {
        console.error(err)
        throw err
    }
    
    // add this package here:
    console.log(require('format-webpack-stats-errors-warnings')(stats, config.PROJECT_ROOT))

    // You can still output the verbose default webpack's output
    process.stdout.write(stats.toString({
            colors: !!+process.env.DISABLE_OUTPUT_COLOR,
            modules: false,
            children: false,
            chunks: false,
            chunkModules: false
        }) + '\n')
})

parameters:

  • stats: The second parameter of webpack callback function.
  • projectRoot: The root path of your project. It is used to make output path be relative. If omitted, the output path will be absolute.

return:

  • A formatted string. You must output it yourself.

Difference with webpack's default output

Webpack's:

Module not found: Error: Can't resolve 'something-not-exists' in 'xxxx\src'
 @ xxxxr/~/.6.4.0@babel-loader/lib!./~/.11.1.4@vue-loader/lib/selector.js?type=script&index=0!./src/App.vue 11:0-30
 @ ./src/App.vue
 @ ./src/main.js

This package's:

!>error: src\App.vue:32,13~33: Module not found: Error: Can't resolve 'something-not-exists' in 'xxxx\src'

Note: this package combined all errors into one line, and add line number and column number.

problemMatcher for vscode:

You can use the following as problemMatcher in your tasks.json of vscode

{
    "owner": "webpack",
    "fileLocation": [
        "relative",
        "${workspaceRoot}"
    ],
    "pattern": {
        "regexp": "^!>(\\w+): (\\S+)?:(\\d+),(\\d+)(?:~(?:(\\d+),)?(\\d+))?: (.*)$",
        "severity": 1,
        "file": 2,
        "line": 3,
        "column": 4,
        "endLine": 5,
        "endColumn": 6,
        "message": 7
    }
}