From 82a96502a4637e581607b41ab777f88a73f4f683 Mon Sep 17 00:00:00 2001 From: Gabriel Schulhof Date: Mon, 30 Mar 2020 09:22:42 -0700 Subject: [PATCH] src: change guards to NAPI_VERSION > 5 Since we have made the decision that we shall include `BigInt` into N-API 6, we can change the guards for the `BigInt` and `BigInt`-based typed array wrappers accordingly, and end our reliance on guarding by `NODE_MAJOR_VERSION`. Signed-off-by: Gabriel Schulhof PR-URL: https://github.com/nodejs/node-addon-api/pull/697 Reviewed-By: Nicola Del Gobbo Reviewed-By: Chengzhong Wu Reviewed-By: Michael Dawson --- common.gypi | 2 -- napi-inl.h | 14 ++++---------- napi.h | 35 ++++++++++------------------------- test/bigint.cc | 5 +---- test/binding.cc | 10 ++-------- test/index.js | 15 +++++---------- test/typedarray.cc | 26 ++++---------------------- 7 files changed, 26 insertions(+), 81 deletions(-) diff --git a/common.gypi b/common.gypi index 76f8d251c..088f961ea 100644 --- a/common.gypi +++ b/common.gypi @@ -1,7 +1,6 @@ { 'variables': { 'NAPI_VERSION%': " 5 inline bool Value::IsBigInt() const { return Type() == napi_bigint; } -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 #if (NAPI_VERSION > 4) inline bool Value::IsDate() const { @@ -624,10 +621,7 @@ inline double Number::DoubleValue() const { return result; } -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 //////////////////////////////////////////////////////////////////////////////// // BigInt Class //////////////////////////////////////////////////////////////////////////////// @@ -688,7 +682,7 @@ inline void BigInt::ToWords(int* sign_bit, size_t* word_count, uint64_t* words) _env, _value, sign_bit, word_count, words); NAPI_THROW_IF_FAILED_VOID(_env, status); } -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 #if (NAPI_VERSION > 4) //////////////////////////////////////////////////////////////////////////////// diff --git a/napi.h b/napi.h index e4b964f87..7828a2b3f 100644 --- a/napi.h +++ b/napi.h @@ -119,12 +119,9 @@ namespace Napi { class Value; class Boolean; class Number; -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 class BigInt; -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 #if (NAPI_VERSION > 4) class Date; #endif @@ -147,13 +144,10 @@ namespace Napi { typedef TypedArrayOf Uint32Array; ///< Typed-array of unsigned 32-bit integers typedef TypedArrayOf Float32Array; ///< Typed-array of 32-bit floating-point values typedef TypedArrayOf Float64Array; ///< Typed-array of 64-bit floating-point values -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 typedef TypedArrayOf BigInt64Array; ///< Typed array of signed 64-bit integers typedef TypedArrayOf BigUint64Array; ///< Typed array of unsigned 64-bit integers -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 /// Defines the signature of a N-API C++ module's registration callback (init) function. typedef Object (*ModuleRegisterCallback)(Env env, Object exports); @@ -257,12 +251,9 @@ namespace Napi { bool IsNull() const; ///< Tests if a value is a null JavaScript value. bool IsBoolean() const; ///< Tests if a value is a JavaScript boolean. bool IsNumber() const; ///< Tests if a value is a JavaScript number. -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 bool IsBigInt() const; ///< Tests if a value is a JavaScript bigint. -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 #if (NAPI_VERSION > 4) bool IsDate() const; ///< Tests if a value is a JavaScript date. #endif @@ -335,10 +326,7 @@ namespace Napi { double DoubleValue() const; ///< Converts a Number value to a 64-bit floating-point value. }; -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 /// A JavaScript bigint value. class BigInt : public Value { public: @@ -377,7 +365,7 @@ namespace Napi { /// be needed to store this BigInt (i.e. the return value of `WordCount()`). void ToWords(int* sign_bit, size_t* word_count, uint64_t* words); }; -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 #if (NAPI_VERSION > 4) /// A JavaScript date value. @@ -859,13 +847,10 @@ namespace Napi { : std::is_same::value ? napi_uint32_array : std::is_same::value ? napi_float32_array : std::is_same::value ? napi_float64_array -// Currently experimental guard with the definition of NAPI_EXPERIMENTAL. -// Once it is no longer experimental guard with the NAPI_VERSION in which it is -// released instead. -#ifdef NAPI_EXPERIMENTAL +#if NAPI_VERSION > 5 : std::is_same::value ? napi_bigint64_array : std::is_same::value ? napi_biguint64_array -#endif // NAPI_EXPERIMENTAL +#endif // NAPI_VERSION > 5 : unknown_array_type; } /// !endcond diff --git a/test/bigint.cc b/test/bigint.cc index a62ed3c30..1f89db84a 100644 --- a/test/bigint.cc +++ b/test/bigint.cc @@ -1,7 +1,4 @@ -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) #define NAPI_EXPERIMENTAL #include "napi.h" diff --git a/test/binding.cc b/test/binding.cc index 111bcce01..8732ae7bd 100644 --- a/test/binding.cc +++ b/test/binding.cc @@ -14,10 +14,7 @@ Object InitBasicTypesArray(Env env); Object InitBasicTypesBoolean(Env env); Object InitBasicTypesNumber(Env env); Object InitBasicTypesValue(Env env); -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) Object InitBigInt(Env env); #endif Object InitBuffer(Env env); @@ -70,10 +67,7 @@ Object Init(Env env, Object exports) { exports.Set("basic_types_boolean", InitBasicTypesBoolean(env)); exports.Set("basic_types_number", InitBasicTypesNumber(env)); exports.Set("basic_types_value", InitBasicTypesValue(env)); -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) exports.Set("bigint", InitBigInt(env)); #endif #if (NAPI_VERSION > 4) diff --git a/test/index.js b/test/index.js index e96ac5bf8..0fc38d280 100644 --- a/test/index.js +++ b/test/index.js @@ -57,15 +57,6 @@ let testModules = [ ]; const napiVersion = Number(process.versions.napi) -const nodeMajorVersion = Number(process.versions.node.match(/\d+/)[0]) - -if (nodeMajorVersion < 10) { - // Currently experimental guard with NODE_MAJOR_VERISION in which it was - // released. Once it is no longer experimental guard with the NAPI_VERSION - // in which it is released instead. - testModules.splice(testModules.indexOf('bigint'), 1); - testModules.splice(testModules.indexOf('typedarray-bigint'), 1); -} if (napiVersion < 3) { testModules.splice(testModules.indexOf('callbackscope'), 1); @@ -87,9 +78,13 @@ if (napiVersion < 5) { testModules.splice(testModules.indexOf('date'), 1); } +if (napiVersion < 6) { + testModules.splice(testModules.indexOf('bigint'), 1); + testModules.splice(testModules.indexOf('typedarray-bigint'), 1); +} + if (typeof global.gc === 'function') { console.log(`Testing with N-API Version '${napiVersion}'.`); - console.log(`Testing with Node.js Major Version '${nodeMajorVersion}'.\n`); console.log('Starting test suite\n'); diff --git a/test/typedarray.cc b/test/typedarray.cc index 3b16ca2f5..08c667699 100644 --- a/test/typedarray.cc +++ b/test/typedarray.cc @@ -1,9 +1,3 @@ -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) -#define NAPI_EXPERIMENTAL -#endif #include "napi.h" using namespace Napi; @@ -70,10 +64,7 @@ Value CreateTypedArray(const CallbackInfo& info) { NAPI_TYPEDARRAY_NEW(Float64Array, info.Env(), length, napi_float64_array) : NAPI_TYPEDARRAY_NEW_BUFFER(Float64Array, info.Env(), length, buffer, bufferOffset, napi_float64_array); -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) } else if (arrayType == "bigint64") { return buffer.IsUndefined() ? NAPI_TYPEDARRAY_NEW(BigInt64Array, info.Env(), length, napi_bigint64_array) : @@ -107,10 +98,7 @@ Value GetTypedArrayType(const CallbackInfo& info) { case napi_uint32_array: return String::New(info.Env(), "uint32"); case napi_float32_array: return String::New(info.Env(), "float32"); case napi_float64_array: return String::New(info.Env(), "float64"); -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) case napi_bigint64_array: return String::New(info.Env(), "bigint64"); case napi_biguint64_array: return String::New(info.Env(), "biguint64"); #endif @@ -150,10 +138,7 @@ Value GetTypedArrayElement(const CallbackInfo& info) { return Number::New(info.Env(), array.As()[index]); case napi_float64_array: return Number::New(info.Env(), array.As()[index]); -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) case napi_bigint64_array: return BigInt::New(info.Env(), array.As()[index]); case napi_biguint64_array: @@ -197,10 +182,7 @@ void SetTypedArrayElement(const CallbackInfo& info) { case napi_float64_array: array.As()[index] = value.DoubleValue(); break; -// Currently experimental guard with NODE_MAJOR_VERISION in which it was -// released. Once it is no longer experimental guard with the NAPI_VERSION -// in which it is released instead. -#if (NODE_MAJOR_VERSION >= 10) +#if (NAPI_VERSION > 5) case napi_bigint64_array: { bool lossless; array.As()[index] = value.As().Int64Value(&lossless);