From a044ccd956b2e666d4ddeadc6b98d9b5291d32eb Mon Sep 17 00:00:00 2001 From: Neal Beeken Date: Mon, 17 Jun 2024 16:37:41 -0400 Subject: [PATCH] feat(NODE-6226): build macos universal binary (#21) --- .github/scripts/libmongocrypt.mjs | 13 +++++++++++-- .github/workflows/build.yml | 2 +- README.md | 15 +++++++++++++++ binding.gyp | 10 +++++++++- 4 files changed, 36 insertions(+), 4 deletions(-) diff --git a/.github/scripts/libmongocrypt.mjs b/.github/scripts/libmongocrypt.mjs index f07dea3..7299ac1 100644 --- a/.github/scripts/libmongocrypt.mjs +++ b/.github/scripts/libmongocrypt.mjs @@ -41,7 +41,8 @@ async function parseArguments() { return { libmongocrypt: { url: args.values.gitURL, ref: args.values.libVersion }, clean: args.values.clean, - build: args.values.build + build: args.values.build, + pkg }; } @@ -189,7 +190,7 @@ export async function downloadLibMongoCrypt(nodeDepsRoot, { ref }) { } async function main() { - const { libmongocrypt, build, clean } = await parseArguments(); + const { libmongocrypt, build, clean, pkg } = await parseArguments(); const nodeDepsDir = resolveRoot('deps'); @@ -228,6 +229,14 @@ async function main() { // The prebuild command will make both a .node file in `./build` (local and CI testing will run on current code) // it will also produce `./prebuilds/mongodb-client-encryption-vVERSION-napi-vNAPI_VERSION-OS-ARCH.tar.gz`. await run('npm', ['run', 'prebuild']); + + if (process.platform === 'darwin') { + // The "arm64" build is actually a universal binary + await fs.copyFile( + resolveRoot('prebuilds', `mongodb-client-encryption-v${pkg.version}-napi-v4-darwin-arm64.tar.gz`), + resolveRoot('prebuilds', `mongodb-client-encryption-v${pkg.version}-napi-v4-darwin-x64.tar.gz`) + ); + } } await main(); diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 93b8df9..a4c3421 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -16,7 +16,7 @@ jobs: host_builds: strategy: matrix: - os: [macos-11, macos-latest, windows-2019] + os: [macos-latest, windows-2019] runs-on: ${{ matrix.os }} steps: - uses: actions/checkout@v4 diff --git a/README.md b/README.md index 61844ac..50f51ca 100644 --- a/README.md +++ b/README.md @@ -33,6 +33,21 @@ Run the following command to build libmongocrypt and setup the node bindings for bash ./etc/build-static.sh ``` +#### Prebuild Platforms + +Below are the platforms that are available as prebuilds on each github release. +`prebuild-install` downloads these automatically depending on the platform you are running npm install on. + +- Linux GLIBC 2.23 or later + - s390x + - arm64 + - x64 +- MacOS universal binary + - x64 + - arm64 +- Windows + - x64 + #### Linting We lint both the c++ bindings and the Typescript. diff --git a/binding.gyp b/binding.gyp index d789780..aeb631f 100644 --- a/binding.gyp +++ b/binding.gyp @@ -23,7 +23,15 @@ 'xcode_settings': { 'GCC_ENABLE_CPP_EXCEPTIONS': 'YES', 'CLANG_CXX_LIBRARY': 'libc++', - 'MACOSX_DEPLOYMENT_TARGET': '10.12' + 'MACOSX_DEPLOYMENT_TARGET': '10.12', + "OTHER_CFLAGS": [ + "-arch x86_64", + "-arch arm64" + ], + "OTHER_LDFLAGS": [ + "-arch x86_64", + "-arch arm64" + ] }, 'cflags!': [ '-fno-exceptions' ], 'cflags_cc!': [ '-fno-exceptions' ],