mirror of
https://github.com/Instadapp/Swap-Aggregator-Subgraph.git
synced 2024-07-29 21:57:12 +00:00
170 lines
5.2 KiB
JavaScript
170 lines
5.2 KiB
JavaScript
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
|
|
import _createClass from "@babel/runtime/helpers/createClass";
|
|
import _inherits from "@babel/runtime/helpers/inherits";
|
|
import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
|
|
import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
|
|
|
|
function _createSuper(Derived) { return function () { var Super = _getPrototypeOf(Derived), result; if (_isNativeReflectConstruct()) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
|
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
|
|
|
|
import { Node } from './Node';
|
|
import { Range } from './Range';
|
|
export var PlainValue = /*#__PURE__*/function (_Node) {
|
|
_inherits(PlainValue, _Node);
|
|
|
|
var _super = _createSuper(PlainValue);
|
|
|
|
function PlainValue() {
|
|
_classCallCheck(this, PlainValue);
|
|
|
|
return _super.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); |