mirror of
				https://github.com/Instadapp/Swap-Aggregator-Subgraph.git
				synced 2024-07-29 21:57:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			184 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			184 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| "use strict";
 | |
| 
 | |
| exports.Collection = exports.isEmptyPath = void 0;
 | |
| 
 | |
| var _addComment = require("../addComment");
 | |
| 
 | |
| var _constants = require("../constants");
 | |
| 
 | |
| var _Node = require("./Node");
 | |
| 
 | |
| var _Scalar = require("./Scalar");
 | |
| 
 | |
| function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
 | |
| 
 | |
| function collectionFromPath(schema, path, value) {
 | |
|   let v = value;
 | |
| 
 | |
|   for (let i = path.length - 1; i >= 0; --i) {
 | |
|     const k = path[i];
 | |
|     const o = Number.isInteger(k) && k >= 0 ? [] : {};
 | |
|     o[k] = v;
 | |
|     v = o;
 | |
|   }
 | |
| 
 | |
|   return schema.createNode(v, false);
 | |
| } // null, undefined, or an empty non-string iterable (e.g. [])
 | |
| 
 | |
| 
 | |
| const isEmptyPath = path => path == null || typeof path === 'object' && path[Symbol.iterator]().next().done;
 | |
| 
 | |
| exports.isEmptyPath = isEmptyPath;
 | |
| 
 | |
