2017-11-03 02:09:34 +02:00
|
|
|
const fs = require('fs-extra');
|
|
|
|
const { wrap } = require('lib/string-utils.js');
|
2017-12-14 20:12:14 +02:00
|
|
|
const Setting = require('lib/models/Setting.js');
|
2017-11-03 02:09:34 +02:00
|
|
|
const { fileExtension, basename, dirname } = require('lib/path-utils.js');
|
|
|
|
const { _, setLocale, languageCode } = require('lib/locale.js');
|
2017-08-04 19:11:10 +02:00
|
|
|
|
|
|
|
const rootDir = dirname(dirname(__dirname));
|
|
|
|
const MAX_WIDTH = 78;
|
|
|
|
const INDENT = ' ';
|
|
|
|
|
2017-10-20 00:02:13 +02:00
|
|
|
function renderTwoColumnData(options, baseIndent, width) {
|
2017-08-04 19:11:10 +02:00
|
|
|
let output = [];
|
|
|
|
const optionColWidth = getOptionColWidth(options);
|
|
|
|
|
|
|
|
for (let i = 0; i < options.length; i++) {
|
|
|
|
let option = options[i];
|
|
|
|
const flag = option[0];
|
|
|
|
const indent = baseIndent + INDENT + ' '.repeat(optionColWidth + 2);
|
|
|
|
|
2017-10-09 00:34:01 +02:00
|
|
|
let r = wrap(option[1], indent, width);
|
2017-08-04 19:11:10 +02:00
|
|
|
r = r.substr(flag.length + (baseIndent + INDENT).length);
|
|
|
|
r = baseIndent + INDENT + flag + r;
|
|
|
|
output.push(r);
|
|
|
|
}
|
|
|
|
|
|
|
|
return output.join("\n");
|
|
|
|
}
|
|
|
|
|
2017-10-09 00:34:01 +02:00
|
|
|
function renderCommandHelp(cmd, width = null) {
|
|
|
|
if (width === null) width = MAX_WIDTH;
|
|
|
|
|
2017-08-04 19:11:10 +02:00
|
|
|
const baseIndent = '';
|
|
|
|
|
|
|
|
let output = [];
|
|
|
|
output.push(baseIndent + cmd.usage());
|
|
|
|
output.push('');
|
2017-10-09 00:34:01 +02:00
|
|
|
output.push(wrap(cmd.description(), baseIndent + INDENT, width));
|
2017-08-04 19:11:10 +02:00
|
|
|
|
2017-10-20 00:02:13 +02:00
|
|
|
const optionString = renderTwoColumnData(cmd.options(), baseIndent, width);
|
2017-08-04 19:11:10 +02:00
|
|
|
|
|
|
|
if (optionString) {
|
|
|
|
output.push('');
|
|
|
|
output.push(optionString);
|
|
|
|
}
|
2017-10-20 00:02:13 +02:00
|
|
|
|
|
|
|
if (cmd.name() === 'config') {
|
|
|
|
const renderMetadata = (md) => {
|
|
|
|
let desc = [];
|
2017-10-24 22:22:57 +02:00
|
|
|
|
2017-10-20 00:02:13 +02:00
|
|
|
if (md.label) {
|
|
|
|
let label = md.label();
|
|
|
|
if (label.length && label[label.length - 1] !== '.') label += '.';
|
|
|
|
desc.push(label);
|
|
|
|
}
|
|
|
|
|
2017-10-24 22:22:57 +02:00
|
|
|
if (md.description) {
|
|
|
|
desc.push(md.description());
|
|
|
|
}
|
|
|
|
|
2017-10-20 00:02:13 +02:00
|
|
|
desc.push(_('Type: %s.', md.isEnum ? _('Enum') : Setting.typeToString(md.type)));
|
|
|
|
if (md.isEnum) desc.push(_('Possible values: %s.', Setting.enumOptionsDoc(md.key, '%s (%s)')));
|
|
|
|
|
|
|
|
let defaultString = null;
|
|
|
|
|
|
|
|
if ('value' in md) {
|
|
|
|
if (md.type === Setting.TYPE_STRING) {
|
|
|
|
defaultString = md.value ? '"' + md.value + '"' : null;
|
|
|
|
} else if (md.type === Setting.TYPE_INT) {
|
|
|
|
defaultString = (md.value ? md.value : 0).toString();
|
|
|
|
} else if (md.type === Setting.TYPE_BOOL) {
|
|
|
|
defaultString = (md.value === true ? 'true' : 'false');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (defaultString !== null) desc.push(_('Default: %s', defaultString));
|
|
|
|
|
2017-10-24 23:09:22 +02:00
|
|
|
return [md.key, desc.join("\n")];
|
2017-10-20 00:02:13 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
output.push('');
|
|
|
|
output.push(_('Possible keys/values:'));
|
|
|
|
output.push('');
|
|
|
|
|
|
|
|
let keysValues = [];
|
|
|
|
const keys = Setting.keys(true, 'cli');
|
|
|
|
for (let i = 0; i < keys.length; i++) {
|
2017-10-24 22:22:57 +02:00
|
|
|
if (keysValues.length) keysValues.push(['','']);
|
2017-10-20 00:02:13 +02:00
|
|
|
const md = Setting.settingMetadata(keys[i]);
|
|
|
|
if (!md.label) continue;
|
|
|
|
keysValues.push(renderMetadata(md));
|
|
|
|
}
|
|
|
|
|
|
|
|
output.push(renderTwoColumnData(keysValues, baseIndent, width));
|
|
|
|
}
|
|
|
|
|
2017-08-04 19:11:10 +02:00
|
|
|
return output.join("\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
function getOptionColWidth(options) {
|
|
|
|
let output = 0;
|
|
|
|
for (let j = 0; j < options.length; j++) {
|
|
|
|
const option = options[j];
|
|
|
|
if (option[0].length > output) output = option[0].length;
|
|
|
|
}
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
2017-11-03 02:13:17 +02:00
|
|
|
module.exports = { renderCommandHelp };
|