Skip to content

Commit

Permalink
Scripts: Document and simplify changing file entry and output of buil…
Browse files Browse the repository at this point in the history
…d scripts
  • Loading branch information
gziolo committed Jun 5, 2019
1 parent 941c6ec commit 682d919
Show file tree
Hide file tree
Showing 5 changed files with 65 additions and 5 deletions.
1 change: 1 addition & 0 deletions packages/scripts/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
- The `lint-pkg-json` command lints now `package.json` files in the entire project's directories by default ([15890](https://github.com/WordPress/gutenberg/pull/15890)).
- The `lint-style` command lints now CSS and SCSS files in the entire project's directories by default ([15890](https://github.com/WordPress/gutenberg/pull/15890)).
- The `lint-js`, `lint-pkg-json` and `lint-style` commands ignore now files located in `build` and `node_modules` folders by default ([15977](https://github.com/WordPress/gutenberg/pull/15977)).
- The `build` and `start` commands supports simplified syntax for multiple entry points: `wp-scripts build entry-one.js entry-two.js` ([15982](https://github.com/WordPress/gutenberg/pull/15982)).

## 3.2.0 (2019-05-21)

Expand Down
8 changes: 6 additions & 2 deletions packages/scripts/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -49,14 +49,16 @@ _Example:_
```json
{
"scripts": {
"build": "wp-scripts build"
"build": "wp-scripts build",
"build:custom": "wp-scripts build entry-one.js entry-two.js --output-path=custom"
}
}
```

This is how you execute the script with presented setup:

* `npm run build` - builds the code for production.
* `npm run build:custom` - builds the code for production with two entry points and a custom output folder. Paths for custom entry points are relative to the project root.

#### Advanced information

Expand Down Expand Up @@ -198,14 +200,16 @@ _Example:_
```json
{
"scripts": {
"start": "wp-scripts start"
"start": "wp-scripts start",
"start:custom": "wp-scripts start entry-one.js entry-two.js --output-path=custom"
}
}
```

This is how you execute the script with presented setup:

* `npm start` - starts the build for development.
* `npm run start:custom` - starts the build for development which contains two entry points and a custom output folder. Paths for custom entry points are relative to the project root.

#### Advanced information

Expand Down
5 changes: 4 additions & 1 deletion packages/scripts/utils/cli.js
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,9 @@ const getCliArg = ( arg ) => {

const hasCliArg = ( arg ) => getCliArg( arg ) !== undefined;

const hasFileInCliArgs = () => minimist( getCliArgs() )._.length > 0;
const getCliFileArgs = () => minimist( getCliArgs() )._;

const hasFileInCliArgs = () => getCliFileArgs().length > 0;

const handleSignal = ( signal ) => {
if ( signal === 'SIGKILL' ) {
Expand Down Expand Up @@ -83,6 +85,7 @@ const spawnScript = ( scriptName, args = [] ) => {
module.exports = {
getCliArg,
getCliArgs,
getCliFileArgs,
hasCliArg,
hasFileInCliArgs,
spawnScript,
Expand Down
54 changes: 52 additions & 2 deletions packages/scripts/utils/config.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
/**
* External dependencies
*/
const { basename } = require( 'path' );

/**
* Internal dependencies
*/
const { hasCliArg, getCliArgs } = require( './cli' );
const { getCliArgs, getCliFileArgs, hasCliArg, hasFileInCliArgs } = require( './cli' );
const { fromConfigRoot, hasProjectFile } = require( './file' );
const { hasPackageProp } = require( './package' );

Expand All @@ -22,12 +27,57 @@ const hasWebpackConfig = () => hasCliArg( '--config' ) ||
hasProjectFile( 'webpack.config.js' ) ||
hasProjectFile( 'webpack.config.babel.js' );

/**
* Converts CLI arguments to the format which webpack understands.
* It allows to optionally pass some additional webpack CLI arguments.
*
* @see https://webpack.js.org/api/cli/#usage-with-config-file
*
* @param {?Array} additionalArgs The list of additional CLI arguments.
*
* @return {Array} The list of CLI arguments to pass to webpack CLI.
*/
const getWebpackArgs = ( additionalArgs = [] ) => {
const webpackArgs = getCliArgs();
let webpackArgs = getCliArgs();

const hasWebpackOutputOption = hasCliArg( '-o' ) || hasCliArg( '--output' );
if ( hasFileInCliArgs() && ! hasWebpackOutputOption ) {
/**
* Converts a path to the entry format supported by webpack, e.g.:
* `./entry-one.js` -> `entry-one=./entry-one.js`
* `entry-two.js` -> `entry-two=./entry-two.js`
*
* @param {string} path The path provided.
*
* @return {string} The entry format supported by webpack.
*/
const pathToEntry = ( path ) => {
const entry = basename( path, '.js' );

if ( ! path.startsWith( './' ) ) {
path = './' + path;
}

return [ entry, path ].join( '=' );
};

// The following handles the support for multiple entry points in webpack, e.g.:
// `wp-scripts build one.js two.js` -> `webpack one=./one.js two=./two.js`
webpackArgs = webpackArgs.map( ( cliArg ) => {
if ( getCliFileArgs().includes( cliArg ) && ! cliArg.includes( '=' ) ) {
return pathToEntry( cliArg );
}

return cliArg;
} );
}

if ( ! hasWebpackConfig() ) {
webpackArgs.push( '--config', fromConfigRoot( 'webpack.config.js' ) );
}

webpackArgs.push( ...additionalArgs );

return webpackArgs;
};

Expand Down
2 changes: 2 additions & 0 deletions packages/scripts/utils/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
const {
getCliArg,
getCliArgs,
getCliFileArgs,
hasCliArg,
hasFileInCliArgs,
spawnScript,
Expand All @@ -29,6 +30,7 @@ module.exports = {
fromConfigRoot,
getCliArg,
getCliArgs,
getCliFileArgs,
getWebpackArgs,
hasBabelConfig,
hasCliArg,
Expand Down

0 comments on commit 682d919

Please sign in to comment.