Files
JiboSDK/node_modules/tsify-preprocess/index.js

82 lines
2.0 KiB
JavaScript
Raw Normal View History

2026-03-22 03:21:45 +02:00
'use strict';
var realpath = require('fs.realpath');
var log = require('util').debuglog(require('./package').name);
var through = require('through2');
var path = require('path');
function tsify(b, opts) {
if (typeof b === 'string') {
throw new Error('tsify appears to have been configured as a transform; it must be configured as a plugin.');
}
var ts = opts.typescript || require('typescript');
if (typeof ts === 'string' || ts instanceof String) {
ts = require(ts);
}
var Tsifier = require('./lib/Tsifier')(ts);
var tsifier = new Tsifier(opts, b._options);
tsifier.on('error', function (error) {
b.pipeline.emit('error', error);
});
tsifier.on('file', function (file, id) {
b.emit('file', file, id);
});
setupPipeline();
var transformOpts = {
global: opts.global
};
b.transform(tsifier.transform.bind(tsifier), transformOpts);
b.on('reset', function () {
setupPipeline();
});
function setupPipeline() {
if (tsifier.opts.jsx && b._extensions.indexOf('.tsx') === -1)
b._extensions.unshift('.tsx');
if (b._extensions.indexOf('.ts') === -1)
b._extensions.unshift('.ts');
b.pipeline.get('record').push(gatherEntryPoints());
}
function gatherEntryPoints() {
var rows = [];
return through.obj(transform, flush);
function transform(row, enc, next) {
rows.push(row);
next();
}
function flush(next) {
var self = this;
var entries = rows
.map(function (row) {
if (row.basedir && (row.file || row.id)) {
return path.resolve(row.basedir, row.file || row.id);
} else {
return row.file || row.id;
}
})
.filter(function (file) { return file; })
.map(function (file) { return realpath.realpathSync(file); });
log('Files from browserify entry points:');
entries.forEach(function (file) { log(' %s', file); });
tsifier.reset();
tsifier.generateCache(entries);
rows.forEach(function (row) { self.push(row); });
self.push(null);
next();
}
}
}
module.exports = tsify;