virtual const char *PoolCString(CYPool &pool) const = 0;
#ifdef CY_EXECUTE
- virtual JSValueRef CastJSValue(JSContextRef context) const = 0;
+ virtual JSValueRef CastJSValue(JSContextRef context, const char *name) const = 0;
#endif
};
#define CYTry \
try
-#define CYCatch(value) \
+#define CYCatch_(value, name) \
catch (const CYException &error) { \
- *exception = error.CastJSValue(context); \
+ *exception = error.CastJSValue(context, name); \
return value; \
} catch (...) { \
*exception = CYCastJSValue(context, "catch(...)"); \
return value; \
}
+#define CYCatch(value) \
+ CYCatch_(value, "Error")
#define _assert_(mode, test, code, format, ...) do \
if (!(test)) \
#define _sqlcall(expr) ({ \
__typeof__(expr) _value = (expr); \
- _assert_("sqlcall", _value == 0 || _value >= 100 && _value < 200, #expr, " %u:%s", _value sqlite3_errmsg(database_)); \
-})
+ _assert_("sqlcall", _value == 0 || _value >= 100 && _value < 200, #expr, " %u:%s", _value, sqlite3_errmsg(database_)); \
+_value; })
+#ifdef CY_EXECUTE
struct CYJSException {
JSContextRef context_;
JSValueRef value_;
CYJSException _error(context); \
(code)(args, _error); \
})
+#endif
#endif/*CYCRIPT_ERROR_HPP*/