diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/libjin/render/jsl.cpp | 9 | ||||
-rw-r--r-- | src/libjin/render/jsl.h | 12 | ||||
-rw-r--r-- | src/script/audio/luaopen_Source.cpp (renamed from src/script/audio/luaopen_Sound.cpp) | 2 | ||||
-rw-r--r-- | src/script/graphics/luaopen_Canvas.cpp | 6 | ||||
-rw-r--r-- | src/script/graphics/luaopen_Image.cpp | 6 | ||||
-rw-r--r-- | src/script/graphics/luaopen_JSL.cpp | 8 | ||||
-rw-r--r-- | src/script/luaopen_types.h | 6 |
7 files changed, 26 insertions, 23 deletions
diff --git a/src/libjin/render/jsl.cpp b/src/libjin/render/jsl.cpp index 49bb18f..58b9a15 100644 --- a/src/libjin/render/jsl.cpp +++ b/src/libjin/render/jsl.cpp @@ -9,10 +9,11 @@ namespace render "#version 120 \n" "#define number float \n" "#define Image sampler2D \n" - "#define Texel texture2D \n" + "#define Canvas sampler2D \n" "#define Color vec4 \n" + "#define Texel texture2D \n" "#define extern uniform \n" - "uniform Image _tex0_; \n" + "uniform Image _tex0_; \n" "%s \n" "void main(){ \n" "gl_FragColor = effect(gl_Color, _tex0_, gl_TexCoord[0].xy, gl_FragCoord.xy);\n" @@ -33,13 +34,13 @@ namespace render destroy(); } - void JSLProgram::destroy() + inline void JSLProgram::destroy() { if (currentJSLProgram == this) unuse(); } - void JSLProgram::initialize(const char* program) + inline void JSLProgram::initialize(const char* program) { if (maxTextureUnits == -1) glGetIntegerv(GL_MAX_TEXTURE_IMAGE_UNITS, &maxTextureUnits); diff --git a/src/libjin/render/jsl.h b/src/libjin/render/jsl.h index 7183325..aff7fea 100644 --- a/src/libjin/render/jsl.h +++ b/src/libjin/render/jsl.h @@ -23,15 +23,15 @@ namespace render inline void JSLProgram::use() { glUseProgram(pid); - JSLProgram::currentJSLProgram = this; - JSLProgram::currentTextureUnit = 0; + currentJSLProgram = this; + currentTextureUnit = 0; } static inline void JSLProgram::unuse() { glUseProgram(0); - JSLProgram::currentJSLProgram = nullptr; - JSLProgram::currentTextureUnit = 0; + currentJSLProgram = nullptr; + currentTextureUnit = 0; } void sendFloat(const char* name, float number); @@ -59,8 +59,8 @@ namespace render GLint getTextureUnit(const std::string& name); - void initialize(const char* program); - void destroy(); + inline void initialize(const char* program); + inline void destroy(); }; diff --git a/src/script/audio/luaopen_Sound.cpp b/src/script/audio/luaopen_Source.cpp index d43147e..2ab5d16 100644 --- a/src/script/audio/luaopen_Sound.cpp +++ b/src/script/audio/luaopen_Source.cpp @@ -16,7 +16,7 @@ namespace lua {0, 0} }; - int luaopen_Sound(lua_State* L) + int luaopen_Source(lua_State* L) { return 1; diff --git a/src/script/graphics/luaopen_Canvas.cpp b/src/script/graphics/luaopen_Canvas.cpp index a34e3b3..1e22772 100644 --- a/src/script/graphics/luaopen_Canvas.cpp +++ b/src/script/graphics/luaopen_Canvas.cpp @@ -50,9 +50,9 @@ namespace lua static int l_gc(lua_State* L) { - Canvas* canvas = checkCanvas(L); - if (canvas != nullptr) - delete canvas; + Proxy* proxy = (Proxy*)luax_checktype(L, 1, TYPE_CANVAS); + Canvas* canvas = (Canvas*)proxy->object; + delete canvas; return 0; } diff --git a/src/script/graphics/luaopen_Image.cpp b/src/script/graphics/luaopen_Image.cpp index 9506ce4..246ea09 100644 --- a/src/script/graphics/luaopen_Image.cpp +++ b/src/script/graphics/luaopen_Image.cpp @@ -63,9 +63,9 @@ namespace lua static int l_gc(lua_State* L) { - Image* i = checkImage(L); - if (i != nullptr) - delete i; + Proxy* proxy = (Proxy*)luax_checktype(L, 1, TYPE_IMAGE); + Image* img = (Image*)proxy->object; + delete img; return 0; } diff --git a/src/script/graphics/luaopen_JSL.cpp b/src/script/graphics/luaopen_JSL.cpp index 33afa2c..919949c 100644 --- a/src/script/graphics/luaopen_JSL.cpp +++ b/src/script/graphics/luaopen_JSL.cpp @@ -121,11 +121,9 @@ namespace lua static int l_gc(lua_State* L) { - JSLProgram* jsl = checkJSLProgram(L); - if (jsl != nullptr && jsl != NULL) - { - delete jsl; - } + Proxy* proxy = (Proxy*)luax_checktype(L, 1, TYPE_JSL); + JSLProgram* jsl = (JSLProgram*)proxy->object; + delete jsl; return 0; } diff --git a/src/script/luaopen_types.h b/src/script/luaopen_types.h index 8c1f2a6..c6ce202 100644 --- a/src/script/luaopen_types.h +++ b/src/script/luaopen_types.h @@ -8,7 +8,7 @@ #define TYPE_FONT "Font" // audio module -#define TYPE_SOUND "Sound" +#define TYPE_SOURCE "Source" class Proxy { @@ -20,6 +20,10 @@ public: } void* object; + + ~Proxy() + { + } }; #endif |