A Webpack plugin to dynamically generate an entry file on compiler initialisation
Sometimes you will want to generate an entry file dynamically. This file may consist of your bower dependencies or it may be a test suite that consists of all your unit test specification files.
This plugin will generate such a file if it is not already present. You may depende your compiler upon the output of this plugin.
The plugin is of the following form.
new EntryGeneratorWebpackPlugin(outputFile, sources)
where:
outputFile
is the javascript file that will be generatedsources
is afunction|Array.<function>
of methods that return a list of files or promise to such
The following configuration generates a vendor.js
files that consists of your bower dependencies
.
var EntryGeneratorWebpackPlugin = require('entry-generator-webpack-plugin')
module.exports = {
entry; {
vendor: 'vendor.js'
...
},
...
plugins: [
new EntryGeneratorWebpackPlugin('vendor.js', [
EntryGeneratorWebpackPlugin.bowerDependenciesSource(),
...
]),
...
]
}
The sources are one or more function([outputPath:string]):Array.<string>|Promise
. It returns a list of files relative to the given output path or a list of module names or a promise that resolves to such.
There are a number of source factories exported on EntryGeneratorWebpackPlugin
, these include:
-
EntryGeneratorWebpackPlugin.bowerDependenciesSource([options])
A source factory that will list bower modules from the
dependencies
field of thebower.json
file in the Webpackcontext
directory. Theoptions
may include any of the standard Webpack file filters (although applied to the module names), meaningtest
,include
,exclude
. -
EntryGeneratorWebpackPlugin.bowerDevDependenciesSource([options])
As above, for the
devDependencies
field. -
EntryGeneratorWebpackPlugin.globSource(pattern, [options])
A source factory that can glob files rooted in the Webpack
context
directory. It supportsoptions
per glob properties. Theoptions
may also include any of the standard Webpack file filters (although applied to the module names), meaningtest
,include
,exclude
. Note however that it is more efficient to use the globignore
property than the Webpackexclude
regular expression.