| //------------------------------------------------------------------------------------------------------- |
| // Copyright (C) Microsoft. All rights reserved. |
| // Licensed under the MIT license. See LICENSE.txt file in the project root for full license information. |
| //------------------------------------------------------------------------------------------------------- |
| #pragma once |
| namespace Js |
| { |
| // Set in ctor/clear in dtor the GetDebuggingFlags()->SetIsBuiltInWrapperPresent. |
| struct AutoRegisterIgnoreExceptionWrapper |
| { |
| AutoRegisterIgnoreExceptionWrapper(ThreadContext* threadContext); |
| ~AutoRegisterIgnoreExceptionWrapper(); |
| static bool IsRegistered(ThreadContext* threadContext); |
| private: |
| ThreadContext* m_threadContext; |
| }; |
| |
| // Note: we don't need to take special for orig helpers that return void, |
| // as when we call we assume that EAX is trashed, so returning Var is fine. |
| Var HelperMethodWrapper0(ScriptContext* scriptContext, void* origHelperAddr); |
| Var HelperMethodWrapper1(ScriptContext* scriptContext, void* origHelperAddr, Var arg1); |
| Var HelperMethodWrapper2(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2); |
| Var HelperMethodWrapper3(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3); |
| Var HelperMethodWrapper4(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4); |
| Var HelperMethodWrapper5(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5); |
| Var HelperMethodWrapper6(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6); |
| Var HelperMethodWrapper7(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7); |
| Var HelperMethodWrapper8(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8); |
| Var HelperMethodWrapper9(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9); |
| Var HelperMethodWrapper10(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10); |
| Var HelperMethodWrapper11(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11); |
| Var HelperMethodWrapper12(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11, Var arg12); |
| Var HelperMethodWrapper13(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11, Var arg12, Var arg13); |
| Var HelperMethodWrapper14(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11, Var arg12, Var arg13, Var arg14); |
| Var HelperMethodWrapper15(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11, Var arg12, Var arg13, Var arg14, Var arg15); |
| Var HelperMethodWrapper16(ScriptContext* scriptContext, void* origHelperAddr, Var arg1, Var arg2, Var arg3, Var arg4, Var arg5, Var arg6, Var arg7, Var arg8, Var arg9, Var arg10, Var arg11, Var arg12, Var arg13, Var arg14, Var arg15, Var arg16); |
| |
| template <bool doCheckPArentInterpreterFrame> |
| void HandleHelperOrLibraryMethodWrapperException(ScriptContext * scriptContext, JavascriptExceptionObject * exceptionObject); |
| |
| // try-catch wrapper used to wrap helper calls or library/built-in calls. |
| // Template parameters: |
| // - Fn: the type of function to wrap |
| // - doCheckParentInterpreterFrame: whether we should check for parent frame being interpreter frame, |
| // needed in case of library call and not needed in case of helper. |
| template <bool doCheckParentInterpreterFrame, typename Fn> |
| Var HelperOrLibraryMethodWrapper(ScriptContext* scriptContext, Fn fn) |
| { |
| Assert(scriptContext); |
| JavascriptExceptionObject* exceptionObject = nullptr; |
| try |
| { |
| return fn(); |
| } |
| catch (const JavascriptException& err) |
| { |
| exceptionObject = err.GetAndClear(); |
| } |
| |
| if (exceptionObject != nullptr) |
| { |
| HandleHelperOrLibraryMethodWrapperException<doCheckParentInterpreterFrame>(scriptContext, exceptionObject); |
| } |
| return scriptContext->GetLibrary()->GetUndefined(); |
| } |
| } |