import _classCallCheck from "@babel/runtime/helpers/classCallCheck"; import _createClass from "@babel/runtime/helpers/createClass"; import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn"; import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf"; import _inherits from "@babel/runtime/helpers/inherits"; import Node from './Node'; import Range from './Range'; var PlainValue = /*#__PURE__*/function (_Node) { _inherits(PlainValue, _Node); function PlainValue() { _classCallCheck(this, PlainValue); return _possibleConstructorReturn(this, _getPrototypeOf(PlainValue).apply(this, arguments)); } _createClass(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 (Node.atDocumentBoundary(src, offset + 1)) break; var end = Node.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(start, offset); offset = Node.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 = Node.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; }(Node); export { PlainValue as default };