'use strict'; var Node = require('../nodes/Node.js'); var Scalar = require('../nodes/Scalar.js'); var resolveBlockMap = require('./resolve-block-map.js'); var resolveBlockSeq = require('./resolve-block-seq.js'); var resolveFlowCollection = require('./resolve-flow-collection.js'); function composeCollection(CN, ctx, token, tagToken, onError) { let coll; switch (token.type) { case 'block-map': { coll = resolveBlockMap.resolveBlockMap(CN, ctx, token, onError); break; } case 'block-seq': { coll = resolveBlockSeq.resolveBlockSeq(CN, ctx, token, onError); break; } case 'flow-collection': { coll = resolveFlowCollection.resolveFlowCollection(CN, ctx, token, onError); break; } } if (!tagToken) return coll; const tagName = ctx.directives.tagName(tagToken.source, msg => onError(tagToken, 'TAG_RESOLVE_FAILED', msg)); if (!tagName) return coll; // Cast needed due to: https://github.com/Microsoft/TypeScript/issues/3841 const Coll = coll.constructor; if (tagName === '!' || tagName === Coll.tagName) { coll.tag = Coll.tagName; return coll; } const expType = Node.isMap(coll) ? 'map' : 'seq'; let tag = ctx.schema.tags.find(t => t.collection === expType && t.tag === tagName); if (!tag) { const kt = ctx.schema.knownTags[tagName]; if (kt && kt.collection === expType) { ctx.schema.tags.push(Object.assign({}, kt, { default: false })); tag = kt; } else { onError(tagToken, 'TAG_RESOLVE_FAILED', `Unresolved tag: ${tagName}`, true); coll.tag = tagName; return coll; } } const res = tag.resolve(coll, msg => onError(tagToken, 'TAG_RESOLVE_FAILED', msg), ctx.options); const node = Node.isNode(res) ? res : new Scalar.Scalar(res); node.range = coll.range; node.tag = tagName; if (tag?.format) node.format = tag.format; return node; } exports.composeCollection = composeCollection;