X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/6fe7ccc865dc7d7541b93c5bcaf6368d2c98a174..HEAD:/runtime/ExceptionHelpers.h diff --git a/runtime/ExceptionHelpers.h b/runtime/ExceptionHelpers.h index 7bffd29..305ebef 100644 --- a/runtime/ExceptionHelpers.h +++ b/runtime/ExceptionHelpers.h @@ -10,7 +10,7 @@ * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. - * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of + * 3. Neither the name of Apple Inc. ("Apple") nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * @@ -29,84 +29,59 @@ #ifndef ExceptionHelpers_h #define ExceptionHelpers_h +#include "ErrorInstance.h" #include "JSObject.h" namespace JSC { -JS_EXPORT_PRIVATE JSObject* createInterruptedExecutionException(JSGlobalData*); -bool isInterruptedExecutionException(JSObject*); -bool isInterruptedExecutionException(JSValue); - -JSObject* createTerminatedExecutionException(JSGlobalData*); -bool isTerminatedExecutionException(JSObject*); -JS_EXPORT_PRIVATE bool isTerminatedExecutionException(JSValue); +typedef JSObject* (*ErrorFactory)(ExecState*, const String&, ErrorInstance::SourceAppender); +JSObject* createTerminatedExecutionException(VM*); +JS_EXPORT_PRIVATE bool isTerminatedExecutionException(Exception*); +JS_EXPORT_PRIVATE JSObject* createError(ExecState*, JSValue, const String&, ErrorInstance::SourceAppender); JS_EXPORT_PRIVATE JSObject* createStackOverflowError(ExecState*); -JSObject* createStackOverflowError(JSGlobalObject*); -JSObject* createOutOfMemoryError(JSGlobalObject*); JSObject* createUndefinedVariableError(ExecState*, const Identifier&); JSObject* createNotAnObjectError(ExecState*, JSValue); -JSObject* createInvalidParamError(ExecState*, const char* op, JSValue); +JSObject* createInvalidFunctionApplyParameterError(ExecState*, JSValue); +JSObject* createInvalidInParameterError(ExecState*, JSValue); +JSObject* createInvalidInstanceofParameterError(ExecState*, JSValue); JSObject* createNotAConstructorError(ExecState*, JSValue); JSObject* createNotAFunctionError(ExecState*, JSValue); -JSObject* createErrorForInvalidGlobalAssignment(ExecState*, const UString&); - -JSObject* throwOutOfMemoryError(ExecState*); -JSObject* throwStackOverflowError(ExecState*); +JSObject* createErrorForInvalidGlobalAssignment(ExecState*, const String&); +JSString* errorDescriptionForValue(ExecState*, JSValue); +JS_EXPORT_PRIVATE JSObject* throwOutOfMemoryError(ExecState*); +JS_EXPORT_PRIVATE JSObject* throwStackOverflowError(ExecState*); +JS_EXPORT_PRIVATE JSObject* throwTerminatedExecutionException(ExecState*); -class InterruptedExecutionError : public JSNonFinalObject { -private: - InterruptedExecutionError(JSGlobalData& globalData) - : JSNonFinalObject(globalData, globalData.interruptedExecutionErrorStructure.get()) - { - } - - static JSValue defaultValue(const JSObject*, ExecState*, PreferredPrimitiveType); +class TerminatedExecutionError final : public JSNonFinalObject { public: typedef JSNonFinalObject Base; + static const unsigned StructureFlags = Base::StructureFlags | StructureIsImmortal; - static InterruptedExecutionError* create(JSGlobalData& globalData) + static TerminatedExecutionError* create(VM& vm) { - InterruptedExecutionError* error = new (NotNull, allocateCell(globalData.heap)) InterruptedExecutionError(globalData); - error->finishCreation(globalData); + TerminatedExecutionError* error = new (NotNull, allocateCell(vm.heap)) TerminatedExecutionError(vm); + error->finishCreation(vm); return error; } - static Structure* createStructure(JSGlobalData& globalData, JSGlobalObject* globalObject, JSValue prototype) + static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype) { - return Structure::create(globalData, globalObject, prototype, TypeInfo(ObjectType, StructureFlags), &s_info); + return Structure::create(vm, globalObject, prototype, TypeInfo(ObjectType, StructureFlags), info()); } - static const ClassInfo s_info; -}; + DECLARE_EXPORT_INFO; -class TerminatedExecutionError : public JSNonFinalObject { private: - TerminatedExecutionError(JSGlobalData& globalData) - : JSNonFinalObject(globalData, globalData.terminatedExecutionErrorStructure.get()) + explicit TerminatedExecutionError(VM& vm) + : JSNonFinalObject(vm, vm.terminatedExecutionErrorStructure.get()) { } static JSValue defaultValue(const JSObject*, ExecState*, PreferredPrimitiveType); -public: - typedef JSNonFinalObject Base; - - static TerminatedExecutionError* create(JSGlobalData& globalData) - { - TerminatedExecutionError* error = new (NotNull, allocateCell(globalData.heap)) TerminatedExecutionError(globalData); - error->finishCreation(globalData); - return error; - } - - static Structure* createStructure(JSGlobalData& globalData, JSGlobalObject* globalObject, JSValue prototype) - { - return Structure::create(globalData, globalObject, prototype, TypeInfo(ObjectType, StructureFlags), &s_info); - } - - static JS_EXPORTDATA const ClassInfo s_info; }; } // namespace JSC