"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.register = register; const language_core_1 = require("@volar/language-core"); const vscode_uri_1 = require("vscode-uri"); const cancellation_1 = require("../utils/cancellation"); const dedupe = require("../utils/dedupe"); const featureWorkers_1 = require("../utils/featureWorkers"); function register(context) { return (uri, position, referenceContext, token = cancellation_1.NoneCancellationToken) => { return (0, featureWorkers_1.languageFeatureWorker)(context, uri, () => position, docs => (0, featureWorkers_1.getGeneratedPositions)(docs, position, language_core_1.isReferencesEnabled), async (plugin, document, position) => { if (token.isCancellationRequested) { return; } const recursiveChecker = dedupe.createLocationSet(); const result = []; await withLinkedCode(document, position); return result; async function withLinkedCode(document, position) { if (!plugin[1].provideReferences) { return; } if (recursiveChecker.has({ uri: document.uri, range: { start: position, end: position } })) { return; } recursiveChecker.add({ uri: document.uri, range: { start: position, end: position } }); const references = await plugin[1].provideReferences(document, position, referenceContext, token) ?? []; for (const reference of references) { let foundMirrorPosition = false; recursiveChecker.add({ uri: reference.uri, range: { start: reference.range.start, end: reference.range.start } }); const decoded = context.decodeEmbeddedDocumentUri(vscode_uri_1.URI.parse(reference.uri)); const sourceScript = decoded && context.language.scripts.get(decoded[0]); const virtualCode = decoded && sourceScript?.generated?.embeddedCodes.get(decoded[1]); const linkedCodeMap = virtualCode && sourceScript ? context.language.linkedCodeMaps.get(virtualCode) : undefined; if (sourceScript && virtualCode && linkedCodeMap) { const embeddedDocument = context.documents.get(context.encodeEmbeddedDocumentUri(sourceScript.id, virtualCode.id), virtualCode.languageId, virtualCode.snapshot); for (const linkedPos of (0, featureWorkers_1.getLinkedCodePositions)(embeddedDocument, linkedCodeMap, reference.range.start)) { if (recursiveChecker.has({ uri: embeddedDocument.uri, range: { start: linkedPos, end: linkedPos } })) { continue; } foundMirrorPosition = true; await withLinkedCode(embeddedDocument, linkedPos); } } if (!foundMirrorPosition) { result.push(reference); } } } }, data => { const results = []; for (const reference of data) { const decoded = context.decodeEmbeddedDocumentUri(vscode_uri_1.URI.parse(reference.uri)); const sourceScript = decoded && context.language.scripts.get(decoded[0]); const virtualCode = decoded && sourceScript?.generated?.embeddedCodes.get(decoded[1]); if (sourceScript && virtualCode) { const embeddedDocument = context.documents.get(context.encodeEmbeddedDocumentUri(sourceScript.id, virtualCode.id), virtualCode.languageId, virtualCode.snapshot); for (const [sourceScript, map] of context.language.maps.forEach(virtualCode)) { const sourceDocument = context.documents.get(sourceScript.id, sourceScript.languageId, sourceScript.snapshot); const docs = [sourceDocument, embeddedDocument, map]; const range = (0, featureWorkers_1.getSourceRange)(docs, reference.range, language_core_1.isReferencesEnabled); if (range) { results.push({ uri: sourceDocument.uri, range, }); } } } else { results.push(reference); } } return results; }, arr => dedupe.withLocations(arr.flat())); }; } //# sourceMappingURL=provideReferences.js.map