React Native-构建可靠的源地图

Bri*_*ean 5 xcode ios source-maps react-native

我想我使用Xcode正确创建了源地图。需要这个用于生产构建。

我补充说:

react-native bundle --platform ios --entry-file index.ios.js --dev false --bundle-output ./ios/main.jsbundle --assets-dest ./ios --sourcemap-output ./sourcemap/sourcemap.js
Run Code Online (Sandbox Code Playgroud)

到Xcode中的Bundle React Native code and imagesin build phases,以生成似乎有效的sourcemap。

但是,当尝试使用以下代码来分析带有行号和列号的源映射时,我没有得到正确的结果

var sourceMap = require('source-map');
var fs = require('fs');

// read source-map, should be new for every build
fs.readFile('../my-app/src/sourcemap/sourcemap.js', 'utf8', function (err, data) {
    var smc = new sourceMap.SourceMapConsumer(data);

    // replace line and colum numbers with line/col from error output
    console.log(smc.originalPositionFor({
        line: 105132,
        column: 98
    }));
});
Run Code Online (Sandbox Code Playgroud)

我正在使用Xcode的堆栈跟踪作为测试,但我得到了null。Xcode部分输出:

2016-04-26 17:50:00.631 [error][tid:com.facebook.React.JavaScript] Can't find variable: dummyVar
2016-04-26 17:50:00.650 [fatal][tid:com.facebook.React.RCTExceptionsManagerQueue] Unhandled JS Exception: Can't find variable: dummyVar
2016-04-26 17:50:00.656 MyApp[311:84730] *** Terminating app due to uncaught exception 'RCTFatalException: Unhandled JS Exception: Can't find variable: dummyVar', reason: 'Unhandled JS Exception: Can't find variable: dummyVar, stack:
render@105132:98
Run Code Online (Sandbox Code Playgroud)

我尝试了行号和列号的多种组合。我知道JS脚本肯定在查看源地图,因为例如,如果我输入,line: 20 column: 10 我将从Navigator / NavigatorSceneConfigs.js中返回的react-native代码库中获得一行

这仅适用于返回的行号index.ios.bundle吗?

任何能指出我正确方向的想法都很棒

谢谢

Ijz*_*ein 5

您可以使用诸如此类的库来react-native-source-maps帮助您处理发布版本的源映射。 https://github.com/philipshurpik/react-native-source-maps

要生成源映射,您可以使用以下设置:

对于 Android,请将其添加到您的android/app/build.gradle文件中。

project.ext.react = [
    ...
    extraPackagerArgs: [
        "--sourcemap-output", "$buildDir/intermediates/assets/release/index.android.bundle.map",
        "--sourcemap-sources-root", "$rootDir/.."
    ]
]
Run Code Online (Sandbox Code Playgroud)

从 React-native 0.55 开始,您现在可以在 iOS 上执行相同的操作。在您的 XCode 项目文件中,将Bundle React Native code and images构建阶段更新为:

export NODE_BINARY=node
export EXTRA_PACKAGER_ARGS=\"--sourcemap-output $CONFIGURATION_BUILD_DIR/$UNLOCALIZED_RESOURCES_FOLDER_PATH/main.jsbundle.map --sourcemap-sources-root $SRCROOT/..\"
../node_modules/react-native/scripts/react-native-xcode.sh
Run Code Online (Sandbox Code Playgroud)