From 2459e150bbeb3a6cda5cc2267d8592aca9c99f4a Mon Sep 17 00:00:00 2001 From: Myles Borins Date: Fri, 10 Aug 2018 12:10:24 -0400 Subject: [PATCH] doc: add note about ABI compatibility Building node against versions of the dependencies that differ from the ones we vendor will result in a non ABI compatible version of Node.js This patch adds a note to make it explicit that if individuals build node against different versions of a dependency they should make a custom NODE_MODULE_VERSION. PR-URL: https://github.com/nodejs/node/pull/22237 Reviewed-By: Vse Mozhet Byt Reviewed-By: Jon Moss Reviewed-By: Benjamin Gruenbaum Reviewed-By: James M Snell Reviewed-By: Trivikram Kamat --- BUILDING.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/BUILDING.md b/BUILDING.md index 1ecdc5abb17adc..3f95f32d72d9b6 100644 --- a/BUILDING.md +++ b/BUILDING.md @@ -433,3 +433,14 @@ To make `./myCustomModule.js` available via `require('myCustomModule')`. ```console > .\vcbuild link-module './myCustomModule.js' ``` + +## Note for downstream distributors of Node.js + +The Node.js ecosystem is reliant on ABI compatibility within a major +release. To maintain ABI compatibility it is required that production +builds of Node.js will be built against the same version of dependencies as the +project vendors. If Node.js is to be built against a different version of a +dependency please create a custom `NODE_MODULE_VERSION` to ensure ecosystem +compatibility. Please consult with the TSC by opening an issue at +https://github.com/nodejs/tsc/issues if you decide to create a custom +`NODE_MODULE_VERSION` so we can avoid duplication in the ecosystem.