| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 |
- /*
- MIT License http://www.opensource.org/licenses/mit-license.php
- Author Tobias Koppers @sokra
- */
- "use strict";
- const createMappingsSerializer = require("./createMappingsSerializer");
- const streamChunks = require("./streamChunks");
- /** @typedef {import("../Source").RawSourceMap} RawSourceMap */
- /** @typedef {import("./streamChunks").GeneratedSourceInfo} GeneratedSourceInfo */
- /** @typedef {import("./streamChunks").OnChunk} OnChunk */
- /** @typedef {import("./streamChunks").OnName} OnName */
- /** @typedef {import("./streamChunks").OnSource} OnSource */
- /** @typedef {import("./streamChunks").Options} Options */
- /** @typedef {import("./streamChunks").SourceMaybeWithStreamChunksFunction} SourceMaybeWithStreamChunksFunction */
- // eslint-disable-next-line valid-jsdoc
- /**
- * @param {SourceMaybeWithStreamChunksFunction} inputSource input source
- * @param {Options} options options
- * @param {OnChunk} onChunk on chunk
- * @param {OnSource} onSource on source
- * @param {OnName} onName on name
- * @returns {{ result: GeneratedSourceInfo, source: string, map: RawSourceMap | null }} result
- */
- const streamAndGetSourceAndMap = (
- inputSource,
- options,
- onChunk,
- onSource,
- onName
- ) => {
- let code = "";
- let mappings = "";
- /** @type {(string | null)[]} */
- let sources = [];
- /** @type {(string | null)[]} */
- let sourcesContent = [];
- /** @type {(string | null)[]} */
- let names = [];
- const addMapping = createMappingsSerializer(
- Object.assign({}, options, { columns: true })
- );
- const finalSource = !!(options && options.finalSource);
- const { generatedLine, generatedColumn, source } = streamChunks(
- inputSource,
- options,
- (
- chunk,
- generatedLine,
- generatedColumn,
- sourceIndex,
- originalLine,
- originalColumn,
- nameIndex
- ) => {
- if (chunk !== undefined) code += chunk;
- mappings += addMapping(
- generatedLine,
- generatedColumn,
- sourceIndex,
- originalLine,
- originalColumn,
- nameIndex
- );
- return onChunk(
- finalSource ? undefined : chunk,
- generatedLine,
- generatedColumn,
- sourceIndex,
- originalLine,
- originalColumn,
- nameIndex
- );
- },
- (sourceIndex, source, sourceContent) => {
- while (sources.length < sourceIndex) {
- sources.push(null);
- }
- sources[sourceIndex] = source;
- if (sourceContent !== undefined) {
- while (sourcesContent.length < sourceIndex) {
- sourcesContent.push(null);
- }
- sourcesContent[sourceIndex] = sourceContent;
- }
- return onSource(sourceIndex, source, sourceContent);
- },
- (nameIndex, name) => {
- while (names.length < nameIndex) {
- names.push(null);
- }
- names[nameIndex] = name;
- return onName(nameIndex, name);
- }
- );
- const resultSource = source !== undefined ? source : code;
- return {
- result: {
- generatedLine,
- generatedColumn,
- source: finalSource ? resultSource : undefined
- },
- source: resultSource,
- 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[]} */ (sources),
- sourcesContent:
- sourcesContent.length > 0
- ? /** @type {string[]} */ (sourcesContent)
- : undefined,
- names: /** @type {string[]} */ (names)
- }
- : null
- };
- };
- module.exports = streamAndGetSourceAndMap;
|