X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/b6961e537b5468dc0458808fdacba4a3291e1d48..334bdca20434ce7c9ded6d95338c79b8612740af:/Exception.hpp diff --git a/Exception.hpp b/Exception.hpp index 2828345..286fdeb 100644 --- a/Exception.hpp +++ b/Exception.hpp @@ -1,4 +1,4 @@ -/* Cycript - Error.hppution Server and Disassembler +/* Cycript - Inlining/Optimizing JavaScript Compiler * Copyright (C) 2009 Jay Freeman (saurik) */ @@ -40,18 +40,28 @@ #ifndef CYCRIPT_EXCEPTION_HPP #define CYCRIPT_EXCEPTION_HPP +#ifdef CY_EXECUTE #include +#endif #include #include "Standard.hpp" struct CYException { + virtual ~CYException() { + } + virtual const char *PoolCString(apr_pool_t *pool) const = 0; +#ifdef CY_EXECUTE virtual JSValueRef CastJSValue(JSContextRef context) const = 0; +#endif }; void CYThrow(const char *format, ...) _noreturn; + +#ifdef CY_EXECUTE void CYThrow(JSContextRef context, JSValueRef value); +#endif #define CYTry \ try @@ -64,6 +74,8 @@ void CYThrow(JSContextRef context, JSValueRef value); return NULL; \ } +// XXX: fix this: _ is not safe; this is /not/ Menes ;P +#undef _assert #define _assert(test, args...) do { \ if (!(test)) \ CYThrow("*** _assert(%s):%s(%u):%s [errno=%d]", #test, __FILE__, __LINE__, __FUNCTION__, errno); \