Renderer.cpp 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. // Copyright (C) 2009-2021, Panagiotis Christopoulos Charitos and contributors.
  2. // All rights reserved.
  3. // Code licensed under the BSD License.
  4. // http://www.anki3d.org/LICENSE
  5. // WARNING: This file is auto generated.
  6. #include <AnKi/Script/LuaBinder.h>
  7. #include <AnKi/Script/ScriptManager.h>
  8. #include <AnKi/Renderer.h>
  9. namespace anki {
  10. static MainRenderer* getMainRenderer(lua_State* l)
  11. {
  12. LuaBinder* binder = nullptr;
  13. lua_getallocf(l, reinterpret_cast<void**>(&binder));
  14. MainRenderer* r = binder->getOtherSystems().m_renderer;
  15. ANKI_ASSERT(r);
  16. return r;
  17. }
  18. LuaUserDataTypeInfo luaUserDataTypeInfoDbg = {-100952987011959913, "Dbg",
  19. LuaUserData::computeSizeForGarbageCollected<Dbg>(), nullptr, nullptr};
  20. template<>
  21. const LuaUserDataTypeInfo& LuaUserData::getDataTypeInfoFor<Dbg>()
  22. {
  23. return luaUserDataTypeInfoDbg;
  24. }
  25. /// Pre-wrap method Dbg::getEnabled.
  26. static inline int pwrapDbggetEnabled(lua_State* l)
  27. {
  28. LuaUserData* ud;
  29. (void)ud;
  30. void* voidp;
  31. (void)voidp;
  32. PtrSize size;
  33. (void)size;
  34. if(ANKI_UNLIKELY(LuaBinder::checkArgsCount(l, 1)))
  35. {
  36. return -1;
  37. }
  38. // Get "this" as "self"
  39. if(LuaBinder::checkUserData(l, 1, luaUserDataTypeInfoDbg, ud))
  40. {
  41. return -1;
  42. }
  43. Dbg* self = ud->getData<Dbg>();
  44. // Call the method
  45. Bool ret = self->getEnabled();
  46. // Push return value
  47. lua_pushboolean(l, ret);
  48. return 1;
  49. }
  50. /// Wrap method Dbg::getEnabled.
  51. static int wrapDbggetEnabled(lua_State* l)
  52. {
  53. int res = pwrapDbggetEnabled(l);
  54. if(res >= 0)
  55. {
  56. return res;
  57. }
  58. lua_error(l);
  59. return 0;
  60. }
  61. /// Pre-wrap method Dbg::setEnabled.
  62. static inline int pwrapDbgsetEnabled(lua_State* l)
  63. {
  64. LuaUserData* ud;
  65. (void)ud;
  66. void* voidp;
  67. (void)voidp;
  68. PtrSize size;
  69. (void)size;
  70. if(ANKI_UNLIKELY(LuaBinder::checkArgsCount(l, 2)))
  71. {
  72. return -1;
  73. }
  74. // Get "this" as "self"
  75. if(LuaBinder::checkUserData(l, 1, luaUserDataTypeInfoDbg, ud))
  76. {
  77. return -1;
  78. }
  79. Dbg* self = ud->getData<Dbg>();
  80. // Pop arguments
  81. Bool arg0;
  82. if(ANKI_UNLIKELY(LuaBinder::checkNumber(l, 2, arg0)))
  83. {
  84. return -1;
  85. }
  86. // Call the method
  87. self->setEnabled(arg0);
  88. return 0;
  89. }
  90. /// Wrap method Dbg::setEnabled.
  91. static int wrapDbgsetEnabled(lua_State* l)
  92. {
  93. int res = pwrapDbgsetEnabled(l);
  94. if(res >= 0)
  95. {
  96. return res;
  97. }
  98. lua_error(l);
  99. return 0;
  100. }
  101. /// Wrap class Dbg.
  102. static inline void wrapDbg(lua_State* l)
  103. {
  104. LuaBinder::createClass(l, &luaUserDataTypeInfoDbg);
  105. LuaBinder::pushLuaCFuncMethod(l, "getEnabled", wrapDbggetEnabled);
  106. LuaBinder::pushLuaCFuncMethod(l, "setEnabled", wrapDbgsetEnabled);
  107. lua_settop(l, 0);
  108. }
  109. LuaUserDataTypeInfo luaUserDataTypeInfoMainRenderer = {-4669156293220173081, "MainRenderer",
  110. LuaUserData::computeSizeForGarbageCollected<MainRenderer>(),
  111. nullptr, nullptr};
  112. template<>
  113. const LuaUserDataTypeInfo& LuaUserData::getDataTypeInfoFor<MainRenderer>()
  114. {
  115. return luaUserDataTypeInfoMainRenderer;
  116. }
  117. /// Pre-wrap method MainRenderer::getAspectRatio.
  118. static inline int pwrapMainRenderergetAspectRatio(lua_State* l)
  119. {
  120. LuaUserData* ud;
  121. (void)ud;
  122. void* voidp;
  123. (void)voidp;
  124. PtrSize size;
  125. (void)size;
  126. if(ANKI_UNLIKELY(LuaBinder::checkArgsCount(l, 1)))
  127. {
  128. return -1;
  129. }
  130. // Get "this" as "self"
  131. if(LuaBinder::checkUserData(l, 1, luaUserDataTypeInfoMainRenderer, ud))
  132. {
  133. return -1;
  134. }
  135. MainRenderer* self = ud->getData<MainRenderer>();
  136. // Call the method
  137. F32 ret = self->getAspectRatio();
  138. // Push return value
  139. lua_pushnumber(l, lua_Number(ret));
  140. return 1;
  141. }
  142. /// Wrap method MainRenderer::getAspectRatio.
  143. static int wrapMainRenderergetAspectRatio(lua_State* l)
  144. {
  145. int res = pwrapMainRenderergetAspectRatio(l);
  146. if(res >= 0)
  147. {
  148. return res;
  149. }
  150. lua_error(l);
  151. return 0;
  152. }
  153. /// Pre-wrap method MainRenderer::setCurrentDebugRenderTarget.
  154. static inline int pwrapMainRenderersetCurrentDebugRenderTarget(lua_State* l)
  155. {
  156. LuaUserData* ud;
  157. (void)ud;
  158. void* voidp;
  159. (void)voidp;
  160. PtrSize size;
  161. (void)size;
  162. if(ANKI_UNLIKELY(LuaBinder::checkArgsCount(l, 2)))
  163. {
  164. return -1;
  165. }
  166. // Get "this" as "self"
  167. if(LuaBinder::checkUserData(l, 1, luaUserDataTypeInfoMainRenderer, ud))
  168. {
  169. return -1;
  170. }
  171. MainRenderer* self = ud->getData<MainRenderer>();
  172. // Pop arguments
  173. const char* arg0;
  174. if(ANKI_UNLIKELY(LuaBinder::checkString(l, 2, arg0)))
  175. {
  176. return -1;
  177. }
  178. // Call the method
  179. self->getOffscreenRenderer().setCurrentDebugRenderTarget(arg0);
  180. return 0;
  181. }
  182. /// Wrap method MainRenderer::setCurrentDebugRenderTarget.
  183. static int wrapMainRenderersetCurrentDebugRenderTarget(lua_State* l)
  184. {
  185. int res = pwrapMainRenderersetCurrentDebugRenderTarget(l);
  186. if(res >= 0)
  187. {
  188. return res;
  189. }
  190. lua_error(l);
  191. return 0;
  192. }
  193. /// Wrap class MainRenderer.
  194. static inline void wrapMainRenderer(lua_State* l)
  195. {
  196. LuaBinder::createClass(l, &luaUserDataTypeInfoMainRenderer);
  197. LuaBinder::pushLuaCFuncMethod(l, "getAspectRatio", wrapMainRenderergetAspectRatio);
  198. LuaBinder::pushLuaCFuncMethod(l, "setCurrentDebugRenderTarget", wrapMainRenderersetCurrentDebugRenderTarget);
  199. lua_settop(l, 0);
  200. }
  201. /// Pre-wrap function getMainRenderer.
  202. static inline int pwrapgetMainRenderer(lua_State* l)
  203. {
  204. LuaUserData* ud;
  205. (void)ud;
  206. void* voidp;
  207. (void)voidp;
  208. PtrSize size;
  209. (void)size;
  210. if(ANKI_UNLIKELY(LuaBinder::checkArgsCount(l, 0)))
  211. {
  212. return -1;
  213. }
  214. // Call the function
  215. MainRenderer* ret = getMainRenderer(l);
  216. // Push return value
  217. if(ANKI_UNLIKELY(ret == nullptr))
  218. {
  219. lua_pushstring(l, "Glue code returned nullptr");
  220. return -1;
  221. }
  222. voidp = lua_newuserdata(l, sizeof(LuaUserData));
  223. ud = static_cast<LuaUserData*>(voidp);
  224. luaL_setmetatable(l, "MainRenderer");
  225. extern LuaUserDataTypeInfo luaUserDataTypeInfoMainRenderer;
  226. ud->initPointed(&luaUserDataTypeInfoMainRenderer, ret);
  227. return 1;
  228. }
  229. /// Wrap function getMainRenderer.
  230. static int wrapgetMainRenderer(lua_State* l)
  231. {
  232. int res = pwrapgetMainRenderer(l);
  233. if(res >= 0)
  234. {
  235. return res;
  236. }
  237. lua_error(l);
  238. return 0;
  239. }
  240. /// Wrap the module.
  241. void wrapModuleRenderer(lua_State* l)
  242. {
  243. wrapDbg(l);
  244. wrapMainRenderer(l);
  245. LuaBinder::pushLuaCFunc(l, "getMainRenderer", wrapgetMainRenderer);
  246. }
  247. } // end namespace anki