UNPKG

ts-gir

Version:
190 lines (143 loc) 17.3 kB
"use strict"; 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"]}