| class Collection extends _Node.Node {
 | |
|   constructor(schema) {
 | |
|     super();
 | |
| 
 | |
|     _defineProperty(this, "items", []);
 | |
| 
 | |
|     this.schema = schema;
 | |
|   }
 | |
| 
 | |
|   addIn(path, value) {
 | |
|     if (isEmptyPath(path)) this.add(value);else {
 | |
|       const [key, ...rest] = path;
 | |
|       const node = this.get(key, true);
 | |
|       if (node instanceof Collection) node.addIn(rest, value);else if (node === undefined && this.schema) this.set(key, collectionFromPath(this.schema, rest, value));else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   deleteIn([key, ...rest]) {
 | |
|     if (rest.length === 0) return this.delete(key);
 | |
|     const node = this.get(key, true);
 | |
|     if (node instanceof Collection) return node.deleteIn(rest);else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
 | |
|   }
 | |
| 
 | |
|   getIn([key, ...rest], keepScalar) {
 | |
|     const node = this.get(key, true);
 | |
|     if (rest.length === 0) return !keepScalar && node instanceof _Scalar.Scalar ? node.value : node;else return node instanceof Collection ? node.getIn(rest, keepScalar) : undefined;
 | |
|   }
 | |
| 
 | |
|   hasAllNullValues() {
 | |
|     return this.items.every(node => {
 | |
|       if (!node || node.type !== 'PAIR') return false;
 | |
|       const n = node.value;
 | |
|       return n == null || n instanceof _Scalar.Scalar && n.value == null && !n.commentBefore && !n.comment && !n.tag;
 | |
|     });
 | |
|   }
 | |
| 
 | |
|   hasIn([key, ...rest]) {
 | |
|     if (rest.length === 0) return this.has(key);
 | |
|     const node = this.get(key, true);
 | |
|     return node instanceof Collection ? node.hasIn(rest) : false;
 | |
|   }
 | |
| 
 | |
|   setIn([key, ...rest], value) {
 | |
|     if (rest.length === 0) {
 | |
|       this.set(key, value);
 | |
|     } else {
 | |
|       const node = this.get(key, true);
 | |
|       if (node instanceof Collection) node.setIn(rest, value);else if (node === undefined && this.schema) this.set(key, collectionFromPath(this.schema, rest, value));else throw new Error(`Expected YAML collection at ${key}. Remaining path: ${rest}`);
 | |
|     }
 | |
|   } // overridden in implementations
 | |
| 
 | |
|   /* istanbul ignore next */
 | |
| 
 | |
| 
 | |
|   toJSON() {
 | |
|     return null;
 | |
|   }
 | |
| 
 | |
|   toString(ctx, {
 | |
|     blockItem,
 | |
|     flowChars,
 | |
|     isMap,
 | |
|     itemIndent
 | |
|   }, onComment, onChompKeep) {
 | |
|     const {
 | |
|       doc,
 | |
|       indent,
 | |
|       indentStep
 | |
|     } = ctx;
 | |
|     const inFlow = this.type === _constants.Type.FLOW_MAP || this.type === _constants.Type.FLOW_SEQ || ctx.inFlow;
 | |
|     if (inFlow) itemIndent += indentStep;
 | |
|     const allNullValues = isMap && this.hasAllNullValues();
 | |
|     ctx = Object.assign({}, ctx, {
 | |
|       allNullValues,
 | |
|       indent: itemIndent,
 | |
|       inFlow,
 | |
|       type: null
 | |
|     });
 | |
|     let chompKeep = false;
 | |
|     let hasItemWithNewLine = false;
 | |
|     const nodes = this.items.reduce((nodes, item, i) => {
 | |
|       let comment;
 | |
| 
 | |
|       if (item) {
 | |
|         if (!chompKeep && item.spaceBefore) nodes.push({
 | |
|           type: 'comment',
 | |
|           str: ''
 | |
|         });
 | |
|         if (item.commentBefore) item.commentBefore.match(/^.*$/gm).forEach(line => {
 | |
|           nodes.push({
 | |
|             type: 'comment',
 | |
|             str: `#${line}`
 | |
|           });
 | |
|         });
 | |
|         if (item.comment) comment = item.comment;
 | |
|         if (inFlow && (!chompKeep && item.spaceBefore || item.commentBefore || item.comment || item.key && (item.key.commentBefore || item.key.comment) || item.value && (item.value.commentBefore || item.value.comment))) hasItemWithNewLine = true;
 | |
|       }
 | |
| 
 | |
|       chompKeep = false;
 | |
|       let str = doc.schema.stringify(item, ctx, () => comment = null, () => chompKeep = true);
 | |
|       if (inFlow && !hasItemWithNewLine && str.includes('\n')) hasItemWithNewLine = true;
 | |
|       if (inFlow && i < this.items.length - 1) str += ',';
 | |
|       str = (0, _addComment.addComment)(str, itemIndent, comment);
 | |
|       if (chompKeep && (comment || inFlow)) chompKeep = false;
 | |
|       nodes.push({
 | |
|         type: 'item',
 | |
|         str
 | |
|       });
 | |
|       return nodes;
 | |
|     }, []);
 | |
|     let str;
 | |
| 
 | |
|     if (nodes.length === 0) {
 | |
|       str = flowChars.start + flowChars.end;
 | |
|     } else if (inFlow) {
 | |
|       const {
 | |
|         start,
 | |
|         end
 | |
|       } = flowChars;
 | |
|       const strings = nodes.map(n => n.str);
 | |
| 
 | |
|       if (hasItemWithNewLine || strings.reduce((sum, str) => sum + str.length + 2, 2) > Collection.maxFlowStringSingleLineLength) {
 | |
|         str = start;
 | |
| 
 | |
|         for (const s of strings) {
 | |
|           str += s ? `\n${indentStep}${indent}${s}` : '\n';
 | |
|         }
 | |
| 
 | |
|         str += `\n${indent}${end}`;
 | |
|       } else {
 | |
|         str = `${start} ${strings.join(' ')} ${end}`;
 | |
|       }
 | |
|     } else {
 | |
|       const strings = nodes.map(blockItem);
 | |
|       str = strings.shift();
 | |
| 
 | |
|       for (const s of strings) str += s ? `\n${indent}${s}` : '\n';
 | |
|     }
 | |
| 
 | |
|     if (this.comment) {
 | |
|       str += '\n' + this.comment.replace(/^/gm, `${indent}#`);
 | |
|       if (onComment) onComment();
 | |
|     } else if (chompKeep && onChompKeep) onChompKeep();
 | |
| 
 | |
|     return str;
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| exports.Collection = Collection;
 | |
| 
 | |
| _defineProperty(Collection, "maxFlowStringSingleLineLength", 60); | 
