in packages/metro/src/lib/getAppendScripts.js [35:151]
function getAppendScripts<T: number | string>(
entryPoint: string,
modules: $ReadOnlyArray<Module<>>,
importBundleNames: Set<string>,
options: Options<T>,
): $ReadOnlyArray<Module<>> {
const output = [];
if (importBundleNames.size) {
const importBundleNamesObject = Object.create(null);
importBundleNames.forEach(absolutePath => {
const bundlePath = path.relative(options.serverRoot, absolutePath);
importBundleNamesObject[options.createModuleId(absolutePath)] =
bundlePath.slice(0, -path.extname(bundlePath).length);
});
const code = `(function(){var $$=${options.getRunModuleStatement(
options.createModuleId(options.asyncRequireModulePath),
)}$$.addImportBundleNames(${String(
JSON.stringify(importBundleNamesObject),
)})})();`;
output.push({
path: '$$importBundleNames',
dependencies: new Map(),
getSource: (): Buffer => Buffer.from(''),
inverseDependencies: new Set(),
output: [
{
type: 'js/script/virtual',
data: {
code,
lineCount: countLines(code),
map: [],
},
},
],
});
}
if (options.runModule) {
const paths = [...options.runBeforeMainModule, entryPoint];
for (const path of paths) {
if (modules.some((module: Module<>) => module.path === path)) {
const code = options.getRunModuleStatement(
options.createModuleId(path),
);
output.push({
path: `require-${path}`,
dependencies: new Map(),
getSource: (): Buffer => Buffer.from(''),
inverseDependencies: new Set(),
output: [
{
type: 'js/script/virtual',
data: {
code,
lineCount: countLines(code),
map: [],
},
},
],
});
}
}
}
if (options.inlineSourceMap || options.sourceMapUrl) {
const sourceMappingURL = options.inlineSourceMap
? getInlineSourceMappingURL(
sourceMapString(modules, {
processModuleFilter: (): boolean => true,
excludeSource: false,
}),
)
: nullthrows(options.sourceMapUrl);
const code = `//# sourceMappingURL=${sourceMappingURL}`;
output.push({
path: 'source-map',
dependencies: new Map(),
getSource: (): Buffer => Buffer.from(''),
inverseDependencies: new Set(),
output: [
{
type: 'js/script/virtual',
data: {
code,
lineCount: countLines(code),
map: [],
},
},
],
});
}
if (options.sourceUrl) {
const code = `//# sourceURL=${options.sourceUrl}`;
output.push({
path: 'source-url',
dependencies: new Map(),
getSource: (): Buffer => Buffer.from(''),
inverseDependencies: new Set(),
output: [
{
type: 'js/script/virtual',
data: {
code,
lineCount: countLines(code),
map: [],
},
},
],
});
}
return output;
}