2015-01-29 17:10:49 -08:00
|
|
|
/**
|
2015-03-23 15:07:33 -07:00
|
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* This source code is licensed under the BSD-style license found in the
|
|
|
|
* LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
* of patent rights can be found in the PATENTS file in the same directory.
|
2015-01-29 17:10:49 -08:00
|
|
|
*
|
|
|
|
* Wrapper on-top of `optimist` in order to properly support boolean flags
|
|
|
|
* and have a slightly less akward API.
|
|
|
|
*
|
|
|
|
* Usage example:
|
|
|
|
* var argv = parseCommandLine([{
|
|
|
|
* command: 'web',
|
|
|
|
* description: 'Run in a web browser instead of iOS',
|
|
|
|
* default: true
|
|
|
|
* }])
|
|
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
|
2016-04-08 12:08:15 -07:00
|
|
|
var optimistModule = require('optimist');
|
2015-01-29 17:10:49 -08:00
|
|
|
|
2015-09-22 09:00:04 -07:00
|
|
|
function parseCommandLine(config, args) {
|
2016-04-08 12:08:15 -07:00
|
|
|
var optimist = new optimistModule();
|
2015-09-22 09:00:04 -07:00
|
|
|
args = args || process.argv;
|
2015-01-29 17:10:49 -08:00
|
|
|
// optimist default API requires you to write the command name three time
|
|
|
|
// This is a small wrapper to accept an object instead
|
|
|
|
for (var i = 0; i < config.length; ++i) {
|
2015-05-20 10:29:56 -07:00
|
|
|
if (config[i].type === 'string') {
|
|
|
|
optimist.string(config[i].command);
|
|
|
|
} else {
|
|
|
|
optimist.boolean(config[i].command);
|
|
|
|
}
|
|
|
|
|
2015-01-29 17:10:49 -08:00
|
|
|
optimist
|
|
|
|
.default(config[i].command, config[i].default)
|
|
|
|
.describe(config[i].command, config[i].description);
|
2015-05-20 10:29:56 -07:00
|
|
|
|
|
|
|
if (config[i].required) {
|
|
|
|
optimist.demand(config[i].command);
|
|
|
|
}
|
2015-01-29 17:10:49 -08:00
|
|
|
}
|
2015-09-22 09:00:04 -07:00
|
|
|
var argv = optimist.parse(args);
|
2015-01-29 17:10:49 -08:00
|
|
|
|
|
|
|
// optimist doesn't have support for --dev=false, instead it returns 'false'
|
|
|
|
for (var i = 0; i < config.length; ++i) {
|
|
|
|
var command = config[i].command;
|
|
|
|
if (argv[command] === undefined) {
|
|
|
|
argv[command] = config[i].default;
|
|
|
|
}
|
|
|
|
if (argv[command] === 'true') {
|
|
|
|
argv[command] = true;
|
|
|
|
}
|
|
|
|
if (argv[command] === 'false') {
|
|
|
|
argv[command] = false;
|
|
|
|
}
|
2015-05-20 18:38:55 -07:00
|
|
|
if (config[i].type === 'string') {
|
|
|
|
// According to https://github.com/substack/node-optimist#numbers,
|
|
|
|
// every argument that looks like a number should be converted to one.
|
|
|
|
var strValue = argv[command];
|
|
|
|
var numValue = strValue ? Number(strValue) : undefined;
|
|
|
|
if (typeof numValue === 'number' && !isNaN(numValue)) {
|
|
|
|
argv[command] = numValue;
|
|
|
|
}
|
|
|
|
}
|
2015-01-29 17:10:49 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Show --help
|
|
|
|
if (argv.help || argv.h) {
|
|
|
|
optimist.showHelp();
|
|
|
|
process.exit();
|
|
|
|
}
|
|
|
|
|
|
|
|
return argv;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = parseCommandLine;
|