| #!/usr/bin/env bash |
| |
| set -o errexit -o nounset -o pipefail |
| |
| # Argument provided by reusable workflow caller, see |
| # https://github.com/bazel-contrib/.github/blob/d197a6427c5435ac22e56e33340dff912bc9334e/.github/workflows/release_ruleset.yaml#L72 |
| TAG=$1 |
| # The prefix is chosen to match what GitHub generates for source archives |
| PREFIX="rules_nodejs-${TAG:1}" |
| ARCHIVE="rules_nodejs-$TAG.tar.gz" |
| git archive --format=tar --prefix="${PREFIX}/" "${TAG}" | gzip > "$ARCHIVE" |
| SHA=$(shasum -a 256 "$ARCHIVE" | awk '{print $1}') |
| |
| # Add generated API docs to the release, see https://github.com/bazelbuild/bazel-central-registry/issues/5593 |
| docs="$(mktemp -d)"; targets="$(mktemp)" |
| bazel --output_base="$docs" query --output=label --output_file="$targets" 'kind("starlark_doc_extract rule", //...)' |
| bazel --output_base="$docs" build --target_pattern_file="$targets" --remote_download_regex='.*doc_extract\.binaryproto' |
| tar --create --auto-compress \ |
| --directory "$(bazel --output_base="$docs" info bazel-bin)" \ |
| --file "$GITHUB_WORKSPACE/${ARCHIVE%.tar.gz}.docs.tar.gz" . |
| |
| cat << EOF |
| ## Using Bzlmod with Bazel 6 or greater |
| |
| 1. (Bazel 6 only) Enable with \`common --enable_bzlmod\` in \`.bazelrc\`. |
| 2. Add to your \`MODULE.bazel\` file: |
| |
| \`\`\`starlark |
| bazel_dep(name = "rules_nodejs", version = "${TAG:1}") |
| \`\`\` |
| |
| ## Using WORKSPACE |
| |
| Paste this snippet into your \`WORKSPACE.bazel\` file: |
| |
| \`\`\`starlark |
| load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive") |
| http_archive( |
| name = "rules_nodejs", |
| sha256 = "${SHA}", |
| strip_prefix = "${PREFIX}", |
| url = "https://github.com/bazel-contrib/rules_nodejs/releases/download/${TAG}/${ARCHIVE}", |
| ) |
| EOF |
| |
| # TODO: fill in more snippet if/when we have an e2e that illustrates what is needed |
| # awk 'f;/--SNIP--/{f=1}' e2e/smoke/WORKSPACE.bazel |
| echo "\`\`\`" |