2018-03-04 21:46:49 +08:00
|
|
|
# Building Node.js with Ninja
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2017-12-17 23:59:46 +08:00
|
|
|
The purpose of this guide is to show how to build Node.js using [Ninja][], as
|
|
|
|
doing so can be significantly quicker than using `make`. Please see
|
2019-07-10 13:07:42 +08:00
|
|
|
[Ninja's site][Ninja] for installation instructions (Unix only).
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2020-04-07 01:50:20 +08:00
|
|
|
[Ninja][] is supported in the Makefile. Run `./configure --ninja` to configure
|
|
|
|
the project to run the regular `make` commands with Ninja.
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2024-05-17 22:39:44 +08:00
|
|
|
When modifying only the JS layer in `lib`, you can use:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
./configure --ninja --node-builtin-modules-path "$(pwd)"
|
|
|
|
```
|
|
|
|
|
2020-04-07 01:50:20 +08:00
|
|
|
For example, `make` will execute `ninja -C out/Release` internally
|
|
|
|
to produce a compiled release binary, It will also execute
|
|
|
|
`ln -fs out/Release/node node`, so that you can execute `./node` at
|
|
|
|
the project's root.
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2020-04-07 01:50:20 +08:00
|
|
|
When running `make`, you will see output similar to the following
|
2017-12-17 23:59:46 +08:00
|
|
|
if the build has succeeded:
|
|
|
|
|
2020-04-24 02:01:52 +08:00
|
|
|
```console
|
2016-01-20 04:24:42 +08:00
|
|
|
ninja: Entering directory `out/Release`
|
|
|
|
[4/4] LINK node, POSTBUILDS
|
|
|
|
```
|
|
|
|
|
2017-12-17 23:59:46 +08:00
|
|
|
The bottom line will change while building, showing the progress as
|
|
|
|
`[finished/total]` build steps. This is useful output that `make` does not
|
2022-05-22 19:47:38 +08:00
|
|
|
produce and is one of the benefits of using Ninja. When using Ninja, builds
|
|
|
|
are always run in parallel, based by default on the number of CPUs your
|
|
|
|
system has. You can use the `-j` parameter to override this behavior,
|
|
|
|
which is equivalent to the `-j` parameter in the regular `make`:
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2020-04-07 01:50:20 +08:00
|
|
|
```bash
|
2022-05-22 19:47:38 +08:00
|
|
|
make -j4 # With this flag, Ninja will limit itself to 4 parallel jobs,
|
|
|
|
# regardless of the number of cores on the current machine.
|
2020-04-07 01:50:20 +08:00
|
|
|
```
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2024-05-31 00:21:56 +08:00
|
|
|
Note: if you are on macOS and use GNU Make version `3.x`, the `-jn` flag
|
|
|
|
will not work. You can either upgrade to `v4.x` (e.g. using a package manager
|
|
|
|
such as [Homebrew](https://formulae.brew.sh/formula/make#default)) or use `make JOBS=n`.
|
|
|
|
|
2016-01-20 04:24:42 +08:00
|
|
|
## Producing a debug build
|
|
|
|
|
2020-04-07 01:50:20 +08:00
|
|
|
To create a debug build rather than a release build:
|
|
|
|
|
|
|
|
```bash
|
2020-06-02 09:37:23 +08:00
|
|
|
./configure --ninja --debug && make
|
2020-04-07 01:50:20 +08:00
|
|
|
```
|
2016-01-20 04:24:42 +08:00
|
|
|
|
2022-08-22 19:39:00 +08:00
|
|
|
## Customizing `ninja` path
|
|
|
|
|
|
|
|
On some systems (such as RHEL7 and below), the Ninja binary might be installed
|
|
|
|
with a different name. For these systems use the `NINJA` env var:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
./configure --ninja && NINJA="ninja-build" make
|
|
|
|
```
|
|
|
|
|
2016-10-26 04:04:13 +08:00
|
|
|
[Ninja]: https://ninja-build.org/
|