mirror of
https://github.com/status-im/metro.git
synced 2025-01-14 21:14:23 +00:00
[react-packager] Better transform errors
This commit is contained in:
parent
c435ce74b6
commit
68b02a843c
@ -35,7 +35,7 @@ describe('Transformer', function() {
|
||||
callback(null, 'content');
|
||||
});
|
||||
|
||||
return new Transformer(OPTIONS).loadFileAndTransform([], 'file', {})
|
||||
return new Transformer(OPTIONS).loadFileAndTransform('file')
|
||||
.then(function(data) {
|
||||
expect(data).toEqual({
|
||||
code: 'transformed',
|
||||
@ -58,7 +58,7 @@ describe('Transformer', function() {
|
||||
callback(null, {error: esprimaError});
|
||||
});
|
||||
|
||||
return new Transformer(OPTIONS).loadFileAndTransform([], 'foo-file.js', {})
|
||||
return new Transformer(OPTIONS).loadFileAndTransform('foo-file.js')
|
||||
.catch(function(error) {
|
||||
expect(error.type).toEqual('TransformError');
|
||||
expect(error.snippet).toEqual([
|
||||
|
34
react-packager/src/JSTransformer/index.js
vendored
34
react-packager/src/JSTransformer/index.js
vendored
@ -78,11 +78,7 @@ Transformer.prototype.invalidateFile = function(filePath) {
|
||||
this._cache.invalidate(filePath);
|
||||
};
|
||||
|
||||
Transformer.prototype.loadFileAndTransform = function(
|
||||
transformSets,
|
||||
filePath,
|
||||
options
|
||||
) {
|
||||
Transformer.prototype.loadFileAndTransform = function(filePath) {
|
||||
if (this._failedToStart) {
|
||||
return this._failedToStart;
|
||||
}
|
||||
@ -92,15 +88,14 @@ Transformer.prototype.loadFileAndTransform = function(
|
||||
return readFile(filePath)
|
||||
.then(function(buffer) {
|
||||
var sourceCode = buffer.toString();
|
||||
var opts = _.extend({}, options, {filename: filePath});
|
||||
|
||||
return q.nfbind(workers)({
|
||||
transformSets: transformSets,
|
||||
sourceCode: sourceCode,
|
||||
options: opts,
|
||||
filename: filePath,
|
||||
}).then(
|
||||
function(res) {
|
||||
if (res.error) {
|
||||
throw formatEsprimaError(res.error, filePath, sourceCode);
|
||||
throw formatError(res.error, filePath, sourceCode);
|
||||
}
|
||||
|
||||
return {
|
||||
@ -117,11 +112,26 @@ Transformer.prototype.loadFileAndTransform = function(
|
||||
function TransformError() {}
|
||||
util.inherits(TransformError, SyntaxError);
|
||||
|
||||
function formatEsprimaError(err, filename, source) {
|
||||
if (!(err.lineNumber && err.column)) {
|
||||
return err;
|
||||
function formatError(err, filename, source) {
|
||||
if (err.lineNumber && err.column) {
|
||||
return formatEsprimaError(err, filename, source);
|
||||
} else {
|
||||
return formatGenericError(err, filename, source);
|
||||
}
|
||||
}
|
||||
|
||||
function formatGenericError(err, filename) {
|
||||
var msg = 'TransformError: ' + filename + ': ' + err.message;
|
||||
var error = new TransformError();
|
||||
var stack = err.stack.split('\n').slice(0, -1);
|
||||
stack.push(msg);
|
||||
error.stack = stack.join('\n');
|
||||
error.message = msg;
|
||||
error.type = 'TransformError';
|
||||
return error;
|
||||
}
|
||||
|
||||
function formatEsprimaError(err, filename, source) {
|
||||
var stack = err.stack.split('\n');
|
||||
stack.shift();
|
||||
|
||||
|
@ -49,7 +49,7 @@ describe('Packager', function() {
|
||||
});
|
||||
|
||||
require('../../JSTransformer').prototype.loadFileAndTransform
|
||||
.mockImpl(function(tsets, path) {
|
||||
.mockImpl(function(path) {
|
||||
return q({
|
||||
code: 'transformed ' + path,
|
||||
sourceCode: 'source ' + path,
|
||||
|
4
react-packager/src/Packager/index.js
vendored
4
react-packager/src/Packager/index.js
vendored
@ -126,9 +126,7 @@ Packager.prototype.getDependencies = function(main) {
|
||||
Packager.prototype._transformModule = function(module) {
|
||||
var resolver = this._resolver;
|
||||
return this._transformer.loadFileAndTransform(
|
||||
['es6'],
|
||||
path.resolve(module.path),
|
||||
this._opts.transformer || {}
|
||||
path.resolve(module.path)
|
||||
).then(function(transformed) {
|
||||
return _.extend(
|
||||
{},
|
||||
|
@ -16,10 +16,11 @@ var staticTypeSyntax =
|
||||
var visitorList = reactVisitors;
|
||||
|
||||
|
||||
function transform(transformSets, srcTxt) {
|
||||
function transform(srcTxt, filename) {
|
||||
var options = {
|
||||
es3: true,
|
||||
sourceType: 'nonStrictModule'
|
||||
sourceType: 'nonStrictModule',
|
||||
filename: filename,
|
||||
};
|
||||
|
||||
// These tranforms mostly just erase type annotations and static typing
|
||||
@ -42,8 +43,8 @@ module.exports = function(data, callback) {
|
||||
var result;
|
||||
try {
|
||||
result = transform(
|
||||
data.transformSets,
|
||||
data.sourceCode
|
||||
data.sourceCode,
|
||||
data.filename
|
||||
);
|
||||
} catch (e) {
|
||||
return callback(null, {
|
||||
|
Loading…
x
Reference in New Issue
Block a user