| /* |
| * Copyright (C) 1999-2001 Harri Porten (porten@kde.org) |
| * Copyright (C) 2001 Peter Kelly (pmk@post.com) |
| * Copyright (C) 2003-2019 Apple Inc. All rights reserved. |
| * |
| * This library is free software; you can redistribute it and/or |
| * modify it under the terms of the GNU Library General Public |
| * License as published by the Free Software Foundation; either |
| * version 2 of the License, or (at your option) any later version. |
| * |
| * This library is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * Library General Public License for more details. |
| * |
| * You should have received a copy of the GNU Library General Public License |
| * along with this library; see the file COPYING.LIB. If not, write to |
| * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
| * Boston, MA 02110-1301, USA. |
| * |
| */ |
| |
| #pragma once |
| |
| #include "ErrorInstance.h" |
| #include "ErrorType.h" |
| #include "Exception.h" |
| #include "InternalFunction.h" |
| #include "JSObject.h" |
| #include "ThrowScope.h" |
| #include <stdint.h> |
| |
| |
| namespace JSC { |
| |
| class CallFrame; |
| class VM; |
| class JSGlobalObject; |
| class JSObject; |
| class SourceCode; |
| class Structure; |
| using ExecState = CallFrame; |
| |
| // ExecState wrappers. |
| JSObject* createError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createEvalError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createRangeError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createRangeError(ExecState*, JSGlobalObject*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createReferenceError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createSyntaxError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| JSObject* createTypeError(ExecState*, const String&, ErrorInstance::SourceAppender, RuntimeType); |
| JSObject* createNotEnoughArgumentsError(ExecState*, ErrorInstance::SourceAppender); |
| JSObject* createURIError(ExecState*, const String&, ErrorInstance::SourceAppender); |
| |
| |
| JS_EXPORT_PRIVATE JSObject* createError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createEvalError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createRangeError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createRangeError(ExecState*, JSGlobalObject*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createReferenceError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createSyntaxError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createTypeError(ExecState*); |
| JS_EXPORT_PRIVATE JSObject* createTypeError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createNotEnoughArgumentsError(ExecState*); |
| JS_EXPORT_PRIVATE JSObject* createURIError(ExecState*, const String&); |
| JS_EXPORT_PRIVATE JSObject* createOutOfMemoryError(ExecState*); |
| JS_EXPORT_PRIVATE JSObject* createOutOfMemoryError(ExecState*, const String&); |
| |
| JS_EXPORT_PRIVATE JSObject* createError(ExecState*, ErrorType, const String&); |
| |
| JSObject* createGetterTypeError(ExecState*, const String&); |
| |
| std::unique_ptr<Vector<StackFrame>> getStackTrace(ExecState*, VM&, JSObject*, bool useCurrentFrame); |
| void getBytecodeOffset(ExecState*, VM&, Vector<StackFrame>*, CallFrame*&, unsigned& bytecodeOffset); |
| bool getLineColumnAndSource(Vector<StackFrame>* stackTrace, unsigned& line, unsigned& column, String& sourceURL); |
| bool addErrorInfo(VM&, Vector<StackFrame>*, JSObject*); |
| JS_EXPORT_PRIVATE void addErrorInfo(ExecState*, JSObject*, bool); |
| JSObject* addErrorInfo(ExecState*, JSObject* error, int line, const SourceCode&); |
| |
| // Methods to throw Errors. |
| |
| // Convenience wrappers, create an throw an exception with a default message. |
| JS_EXPORT_PRIVATE Exception* throwConstructorCannotBeCalledAsFunctionTypeError(ExecState*, ThrowScope&, const char* constructorName); |
| JS_EXPORT_PRIVATE Exception* throwTypeError(ExecState*, ThrowScope&); |
| JS_EXPORT_PRIVATE Exception* throwTypeError(ExecState*, ThrowScope&, ASCIILiteral errorMessage); |
| JS_EXPORT_PRIVATE Exception* throwTypeError(ExecState*, ThrowScope&, const String& errorMessage); |
| JS_EXPORT_PRIVATE Exception* throwSyntaxError(ExecState*, ThrowScope&); |
| JS_EXPORT_PRIVATE Exception* throwSyntaxError(ExecState*, ThrowScope&, const String& errorMessage); |
| inline Exception* throwRangeError(ExecState* state, ThrowScope& scope, const String& errorMessage) { return throwException(state, scope, createRangeError(state, errorMessage)); } |
| |
| JS_EXPORT_PRIVATE Exception* throwGetterTypeError(ExecState*, ThrowScope&, const String& errorMessage); |
| JS_EXPORT_PRIVATE JSValue throwDOMAttributeGetterTypeError(ExecState*, ThrowScope&, const ClassInfo*, PropertyName); |
| |
| // Convenience wrappers, wrap result as an EncodedJSValue. |
| inline void throwVMError(ExecState* exec, ThrowScope& scope, Exception* exception) { throwException(exec, scope, exception); } |
| inline EncodedJSValue throwVMError(ExecState* exec, ThrowScope& scope, JSValue error) { return JSValue::encode(throwException(exec, scope, error)); } |
| inline EncodedJSValue throwVMError(ExecState* exec, ThrowScope& scope, const char* errorMessage) { return JSValue::encode(throwException(exec, scope, createError(exec, errorMessage))); } |
| inline EncodedJSValue throwVMTypeError(ExecState* exec, ThrowScope& scope) { return JSValue::encode(throwTypeError(exec, scope)); } |
| inline EncodedJSValue throwVMTypeError(ExecState* exec, ThrowScope& scope, ASCIILiteral errorMessage) { return JSValue::encode(throwTypeError(exec, scope, errorMessage)); } |
| inline EncodedJSValue throwVMTypeError(ExecState* exec, ThrowScope& scope, const String& errorMessage) { return JSValue::encode(throwTypeError(exec, scope, errorMessage)); } |
| inline EncodedJSValue throwVMRangeError(ExecState* state, ThrowScope& scope, const String& errorMessage) { return JSValue::encode(throwRangeError(state, scope, errorMessage)); } |
| inline EncodedJSValue throwVMGetterTypeError(ExecState* exec, ThrowScope& scope, const String& errorMessage) { return JSValue::encode(throwGetterTypeError(exec, scope, errorMessage)); } |
| inline EncodedJSValue throwVMDOMAttributeGetterTypeError(ExecState* state, ThrowScope& scope, const ClassInfo* classInfo, PropertyName propertyName) { return JSValue::encode(throwDOMAttributeGetterTypeError(state, scope, classInfo, propertyName)); } |
| |
| } // namespace JSC |