X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/d15b59f5d4f43d12719c5ce37518246058b405c6..15024d7e7c224d837592094932a2da18d17ee015:/Exception.hpp diff --git a/Exception.hpp b/Exception.hpp index a3be1a8..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,17 +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 @@ -63,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); \ @@ -91,6 +104,12 @@ void CYThrow(JSContextRef context, JSValueRef value); _assert(_aprstatus == APR_SUCCESS); \ } while (false) +#define _krncall(expr) \ + do { \ + kern_return_t _krnstatus((expr)); \ + _assert(_krnstatus == KERN_SUCCESS); \ + } while (false) + #define _sqlcall(expr) ({ \ __typeof__(expr) _value = (expr); \ if (_value != 0 && (_value < 100 || _value >= 200)) \