- 37개 파일 IP → zioinfo.co.kr 치환 (소스/매뉴얼/설정/하네스) - Manager DrConsole/NetworkConsole/CsapConsole 빌드 + /var/www/manager/ 배포 - 테스트: Manager HTTP 200, ITSM 신규 API 7개 전체 200 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
101 lines
2.9 KiB
JavaScript
101 lines
2.9 KiB
JavaScript
"use strict";
|
|
|
|
const Consumer = require("./Consumer");
|
|
const { SourceMapGenerator } = require("source-map");
|
|
Consumer;
|
|
function composeSourceMaps(maps) {
|
|
const SourceMetadataMapConsumer = require("metro-symbolicate/src/SourceMetadataMapConsumer");
|
|
const GoogleIgnoreListConsumer = require("metro-symbolicate/src/GoogleIgnoreListConsumer");
|
|
if (maps.length < 1) {
|
|
throw new Error("composeSourceMaps: Expected at least one map");
|
|
}
|
|
const firstMap = maps[0];
|
|
const consumers = maps
|
|
.map(function (map) {
|
|
return new Consumer(map);
|
|
})
|
|
.reverse();
|
|
const generator = new SourceMapGenerator({
|
|
file: consumers[0].file,
|
|
});
|
|
consumers[0].eachMapping((mapping) => {
|
|
const original = findOriginalPosition(
|
|
consumers,
|
|
mapping.generatedLine,
|
|
mapping.generatedColumn
|
|
);
|
|
generator.addMapping({
|
|
generated: {
|
|
line: mapping.generatedLine,
|
|
column: mapping.generatedColumn,
|
|
},
|
|
original:
|
|
original.line != null
|
|
? {
|
|
line: original.line,
|
|
column: original.column,
|
|
}
|
|
: null,
|
|
source: original.source,
|
|
name: original.name,
|
|
});
|
|
});
|
|
const composedMap = generator.toJSON();
|
|
composedMap.sourcesContent = composedMap.sources.map((source) =>
|
|
consumers[consumers.length - 1].sourceContentFor(source, true)
|
|
);
|
|
if (composedMap.sourcesContent.every((content) => content == null)) {
|
|
delete composedMap.sourcesContent;
|
|
}
|
|
const metadataConsumer = new SourceMetadataMapConsumer(firstMap);
|
|
composedMap.x_facebook_sources = metadataConsumer.toArray(
|
|
composedMap.sources
|
|
);
|
|
const function_offsets = maps[maps.length - 1].x_hermes_function_offsets;
|
|
if (function_offsets) {
|
|
composedMap.x_hermes_function_offsets = function_offsets;
|
|
}
|
|
const ignoreListConsumer = new GoogleIgnoreListConsumer(firstMap);
|
|
const x_google_ignoreList = ignoreListConsumer.toArray(composedMap.sources);
|
|
if (x_google_ignoreList.length) {
|
|
composedMap.x_google_ignoreList = x_google_ignoreList;
|
|
}
|
|
return composedMap;
|
|
}
|
|
function findOriginalPosition(consumers, generatedLine, generatedColumn) {
|
|
let currentLine = generatedLine;
|
|
let currentColumn = generatedColumn;
|
|
let original = {
|
|
line: null,
|
|
column: null,
|
|
source: null,
|
|
name: null,
|
|
};
|
|
for (const consumer of consumers) {
|
|
if (currentLine == null || currentColumn == null) {
|
|
return {
|
|
line: null,
|
|
column: null,
|
|
source: null,
|
|
name: null,
|
|
};
|
|
}
|
|
original = consumer.originalPositionFor({
|
|
line: currentLine,
|
|
column: currentColumn,
|
|
});
|
|
currentLine = original.line;
|
|
currentColumn = original.column;
|
|
if (currentLine == null) {
|
|
return {
|
|
line: null,
|
|
column: null,
|
|
source: null,
|
|
name: null,
|
|
};
|
|
}
|
|
}
|
|
return original;
|
|
}
|
|
module.exports = composeSourceMaps;
|