2016-01-27 10:29:26 +00:00
|
|
|
(function() {
|
2018-02-12 05:05:29 +00:00
|
|
|
/**
|
|
|
|
Definition of the SyntaxErrorEx class.
|
|
|
|
@module utils/syntax-error-ex
|
|
|
|
@license MIT. See LICENSE.md for details.
|
|
|
|
*/
|
2016-01-27 10:29:26 +00:00
|
|
|
var SyntaxErrorEx;
|
|
|
|
|
2018-02-12 05:05:29 +00:00
|
|
|
/**
|
|
|
|
Represents a SyntaxError exception with line and column info.
|
|
|
|
Collect syntax error information from the provided exception object. The
|
|
|
|
JavaScript `SyntaxError` exception isn't interpreted uniformly across environ-
|
|
|
|
ments, so we reparse on error to grab the line and column.
|
|
|
|
See: http://stackoverflow.com/q/13323356
|
|
|
|
@class SyntaxErrorEx
|
|
|
|
*/
|
|
|
|
SyntaxErrorEx = class SyntaxErrorEx {
|
|
|
|
constructor(ex, rawData) {
|
|
|
|
var JSONLint, colNum, err, lineNum, lint;
|
2016-02-12 22:11:11 +00:00
|
|
|
lineNum = null;
|
|
|
|
colNum = null;
|
|
|
|
JSONLint = require('json-lint');
|
|
|
|
lint = JSONLint(rawData, {
|
|
|
|
comments: false
|
|
|
|
});
|
|
|
|
if (lint.error) {
|
2018-02-12 05:05:29 +00:00
|
|
|
[this.line, this.col] = [lint.line, lint.character];
|
2016-02-12 22:11:11 +00:00
|
|
|
}
|
|
|
|
if (!lint.error) {
|
|
|
|
JSONLint = require('jsonlint');
|
|
|
|
try {
|
|
|
|
JSONLint.parse(rawData);
|
2018-02-12 05:05:29 +00:00
|
|
|
} catch (error) {
|
|
|
|
err = error;
|
|
|
|
this.line = (/on line (\d+)/.exec(err))[1];
|
2016-02-12 22:11:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-02-12 05:05:29 +00:00
|
|
|
};
|
2016-01-27 10:29:26 +00:00
|
|
|
|
2018-02-12 05:05:29 +00:00
|
|
|
// Return true if the supplied parameter is a JavaScript SyntaxError
|
2016-01-27 10:29:26 +00:00
|
|
|
SyntaxErrorEx.is = function(ex) {
|
|
|
|
return ex instanceof SyntaxError;
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = SyntaxErrorEx;
|
|
|
|
|
|
|
|
}).call(this);
|
2016-02-02 02:14:36 +00:00
|
|
|
|
|
|
|
//# sourceMappingURL=syntax-error-ex.js.map
|