ts-gir
Version:
generate typescript from gir
190 lines (143 loc) • 17.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
require("core-js/modules/es.symbol.description");
require("core-js/modules/es.array.filter");
require("core-js/modules/es.array.iterator");
require("core-js/modules/es.object.get-own-property-descriptors");
require("core-js/modules/es.set");
require("core-js/modules/es.string.search");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
var _err = _interopRequireDefault(require("err"));
var _lodash = _interopRequireDefault(require("lodash"));
var _cosmiconfig = require("cosmiconfig");
var _util = _interopRequireDefault(require("util"));
var _fsExtra = _interopRequireDefault(require("fs-extra"));
var _glob = _interopRequireDefault(require("glob"));
var _path = _interopRequireDefault(require("path"));
var _pkgDir = _interopRequireDefault(require("pkg-dir"));
var _command = require("@oclif/command");
var _bluebird = require("bluebird");
var _runtime = require("babel-plugin-ts-optchain/lib/runtime");
var _Gir = _interopRequireDefault(require("./Gir"));
var _GirJSGenerator = _interopRequireDefault(require("./GirJSGenerator"));
var _GirTSGenerator = _interopRequireDefault(require("./GirTSGenerator"));
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
const glob = _util.default.promisify(_glob.default);
const rootPath = _pkgDir.default.sync(process.cwd()) || process.cwd();
class TSGir extends _command.Command {
constructor(...args) {
super(...args);
this.warnings = new Set();
}
getUserConfig() {
return (0, _asyncToGenerator2.default)(function* () {
const userConfig = (0, _runtime.oc)((yield (0, _cosmiconfig.cosmiconfig)('tsgir').search(rootPath)), ["config"], {});
return _objectSpread({
importMap: {},
ignoreDuplicates: false
}, userConfig);
})();
}
runForFile(girFile) {
var _this = this;
return (0, _asyncToGenerator2.default)(function* () {
const _this$parse = _this.parse(TSGir),
flags = _this$parse.flags;
const gir = new _Gir.default();
yield gir.loadFile(girFile);
if (!gir.repository) throw new _err.default('xml not loaded');
let $namespaces = gir.repository.namespace;
if (!Array.isArray($namespaces)) $namespaces = [$namespaces];
yield (0, _bluebird.mapSeries)($namespaces,
/*#__PURE__*/
function () {
var _ref = (0, _asyncToGenerator2.default)(function* ($namespace) {
const namespaceName = $namespace['@_name'];
const userConfig = yield _this.getUserConfig();
const moduleName = flags.module || userConfig.moduleName; // console.log(`Process namespace "${namespaceName}"`);
const basename = flags.output || userConfig.output || _lodash.default.kebabCase(namespaceName);
const dir = flags.dir || userConfig.dir || '';
const path = _path.default.resolve(process.cwd(), dir, basename);
const girTSGenerator = new _GirTSGenerator.default($namespace, userConfig, {
info: _this.log,
warn: _this.handleWarn.bind(_this)
}, moduleName);
girTSGenerator.build();
const girJSGenerator = new _GirJSGenerator.default($namespace, girTSGenerator.renamed);
girJSGenerator.build();
const tsCode = girTSGenerator.generate();
const jsCode = girJSGenerator.generate();
yield _fsExtra.default.writeFile(`${path}.d.ts`, tsCode);
yield _fsExtra.default.writeFile(`${path}.js`, jsCode);
});
return function (_x) {
return _ref.apply(this, arguments);
};
}());
})();
}
run() {
var _this2 = this;
return (0, _asyncToGenerator2.default)(function* () {
const _this2$parse = _this2.parse(TSGir),
flags = _this2$parse.flags;
let inputFiles = [];
if (Array.isArray(flags.inputs)) {
inputFiles = flags.inputs;
} else {
inputFiles = yield glob(flags.inputs);
}
for (let i = 0; i < inputFiles.length; i++) {
if (inputFiles[i]) {
yield _this2.runForFile(inputFiles[i]);
}
}
})();
}
handleWarn(input) {
if (typeof input === 'string') {
if (this.warnings.has(input)) return;
this.warnings.add(input);
}
this.warn(input);
}
}
exports.default = TSGir;
TSGir.description = 'generate typescript from gir';
TSGir.flags = {
help: _command.flags.help({
char: 'h'
}),
module: _command.flags.string({
char: 'm'
}),
output: _command.flags.string({
char: 'o',
description: 'Output basename, if not set, the namespace is used'
}),
dir: _command.flags.string({
char: 'd',
description: 'Output dir'
}),
silent: _command.flags.boolean({
char: 's'
}),
verbose: _command.flags.boolean(),
version: _command.flags.version({
char: 'v'
}),
inputs: _command.flags.string({
char: 'i',
multiple: true,
required: true,
default: '/usr/share/gir-1.0/*.gir',
description: 'Paths to GIR files to generate type definitions from (with wild card support)'
})
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/TSGir.ts"],"names":["glob","util","promisify","globCb","rootPath","pkgDir","sync","process","cwd","TSGir","Command","warnings","Set","getUserConfig","userConfig","oc","search","importMap","ignoreDuplicates","runForFile","girFile","parse","flags","gir","Gir","loadFile","repository","Err","$namespaces","namespace","Array","isArray","$namespace","namespaceName","moduleName","module","basename","output","_","kebabCase","dir","path","Path","resolve","girTSGenerator","GirTSGenerator","info","log","warn","handleWarn","bind","build","girJSGenerator","GirJSGenerator","renamed","tsCode","generate","jsCode","fs","writeFile","run","inputFiles","inputs","i","length","input","has","add","description","help","char","string","silent","boolean","verbose","version","multiple","required","default"],"mappings":"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","sourcesContent":["import Err from 'err';\nimport _ from 'lodash';\nimport { cosmiconfig } from 'cosmiconfig';\nimport util from 'util';\nimport fs from 'fs-extra';\nimport globCb from 'glob';\nimport Path from 'path';\nimport pkgDir from 'pkg-dir';\nimport { Command, flags } from '@oclif/command';\nimport { mapSeries } from 'bluebird';\n// Needs babel\nimport { oc } from 'ts-optchain.macro';\nimport Gir from './Gir';\nimport GirJSGenerator from './GirJSGenerator';\nimport GirTSGenerator from './GirTSGenerator';\nimport { Namespace, UserConfig } from './types';\n\nconst glob = util.promisify(globCb);\n\nconst rootPath = pkgDir.sync(process.cwd()) || process.cwd();\n\nexport default class TSGir extends Command {\n  static description = 'generate typescript from gir';\n\n  static flags = {\n    help: flags.help({ char: 'h' }),\n    module: flags.string({ char: 'm' }),\n    output: flags.string({\n      char: 'o',\n      description: 'Output basename, if not set, the namespace is used'\n    }),\n    dir: flags.string({ char: 'd', description: 'Output dir' }),\n    silent: flags.boolean({ char: 's' }),\n    verbose: flags.boolean(),\n    version: flags.version({ char: 'v' }),\n    inputs: flags.string({\n      char: 'i',\n      multiple: true,\n      required: true,\n      default: '/usr/share/gir-1.0/*.gir',\n      description:\n        'Paths to GIR files to generate type definitions from (with wild card support)'\n    })\n  };\n\n  warnings: Set<string> = new Set();\n\n  async getUserConfig(): Promise<UserConfig> {\n    const userConfig: Partial<UserConfig> = oc(\n      await cosmiconfig('tsgir').search(rootPath)\n    ).config({});\n    return {\n      importMap: {},\n      ignoreDuplicates: false,\n      ...userConfig\n    };\n  }\n\n  async runForFile(girFile: string) {\n    const { flags } = this.parse(TSGir);\n    const gir = new Gir();\n    await gir.loadFile(girFile);\n    if (!gir.repository) throw new Err('xml not loaded');\n    let $namespaces = gir.repository.namespace;\n    if (!Array.isArray($namespaces)) $namespaces = [$namespaces];\n    await mapSeries($namespaces, async ($namespace: Namespace) => {\n      const namespaceName = $namespace['@_name'];\n      const userConfig = await this.getUserConfig();\n      const moduleName = flags.module || userConfig.moduleName;\n      // console.log(`Process namespace \"${namespaceName}\"`);\n      const basename =\n        flags.output || userConfig.output || _.kebabCase(namespaceName);\n      const dir = flags.dir || userConfig.dir || '';\n      const path = Path.resolve(process.cwd(), dir, basename);\n      const girTSGenerator = new GirTSGenerator(\n        $namespace,\n        userConfig,\n        {\n          info: this.log,\n          warn: this.handleWarn.bind(this)\n        },\n        moduleName\n      );\n      girTSGenerator.build();\n\n      const girJSGenerator = new GirJSGenerator(\n        $namespace,\n        girTSGenerator.renamed\n      );\n      girJSGenerator.build();\n      const tsCode = girTSGenerator.generate();\n      const jsCode = girJSGenerator.generate();\n      await fs.writeFile(`${path}.d.ts`, tsCode);\n      await fs.writeFile(`${path}.js`, jsCode);\n    });\n  }\n\n  async run() {\n    const { flags } = this.parse(TSGir);\n    let inputFiles = [];\n    if (Array.isArray(flags.inputs)) {\n      inputFiles = flags.inputs;\n    } else {\n      inputFiles = await glob(flags.inputs);\n    }\n    for (let i = 0; i < inputFiles.length; i++) {\n      if (inputFiles[i]) {\n        await this.runForFile(inputFiles[i]);\n      }\n    }\n  }\n\n  handleWarn(input: string | Error): void {\n    if (typeof input === 'string') {\n      if (this.warnings.has(input)) return;\n      this.warnings.add(input);\n    }\n    this.warn(input);\n  }\n}\n"]}