Browse Source

Make run method in bin/neutrino self contained.

v6-dev
Jarid Margolin 8 years ago
parent
commit
60880d8b57
  1. 22
      packages/neutrino/bin/neutrino
  2. 1
      packages/neutrino/package.json

22
packages/neutrino/bin/neutrino

@ -10,17 +10,9 @@ const { pathOr, pipe, partialRight } = require('ramda');
const { join } = require('path'); const { join } = require('path');
const stringify = require('javascript-stringify'); const stringify = require('javascript-stringify');
const sort = require('deep-sort-object'); const sort = require('deep-sort-object');
const optional = require('optional');
const inspect = pipe(sort, partialRight(stringify, [null, 2]), console.log, process.exit); const inspect = pipe(sort, partialRight(stringify, [null, 2]), console.log, process.exit);
const cwd = process.cwd();
let pkg = {};
try {
pkg = require(join(cwd, 'package.json'));
} catch (ex) {}
const pkgPresets = pathOr([], ['neutrino', 'presets'], pkg);
const environments = { build: 'production', start: 'development', test: 'test' };
const args = yargs const args = yargs
.option('inspect', { .option('inspect', {
description: 'Output a string representation of the configuration used by Neutrino and exit', description: 'Output a string representation of the configuration used by Neutrino and exit',
@ -55,13 +47,17 @@ const args = yargs
.help() .help()
.argv; .argv;
function run(command, presets) { function run(command, args) {
process.env.NODE_ENV = environments[command]; const environments = { build: 'production', start: 'development', test: 'test' };
const pkg = optional(join(process.cwd(), 'package.json')) || {};
const pkgPresets = pathOr([], ['neutrino', 'presets'], pkg);
const presets = [...new Set(pkgPresets.concat(args.presets))];
const options = pathOr({}, ['neutrino', 'options'], pkg); const options = pathOr({}, ['neutrino', 'options'], pkg);
const config = pathOr({}, ['neutrino', 'config'], pkg); const config = pathOr({}, ['neutrino', 'config'], pkg);
const api = new Neutrino(Object.assign(options, { config })); const api = new Neutrino(Object.assign(options, { config }));
process.env.NODE_ENV = environments[command];
// Grab all presets and merge them into a single webpack-chain config instance // Grab all presets and merge them into a single webpack-chain config instance
api.import(presets); api.import(presets);
@ -83,4 +79,4 @@ function run(command, presets) {
}); });
} }
run(args._[0], [...new Set(pkgPresets.concat(args.presets))]); run(args._[0], args);

1
packages/neutrino/package.json

@ -25,6 +25,7 @@
"deep-sort-object": "^1.0.1", "deep-sort-object": "^1.0.1",
"deepmerge": "^1.3.2", "deepmerge": "^1.3.2",
"javascript-stringify": "^1.6.0", "javascript-stringify": "^1.6.0",
"optional": "^0.1.3",
"ora": "^1.1.0", "ora": "^1.1.0",
"ramda": "^0.23.0", "ramda": "^0.23.0",
"webpack": "^2.2.1", "webpack": "^2.2.1",

Loading…
Cancel
Save