From f73d9f139343bdc67e03c78222ace3ec8f980304 Mon Sep 17 00:00:00 2001 From: evanbacon Date: Wed, 5 Jun 2024 17:23:23 +0200 Subject: [PATCH] apply custom serializer to source map endpoint in dev server --- packages/metro/src/Server.js | 49 ++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/packages/metro/src/Server.js b/packages/metro/src/Server.js index ce94a10fe9..325628cb5b 100644 --- a/packages/metro/src/Server.js +++ b/packages/metro/src/Server.js @@ -1153,6 +1153,55 @@ class Server { prepend = []; } + // If the project defines a custom serializer, then we should run it to ensure any + // mutations to the graph are applied in the sourcemap. + if (this._config.serializer.customSerializer) { + const bundle = await this._config.serializer.customSerializer( + entryFile, + prepend, + graph, + { + asyncRequireModulePath: await this._resolveRelativePath( + this._config.transformer.asyncRequireModulePath, + { + relativeTo: 'project', + resolverOptions, + transformOptions, + }, + ), + processModuleFilter: this._config.serializer.processModuleFilter, + createModuleId: this._createModuleId, + getRunModuleStatement: + this._config.serializer.getRunModuleStatement, + includeAsyncPaths: graphOptions.lazy, + dev: transformOptions.dev, + projectRoot: this._config.projectRoot, + modulesOnly: serializerOptions.modulesOnly, + runBeforeMainModule: + this._config.serializer.getModulesRunBeforeMainModule( + path.relative(this._config.projectRoot, entryFile), + ), + runModule: serializerOptions.runModule, + sourceMapUrl: serializerOptions.sourceMapUrl, + sourceUrl: serializerOptions.sourceUrl, + inlineSourceMap: serializerOptions.inlineSourceMap, + serverRoot: + this._config.server.unstable_serverRoot ?? + this._config.projectRoot, + shouldAddToIgnoreList: (module: Module<>) => + this._shouldAddModuleToIgnoreList(module), + getSourceUrl: (module: Module<>) => + this._getModuleSourceUrl(module, serializerOptions.sourcePaths), + }, + ); + + // If the serializer returned the source map then we can use it here, otherwise + // fall back to the default source map generation with the possibly mutated graph. + if (typeof bundle !== 'string' && bundle.map) { + return bundle.map; + } + } + return await sourceMapStringNonBlocking( [...prepend, ...this._getSortedModules(graph)], {