lj_err.h 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. ** Error handling.
  3. ** Copyright (C) 2005-2021 Mike Pall. See Copyright Notice in luajit.h
  4. */
  5. #ifndef _LJ_ERR_H
  6. #define _LJ_ERR_H
  7. #include <stdarg.h>
  8. #include "lj_obj.h"
  9. typedef enum {
  10. #define ERRDEF(name, msg) \
  11. LJ_ERR_##name, LJ_ERR_##name##_ = LJ_ERR_##name + sizeof(msg)-1,
  12. #include "lj_errmsg.h"
  13. LJ_ERR__MAX
  14. } ErrMsg;
  15. LJ_DATA const char *lj_err_allmsg;
  16. #define err2msg(em) (lj_err_allmsg+(int)(em))
  17. LJ_FUNC GCstr *lj_err_str(lua_State *L, ErrMsg em);
  18. LJ_FUNCA_NORET void LJ_FASTCALL lj_err_throw(lua_State *L, int errcode);
  19. LJ_FUNC_NORET void lj_err_mem(lua_State *L);
  20. LJ_FUNC_NORET void LJ_FASTCALL lj_err_run(lua_State *L);
  21. #if LJ_HASJIT
  22. LJ_FUNCA_NORET void LJ_FASTCALL lj_err_trace(lua_State *L, int errcode);
  23. #endif
  24. LJ_FUNC_NORET void lj_err_msg(lua_State *L, ErrMsg em);
  25. LJ_FUNC_NORET void lj_err_lex(lua_State *L, GCstr *src, const char *tok,
  26. BCLine line, ErrMsg em, va_list argp);
  27. LJ_FUNC_NORET void lj_err_optype(lua_State *L, cTValue *o, ErrMsg opm);
  28. LJ_FUNC_NORET void lj_err_comp(lua_State *L, cTValue *o1, cTValue *o2);
  29. LJ_FUNC_NORET void lj_err_optype_call(lua_State *L, TValue *o);
  30. LJ_FUNC_NORET void lj_err_callermsg(lua_State *L, const char *msg);
  31. LJ_FUNC_NORET void lj_err_callerv(lua_State *L, ErrMsg em, ...);
  32. LJ_FUNC_NORET void lj_err_caller(lua_State *L, ErrMsg em);
  33. LJ_FUNC_NORET void lj_err_arg(lua_State *L, int narg, ErrMsg em);
  34. LJ_FUNC_NORET void lj_err_argv(lua_State *L, int narg, ErrMsg em, ...);
  35. LJ_FUNC_NORET void lj_err_argtype(lua_State *L, int narg, const char *xname);
  36. LJ_FUNC_NORET void lj_err_argt(lua_State *L, int narg, int tt);
  37. #if LJ_UNWIND_JIT && !LJ_ABI_WIN
  38. LJ_FUNC uint8_t *lj_err_register_mcode(void *base, size_t sz, uint8_t *info);
  39. LJ_FUNC void lj_err_deregister_mcode(void *base, size_t sz, uint8_t *info);
  40. #else
  41. #define lj_err_register_mcode(base, sz, info) (info)
  42. #define lj_err_deregister_mcode(base, sz, info) UNUSED(base)
  43. #endif
  44. #if LJ_UNWIND_EXT && !LJ_ABI_WIN && defined(LUA_USE_ASSERT)
  45. LJ_FUNC void lj_err_verify(void);
  46. #else
  47. #define lj_err_verify() ((void)0)
  48. #endif
  49. #endif