UNPKG

tap

Version:

A Test-Anything-Protocol library for JavaScript

183 lines (148 loc) 5.18 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _Node2 = _interopRequireDefault(require("./Node")); var _Range = _interopRequireDefault(require("./Range")); var PlainValue = /*#__PURE__*/ function (_Node) { (0, _inherits2.default)(PlainValue, _Node); function PlainValue() { (0, _classCallCheck2.default)(this, PlainValue); return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(PlainValue).apply(this, arguments)); } (0, _createClass2.default)(PlainValue, [{ key: "parseBlockValue", value: function parseBlockValue(start) { var _this$context = this.context, indent = _this$context.indent, inFlow = _this$context.inFlow, src = _this$context.src; var offset = start; var valueEnd = start; for (var ch = src[offset]; ch === '\n'; ch = src[offset]) { if (_Node2.default.atDocumentBoundary(src, offset + 1)) break; var end = _Node2.default.endOfBlockIndent(src, indent, offset + 1); if (end === null || src[end] === '#') break; if (src[end] === '\n') { offset = end; } else { valueEnd = PlainValue.endOfLine(src, end, inFlow); offset = valueEnd; } } if (this.valueRange.isEmpty()) this.valueRange.start = start; this.valueRange.end = valueEnd; return valueEnd; } /** * Parses a plain value from the source * * Accepted forms are: * ``` * #comment * * first line * * first line #comment * * first line * block * lines * * #comment * block * lines * ``` * where block lines are empty or have an indent level greater than `indent`. * * @param {ParseContext} context * @param {number} start - Index of first character * @returns {number} - Index of the character after this scalar, may be `\n` */ }, { key: "parse", value: function parse(context, start) { this.context = context; var inFlow = context.inFlow, src = context.src; var offset = start; var ch = src[offset]; if (ch && ch !== '#' && ch !== '\n') { offset = PlainValue.endOfLine(src, start, inFlow); } this.valueRange = new _Range.default(start, offset); offset = _Node2.default.endOfWhiteSpace(src, offset); offset = this.parseComment(offset); if (!this.hasComment || this.valueRange.isEmpty()) { offset = this.parseBlockValue(offset); } return offset; } }, { key: "strValue", get: function get() { if (!this.valueRange || !this.context) return null; var _this$valueRange = this.valueRange, start = _this$valueRange.start, end = _this$valueRange.end; var src = this.context.src; var ch = src[end - 1]; while (start < end && (ch === '\n' || ch === '\t' || ch === ' ')) { ch = src[--end - 1]; } ch = src[start]; while (start < end && (ch === '\n' || ch === '\t' || ch === ' ')) { ch = src[++start]; } var str = ''; for (var i = start; i < end; ++i) { var _ch = src[i]; if (_ch === '\n') { var _Node$foldNewline = _Node2.default.foldNewline(src, i, -1), fold = _Node$foldNewline.fold, offset = _Node$foldNewline.offset; str += fold; i = offset; } else if (_ch === ' ' || _ch === '\t') { // trim trailing whitespace var wsStart = i; var next = src[i + 1]; while (i < end && (next === ' ' || next === '\t')) { i += 1; next = src[i + 1]; } if (next !== '\n') str += i > wsStart ? src.slice(wsStart, i + 1) : _ch; } else { str += _ch; } } return str; } }], [{ key: "endOfLine", value: function endOfLine(src, start, inFlow) { var ch = src[start]; var offset = start; while (ch && ch !== '\n') { if (inFlow && (ch === '[' || ch === ']' || ch === '{' || ch === '}' || ch === ',')) break; var next = src[offset + 1]; if (ch === ':' && (!next || next === '\n' || next === '\t' || next === ' ' || inFlow && next === ',')) break; if ((ch === ' ' || ch === '\t') && next === '#') break; offset += 1; ch = next; } return offset; } }]); return PlainValue; }(_Node2.default); exports.default = PlainValue;