在bazel构建中运行react-native cli

时间:2019-11-22 20:45:32

标签: react-native bazel react-native-cli

我正在为React-Native Android项目设置Bazel构建。由于我将不会使用Android Studio和Gradle,因此需要调用react-native cli创建RN包。我尝试了genrulenodejs_binary规则的几种组合,以及对react-nativenpx react-nativereact-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" ]
)

1 个答案:

答案 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"],
)