12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.SourceLocation = exports.Position = undefined;
- var _classCallCheck2 = require("babel-runtime/helpers/classCallCheck");
- var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
- exports.getLineInfo = getLineInfo;
- var _whitespace = require("./whitespace");
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- // These are used when `options.locations` is on, for the
- // `startLoc` and `endLoc` properties.
- var Position = exports.Position = function Position(line, col) {
- (0, _classCallCheck3.default)(this, Position);
- this.line = line;
- this.column = col;
- };
- var SourceLocation = exports.SourceLocation = function SourceLocation(start, end) {
- (0, _classCallCheck3.default)(this, SourceLocation);
- this.start = start;
- this.end = end;
- };
- // The `getLineInfo` function is mostly useful when the
- // `locations` option is off (for performance reasons) and you
- // want to find the line/column position for a given character
- // offset. `input` should be the code string that the offset refers
- // into.
- function getLineInfo(input, offset) {
- for (var line = 1, cur = 0;;) {
- _whitespace.lineBreakG.lastIndex = cur;
- var match = _whitespace.lineBreakG.exec(input);
- if (match && match.index < offset) {
- ++line;
- cur = match.index + match[0].length;
- } else {
- return new Position(line, offset - cur);
- }
- }
- }
|