Sha256: a4db330a1216ab320199153f47ddec79ce5d0c0dbb8d3a4a28c9692b401213e8
Contents?: true
Size: 1.83 KB
Versions: 58
Compression:
Stored size: 1.83 KB
Contents
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = removeTypeDuplicates; var _index = require("../../validators/generated/index.js"); function getQualifiedName(node) { return (0, _index.isIdentifier)(node) ? node.name : `${node.right.name}.${getQualifiedName(node.left)}`; } function removeTypeDuplicates(nodesIn) { const nodes = Array.from(nodesIn); const generics = new Map(); const bases = new Map(); const typeGroups = new Set(); const types = []; for (let i = 0; i < nodes.length; i++) { const node = nodes[i]; if (!node) continue; if (types.indexOf(node) >= 0) { continue; } if ((0, _index.isTSAnyKeyword)(node)) { return [node]; } if ((0, _index.isTSBaseType)(node)) { bases.set(node.type, node); continue; } if ((0, _index.isTSUnionType)(node)) { if (!typeGroups.has(node.types)) { nodes.push(...node.types); typeGroups.add(node.types); } continue; } if ((0, _index.isTSTypeReference)(node) && node.typeParameters) { const name = getQualifiedName(node.typeName); if (generics.has(name)) { let existing = generics.get(name); if (existing.typeParameters) { if (node.typeParameters) { existing.typeParameters.params.push(...node.typeParameters.params); existing.typeParameters.params = removeTypeDuplicates(existing.typeParameters.params); } } else { existing = node.typeParameters; } } else { generics.set(name, node); } continue; } types.push(node); } for (const [, baseType] of bases) { types.push(baseType); } for (const [, genericName] of generics) { types.push(genericName); } return types; } //# sourceMappingURL=removeTypeDuplicates.js.map
Version data entries
58 entries across 16 versions & 3 rubygems