我正在为React-Native Android项目设置Bazel构建。由于我将不会使用Android Studio和Gradle,因此需要调用react-native cli创建RN包。我尝试了genrule
和nodejs_binary
规则的几种组合,以及对react-native
,npx react-native
和react-native\cli.js
的调用。这些尝试以以下两个错误之一结束:
1)
error Unrecognized command "bundle".
debug We couldn't find a package.json in your project. Are you sure you are running it inside a React Native project?
2)
Error: EPERM: operation not permitted, chmod '/private/var/tmp/_bazel_joshnunez/bfd4b860cd0c2d2f0e40baa90bf393fd/sandbox/darwin-sandbox/471/execroot/native_modules/bazel-out/host/bin/external/androi
d_sample/src/rncli.sh.runfiles/npm/node_modules/@react-native-community/cli/build/commands/server/external/xsel'
以下是我正在使用的bazel规则(许多排列都用#注释掉了):
nodejs_binary(
name = "rncli",
entry_point = "@npm//:node_modules/react-native/local-cli/cli.js",
node_modules = "@npm//:node_modules"
)
genrule (
name = "rnAndroidBundle",
outs = [ "main/assets/index.android.bundle" ],
cmd = "$(location :rncli) bundle --verbose --entry-file $(location :appEntry) --platform android --bundle-output $@",
#cmd = "npm run react-native bundle --verbose --entry-file $(location :appEntry) --platform android --bundle-output $@",
#cmd = "npx react-native bundle --verbose --entry-file $(location :appEntry) --platform android --bundle-output $@",
#cmd = "$(location @npm//:node_modules/react-native/cli.js) bundle --verbose --entry-file $(location :appEntry) --platform android --bundle-output $@",
#cmd = "node node_modules/react-native/local-cli/cli.js bundle --verbose --entry-file $(location :appEntry) --platform android --bundle-output $@",
#cmd = "node $(location @npm//react-native:node_modules/react-native/cli.js) bundle --verbose --entry-file external/android_sample/src/app.tsx --platform android --bundle-output $@",
#srcs = [ "@npm//react-native" ],
srcs = [ "appEntry" ],
#tools = [ "@npm//:node_modules/react-native/cli.js" ]
tools = [ ":rncli" ]
)
filegroup (
name = "appEntry",
srcs = [ "app.tsx" ]
)
答案 0 :(得分:0)
你有没有得到过这个可行的实现?对于新的 node_rules,我使用了一个 npm_package_bin
示例,该示例与您在此处的示例非常相似。我可以运行 bundle 命令,但在此之后我遇到了其他问题,因此不能肯定它是否会解决您的问题。
您可以尝试按照此实现的方式进行操作:
package(default_visibility = ["//visibility:public"])
load("@build_bazel_rules_nodejs//:index.bzl", "nodejs_binary","npm_package_bin", "copy_to_bin")
load("@bazel_skylib//rules:write_file.bzl", "write_file")
# note that @npm has been provided in the workspace by a yarn-install command
nodejs_binary(
name = "android_build_bin",
entry_point = "@npm//:node_modules/react-native/local-cli/cli.js",
templated_args = ["bundle --platform android" +
"--config ../../../../cli.config.js"],
data = [
"@npm//:node_modules",
":cli.config.js",
],
)
nodejs_binary(
name = "ios_build_bin",
entry_point = "@npm//:node_modules/react-native/local-cli/cli.js",
templated_args = ["bundle --platform ios" +
"--config ../../../../cli.config.js"],
data = [
"@npm//:node_modules",
":cli.config.js",
],
)
# bring across source files into the bin folder (note your paths would differ)
copy_to_bin(
name = "sources",
srcs = glob(
include = [
"src/**",
"*",
],
exclude = [],
exclude_directories = 1,
)
)
write_file(
name = "write_chdir_script",
out = "chdir.js",
content = ["process.chdir(__dirname)"],
)
npm_package_bin(
name = "android_build",
outs = [
"build/android/index.android.bundle",
"build/android/index.android.bundle.map",
"build/android/index.android.bundle.meta",
],
args = ["--node_options=--require=./$(execpath chdir.js)"],
tool = ":android_build_bin",
data = [":sources", "chdir.js"],
)
npm_package_bin(
name = "ios_build",
outs = [
"build/ios/index.ios.bundle",
"build/ios/index.ios.bundle.map",
"build/ios/index.ios.bundle.meta",
],
args = ["--node_options=--require=./$(execpath chdir.js)"],
tool = ":ios_build_bin",
data = [":sources", "chdir.js"],
)