diff options
| author | ruki <waruqi@gmail.com> | 2018-11-08 00:38:48 +0800 |
|---|---|---|
| committer | ruki <waruqi@gmail.com> | 2018-11-07 21:53:09 +0800 |
| commit | 26105034da4fcce7ac883c899d781f016559310d (patch) | |
| tree | c459a5dc4e3aa0972d9919033ece511ce76dd129 /node_modules/@webpack-contrib/config-loader/lib/index.js | |
| parent | 2c77f00f1a7ecb6c8192f9c16d3b2001b254a107 (diff) | |
| download | xmake-docs-26105034da4fcce7ac883c899d781f016559310d.tar.gz xmake-docs-26105034da4fcce7ac883c899d781f016559310d.zip | |
switch to vuepress
Diffstat (limited to 'node_modules/@webpack-contrib/config-loader/lib/index.js')
| -rw-r--r-- | node_modules/@webpack-contrib/config-loader/lib/index.js | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/node_modules/@webpack-contrib/config-loader/lib/index.js b/node_modules/@webpack-contrib/config-loader/lib/index.js new file mode 100644 index 00000000..cafce44c --- /dev/null +++ b/node_modules/@webpack-contrib/config-loader/lib/index.js @@ -0,0 +1,29 @@ +const merge = require('merge-options'); +const webpackLog = require('webpack-log'); +const validate = require('@webpack-contrib/schema-utils'); +const webpackSchema = require('webpack/schemas/WebpackOptions.json'); + +const { extend } = require('./extend'); +const load = require('./load'); +const resolve = require('./resolve'); + +module.exports = (options = {}) => { + webpackLog({ name: 'config', id: 'webpack-config-loader' }); + + const name = 'config-loader'; + const raw = load(options); + const schema = merge({}, options.schema, webpackSchema); + + return resolve(raw).then((result) => { + const { config, configPath } = result; + + return extend(config).then((finalConfig) => { + // finalConfig may be a single Object or it may be an Array[Object] + // for simplicity, concat into an array and treat both types the same. + for (const target of [].concat(finalConfig)) { + validate({ name, schema, target }); + } + return { config: finalConfig, configPath }; + }); + }); +}; |
