From e59c6f642dbbfe3dae0eb9a0d079a9a636d1394e Mon Sep 17 00:00:00 2001 From: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> Date: Sat, 17 Dec 2022 11:48:07 -0800 Subject: Add `strict` option to Bun.deepEquals --- src/bun.js/bindings/ZigGlobalObject.cpp | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/bun.js/bindings/ZigGlobalObject.cpp b/src/bun.js/bindings/ZigGlobalObject.cpp index 06a4bbd87..1e70fdd99 100644 --- a/src/bun.js/bindings/ZigGlobalObject.cpp +++ b/src/bun.js/bindings/ZigGlobalObject.cpp @@ -1814,14 +1814,21 @@ JSC_DEFINE_HOST_FUNCTION(functionBunDeepEquals, (JSGlobalObject * globalObject, return JSValue::encode(jsUndefined()); } - JSC::JSValue arg1 = callFrame->argument(0); - JSC::JSValue arg2 = callFrame->argument(1); + JSC::JSValue arg1 = callFrame->uncheckedArgument(0); + JSC::JSValue arg2 = callFrame->uncheckedArgument(1); + JSC::JSValue arg3 = callFrame->argument(2); Vector, 16> stack; - bool isEqual = Bun__deepEquals(globalObject, arg1, arg2, stack, &scope, true); - RETURN_IF_EXCEPTION(scope, {}); - return JSValue::encode(jsBoolean(isEqual)); + if (arg3.isBoolean() && arg3.asBoolean()) { + bool isEqual = Bun__deepEquals(globalObject, arg1, arg2, stack, &scope, true); + RETURN_IF_EXCEPTION(scope, {}); + return JSValue::encode(jsBoolean(isEqual)); + } else { + bool isEqual = Bun__deepEquals(globalObject, arg1, arg2, stack, &scope, true); + RETURN_IF_EXCEPTION(scope, {}); + return JSValue::encode(jsBoolean(isEqual)); + } } JSC_DECLARE_HOST_FUNCTION(functionBunNanoseconds); -- cgit v1.2.3