@oaklean/cli
Version:
A command-line interface that provides utilities for parsing, inspecting, and converting the .oak file format, as well as interfaces used in the @oaklean suite.
48 lines • 3.85 kB
JavaScript
;
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const fs_1 = __importDefault(require("fs"));
const profiler_core_1 = require("@oaklean/profiler-core");
const commander_1 = require("commander");
class ConfigCommands {
constructor() {
const parseCommand = commander_1.program
.command('config')
.description('commands to interact with a config file');
parseCommand
.command('resolve')
.description('Resolves the given config file and outputs the resolved config (including all default values and overrides)')
.argument('<input>', 'input file path')
.action(this.resolve.bind(this));
}
static init() {
return new ConfigCommands();
}
resolve(input) {
return __awaiter(this, void 0, void 0, function* () {
let inputPath = new profiler_core_1.UnifiedPath(input);
if (inputPath.isRelative()) {
inputPath = new profiler_core_1.UnifiedPath(process.cwd()).join(inputPath);
}
if (!fs_1.default.existsSync(inputPath.toPlatformString())) {
profiler_core_1.LoggerHelper.error(`The file ${inputPath.toPlatformString()} does not exist`);
return;
}
const config = yield profiler_core_1.ProfilerConfig.resolveFromFile(inputPath);
profiler_core_1.LoggerHelper.log(JSON.stringify(config, null, 2));
});
}
}
exports.default = ConfigCommands;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ29uZmlnQ29tbWFuZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tbWFuZHMvQ29uZmlnQ29tbWFuZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7QUFBQSw0Q0FBbUI7QUFFbkIsMERBSStCO0FBQy9CLHlDQUFtQztBQUVuQyxNQUFxQixjQUFjO0lBQ2xDO1FBQ0MsTUFBTSxZQUFZLEdBQUcsbUJBQU87YUFDMUIsT0FBTyxDQUFDLFFBQVEsQ0FBQzthQUNqQixXQUFXLENBQUMseUNBQXlDLENBQUMsQ0FBQTtRQUV4RCxZQUFZO2FBQ1YsT0FBTyxDQUFDLFNBQVMsQ0FBQzthQUNsQixXQUFXLENBQ1gsNkdBQTZHLENBQzdHO2FBQ0EsUUFBUSxDQUFDLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQzthQUN0QyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtJQUNsQyxDQUFDO0lBRUQsTUFBTSxDQUFDLElBQUk7UUFDVixPQUFPLElBQUksY0FBYyxFQUFFLENBQUE7SUFDNUIsQ0FBQztJQUVLLE9BQU8sQ0FBQyxLQUFhOztZQUMxQixJQUFJLFNBQVMsR0FBRyxJQUFJLDJCQUFXLENBQUMsS0FBSyxDQUFDLENBQUE7WUFDdEMsSUFBSSxTQUFTLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQztnQkFDNUIsU0FBUyxHQUFHLElBQUksMkJBQVcsQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUE7WUFDM0QsQ0FBQztZQUNELElBQUksQ0FBQyxZQUFFLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLEVBQUUsQ0FBQztnQkFDbEQsNEJBQVksQ0FBQyxLQUFLLENBQ2pCLFlBQVksU0FBUyxDQUFDLGdCQUFnQixFQUFFLGlCQUFpQixDQUN6RCxDQUFBO2dCQUNELE9BQU07WUFDUCxDQUFDO1lBRUQsTUFBTSxNQUFNLEdBQUcsTUFBTSw4QkFBYyxDQUFDLGVBQWUsQ0FBQyxTQUFTLENBQUMsQ0FBQTtZQUM5RCw0QkFBWSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQTtRQUNsRCxDQUFDO0tBQUE7Q0FDRDtBQWxDRCxpQ0FrQ0MifQ==