| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 | 
							- /*
 
- 	MIT License http://www.opensource.org/licenses/mit-license.php
 
- 	Author Tobias Koppers @sokra
 
- */
 
- "use strict";
 
- const createMappingsSerializer = require("./createMappingsSerializer");
 
- /** @typedef {import("../Source").RawSourceMap} RawSourceMap */
 
- /** @typedef {import("../Source").SourceAndMap} SourceAndMap */
 
- /** @typedef {import("./streamChunks").Options} Options */
 
- /** @typedef {import("./streamChunks").StreamChunksFunction} StreamChunksFunction */
 
- /** @typedef {{ streamChunks: StreamChunksFunction }} SourceLikeWithStreamChunks */
 
- /**
 
-  * @param {SourceLikeWithStreamChunks} inputSource input source
 
-  * @param {Options=} options options
 
-  * @returns {SourceAndMap} map
 
-  */
 
- module.exports.getSourceAndMap = (inputSource, options) => {
 
- 	let code = "";
 
- 	let mappings = "";
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialSources = [];
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialSourcesContent = [];
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialNames = [];
 
- 	const addMapping = createMappingsSerializer(options);
 
- 	const { source } = inputSource.streamChunks(
 
- 		{ ...options, finalSource: true },
 
- 		(
 
- 			chunk,
 
- 			generatedLine,
 
- 			generatedColumn,
 
- 			sourceIndex,
 
- 			originalLine,
 
- 			originalColumn,
 
- 			nameIndex,
 
- 		) => {
 
- 			if (chunk !== undefined) code += chunk;
 
- 			mappings += addMapping(
 
- 				generatedLine,
 
- 				generatedColumn,
 
- 				sourceIndex,
 
- 				originalLine,
 
- 				originalColumn,
 
- 				nameIndex,
 
- 			);
 
- 		},
 
- 		(sourceIndex, source, sourceContent) => {
 
- 			while (potentialSources.length < sourceIndex) {
 
- 				potentialSources.push(null);
 
- 			}
 
- 			potentialSources[sourceIndex] = source;
 
- 			if (sourceContent !== undefined) {
 
- 				while (potentialSourcesContent.length < sourceIndex) {
 
- 					potentialSourcesContent.push(null);
 
- 				}
 
- 				potentialSourcesContent[sourceIndex] = sourceContent;
 
- 			}
 
- 		},
 
- 		(nameIndex, name) => {
 
- 			while (potentialNames.length < nameIndex) {
 
- 				potentialNames.push(null);
 
- 			}
 
- 			potentialNames[nameIndex] = name;
 
- 		},
 
- 	);
 
- 	return {
 
- 		source: source !== undefined ? source : code,
 
- 		map:
 
- 			mappings.length > 0
 
- 				? {
 
- 						version: 3,
 
- 						file: "x",
 
- 						mappings,
 
- 						// We handle broken sources as `null`, in spec this field should be string, but no information what we should do in such cases if we change type it will be breaking change
 
- 						sources: /** @type {string[]} */ (potentialSources),
 
- 						sourcesContent:
 
- 							potentialSourcesContent.length > 0
 
- 								? /** @type {string[]} */ (potentialSourcesContent)
 
- 								: undefined,
 
- 						names: /** @type {string[]} */ (potentialNames),
 
- 					}
 
- 				: null,
 
- 	};
 
- };
 
- /**
 
-  * @param {SourceLikeWithStreamChunks} source source
 
-  * @param {Options=} options options
 
-  * @returns {RawSourceMap | null} map
 
-  */
 
- module.exports.getMap = (source, options) => {
 
- 	let mappings = "";
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialSources = [];
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialSourcesContent = [];
 
- 	/** @type {(string | null)[]} */
 
- 	const potentialNames = [];
 
- 	const addMapping = createMappingsSerializer(options);
 
- 	source.streamChunks(
 
- 		{ ...options, source: false, finalSource: true },
 
- 		(
 
- 			chunk,
 
- 			generatedLine,
 
- 			generatedColumn,
 
- 			sourceIndex,
 
- 			originalLine,
 
- 			originalColumn,
 
- 			nameIndex,
 
- 		) => {
 
- 			mappings += addMapping(
 
- 				generatedLine,
 
- 				generatedColumn,
 
- 				sourceIndex,
 
- 				originalLine,
 
- 				originalColumn,
 
- 				nameIndex,
 
- 			);
 
- 		},
 
- 		(sourceIndex, source, sourceContent) => {
 
- 			while (potentialSources.length < sourceIndex) {
 
- 				potentialSources.push(null);
 
- 			}
 
- 			potentialSources[sourceIndex] = source;
 
- 			if (sourceContent !== undefined) {
 
- 				while (potentialSourcesContent.length < sourceIndex) {
 
- 					potentialSourcesContent.push(null);
 
- 				}
 
- 				potentialSourcesContent[sourceIndex] = sourceContent;
 
- 			}
 
- 		},
 
- 		(nameIndex, name) => {
 
- 			while (potentialNames.length < nameIndex) {
 
- 				potentialNames.push(null);
 
- 			}
 
- 			potentialNames[nameIndex] = name;
 
- 		},
 
- 	);
 
- 	return mappings.length > 0
 
- 		? {
 
- 				version: 3,
 
- 				file: "x",
 
- 				mappings,
 
- 				// We handle broken sources as `null`, in spec this field should be string, but no information what we should do in such cases if we change type it will be breaking change
 
- 				sources: /** @type {string[]} */ (potentialSources),
 
- 				sourcesContent:
 
- 					potentialSourcesContent.length > 0
 
- 						? /** @type {string[]} */ (potentialSourcesContent)
 
- 						: undefined,
 
- 				names: /** @type {string[]} */ (potentialNames),
 
- 			}
 
- 		: null;
 
- };
 
 
  |