Pull request contributions are welcome!
For major changes, please open an issue first to discuss what you would like to change.
Please make sure to update tests and documentation as appropriate.
When installing Node.js, on the "Tools for Native Modules" page, be sure to "Automatically install the necessary tools".
Also, in an Administrator PowerShell, run:
choco install llvm
Install the Xcode Command Line Tools, and then
brew install clang-format
sudo apt-get install build-essential clang-format libglib2.0-dev libblkid-dev uuid-dev
Run npm run precommit
, which:
Keep in mind: this project's build matrix is extensive--be sure any edit takes into account both Windows and POSIX systems.
Problem: npm scripts containing Unix shell operators like ||
with complex commands will fail on Windows with syntax errors like $' was unexpected at this time.
Why: Windows Command Prompt/PowerShell parses the entire command line before execution, including the Unix-specific parts that would never run on Windows. Even though constructs like node scripts/is-platform.mjs win32 || <unix-command>
would exit early on Windows, the shell still tries to parse the syntax after ||
.
Solution: For platform-specific npm scripts that use shell operators:
scripts/clang-tidy.mjs
)process.platform
or os.platform()
to detect Windows and exit earlychild_process.spawn()
with sh -c
Example: The clang-tidy
npm script was moved from:
"clang-tidy": "node scripts/is-platform.mjs win32 || (npm run configure && bear -- npm run node-gyp-rebuild && find src -name '*.cpp' -o -name '*.h' | grep -E '\\.(cpp|h)$' | grep -v -E '(windows|darwin)/' | xargs clang-tidy)"
To:
"clang-tidy": "node scripts/clang-tidy.mjs"
Where the script handles platform detection and command execution internally.
This project follows consistent naming patterns for npm scripts to improve discoverability and maintainability:
Scripts follow an action:target
pattern where:
build
, clean
, lint
, test
)native
, ts
, dist
)Examples:
build:native
- Build native C++ codelint:ts
- Lint TypeScript codeclean:dist
- Clean distribution filesActions that have multiple targets can be run in parallel using wildcards:
npm run clean
runs all clean:*
scriptsnpm run lint
runs all lint:*
scriptsrun-p
from npm-run-all for parallel executiontest:*
memory:test
- Comprehensive memory testing suiteENABLE_ASAN=1
to include sanitizer testssetup:native
instead of just setup
)prebuild
vs build
)