title | layout | toc |
---|---|---|
Making changes to rules_nodejs |
default |
true |
One advantage of open-source software is that you can make your own changes that suit your needs.
The packages published to npm and GitHub differ from the sources in this repo. The packages have only runtime bazel dependencies, but the sources depend on development dependencies. For example, the @bazel_skylib
library is a development-time transitive dependency, while an npm package would have that dependency statically linked in.
This differs from much of the Bazel ecosystem, where you are expected to build the whole transitive toolchain from sources.
If you have a small change, it's easiest to just patch the distributed artifacts rather than build from source. However if you're doing active development in rules_nodejs or have a policy of not depending on release artifacts, it's possible to depend directly on sources. This is not yet documented; file an issue on our repo if you think you need this.
The pattern we use most commonly is to use patch-package. To store your local changes to the npm packages follow the steps:
npm i -D patch-package
- Edit the target package in your
node_modules
- Run
npx patch-package <npm package>
. This will store the patch in thepatches/
directory in the root of the workspace - Add
"postinstall": "patch-package"
to thepackage.json
in your repo to apply the patches when building dependencies (aka atnpm install
)
rules_nodejs has a distribution format which is a tgz published to GitHub, and this can make it tricky to make casual changes without forking the project and building your own release artifacts.
Bazel has a handy patching mechanism that lets you easily apply a local patch to the release artifact for built-in rules: the patches
attribute to http_archive
.
First, make your changes in a clone of the rules_nodejs repo. Export a patch file simply using git diff
:
git diff > my.patch
Then copy the patch file somewhere in your repo and point to it from your WORKSPACE
file:
http_archive(
name = "build_bazel_rules_nodejs",
patch_args = ["-p1"],
patches = ["//path/to/my.patch"],
sha256 = "6d4edbf28ff6720aedf5f97f9b9a7679401bf7fca9d14a0fff80f644a99992b4",
urls = ["https://github.com/bazelbuild/rules_nodejs/releases/download/0.32.2/rules_nodejs-0.32.2.tar.gz"],
)