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); | 
