diff options
-rw-r--r-- | src/GuiLua/GuiLua.c | 64 | ||||
-rw-r--r-- | src/libraries/Runnr.c | 66 | ||||
-rw-r--r-- | src/libraries/Runnr.h | 1 |
3 files changed, 69 insertions, 62 deletions
diff --git a/src/GuiLua/GuiLua.c b/src/GuiLua/GuiLua.c index 3bdada9..92254ea 100644 --- a/src/GuiLua/GuiLua.c +++ b/src/GuiLua/GuiLua.c | |||
@@ -144,6 +144,7 @@ and ordinary elementary widgets. Proper introspection can come later. | |||
144 | 144 | ||
145 | #include "LumbrJack.h" | 145 | #include "LumbrJack.h" |
146 | #include "GuiLua.h" | 146 | #include "GuiLua.h" |
147 | #include "Runnr.h" | ||
147 | 148 | ||
148 | 149 | ||
149 | static int logDom; // Our logging domain. | 150 | static int logDom; // Our logging domain. |
@@ -158,77 +159,16 @@ win.quitter.colour.r = 5 -> direct access to the table, well "direct" via Th | |||
158 | */ | 159 | */ |
159 | 160 | ||
160 | 161 | ||
161 | static int traceBack(lua_State *L) | ||
162 | { | ||
163 | const char *msg = ""; | ||
164 | int top = lua_gettop(L); | ||
165 | // int i; | ||
166 | |||
167 | // printf("Stack is %d deep\n", top); | ||
168 | // for (i = 1; i <= top; i++) | ||
169 | // dumpStack(L, i); | ||
170 | |||
171 | if (top) | ||
172 | msg = lua_tostring(L, 1); | ||
173 | lua_getglobal(L, "debug"); | ||
174 | push_lua(L, "@ ( )", lua_gettop(L), "traceback", 1); | ||
175 | lua_pushstring(L, "\n"); | ||
176 | lua_pushstring(L, msg); | ||
177 | lua_concat(L, 3); | ||
178 | |||
179 | return 1; | ||
180 | } | ||
181 | |||
182 | static void _on_click(void *data, Evas_Object *obj, void *event_info EINA_UNUSED) | 162 | static void _on_click(void *data, Evas_Object *obj, void *event_info EINA_UNUSED) |
183 | { | 163 | { |
184 | Widget *wid = data; | 164 | Widget *wid = data; |
185 | 165 | ||
186 | if (wid) | 166 | if (wid) |
187 | { | 167 | { |
188 | int _T, _A, err; | ||
189 | lua_State *L = wid->data; | 168 | lua_State *L = wid->data; |
190 | 169 | ||
191 | PD("Doing action %s", wid->action); | 170 | PD("Doing action %s", wid->action); |
192 | 171 | doLuaString(L, wid->action, wid->win->module); | |
193 | lua_pushcfunction(L, traceBack); | ||
194 | _T = lua_gettop(L); | ||
195 | |||
196 | if (luaL_loadstring(L, wid->action)) | ||
197 | { | ||
198 | const char *err = lua_tostring(L, 1); | ||
199 | |||
200 | PE("Error parsing - %s, ERROR %s", wid->action, err); | ||
201 | } | ||
202 | else | ||
203 | { | ||
204 | _A = lua_gettop(L); | ||
205 | if (wid->win->module) | ||
206 | { | ||
207 | lua_getfield(L, LUA_REGISTRYINDEX, wid->win->module); | ||
208 | |||
209 | // Consistancy would be good, just sayin'. | ||
210 | if (0 == lua_setfenv(L, _A)) | ||
211 | { | ||
212 | PE("Error setting environment for - %s", wid->action); | ||
213 | return; | ||
214 | } | ||
215 | } | ||
216 | |||
217 | if ((err = lua_pcall(L, 0, LUA_MULTRET, _T))) | ||
218 | { | ||
219 | const char *err_type; | ||
220 | |||
221 | switch (err) | ||
222 | { | ||
223 | case LUA_ERRRUN: err_type = "runtime"; break; | ||
224 | case LUA_ERRSYNTAX: err_type = "syntax"; break; | ||
225 | case LUA_ERRMEM: err_type = "memory allocation"; break; | ||
226 | case LUA_ERRERR: err_type = "error handler"; break; | ||
227 | default: err_type = "unknown"; break; | ||
228 | } | ||
229 | PE("Error running - %s, \n%s - %s", wid->action, err_type, lua_tostring(L, -1)); | ||
230 | } | ||
231 | } | ||
232 | } | 172 | } |
233 | } | 173 | } |
234 | 174 | ||
diff --git a/src/libraries/Runnr.c b/src/libraries/Runnr.c index cff402e..238bfb2 100644 --- a/src/libraries/Runnr.c +++ b/src/libraries/Runnr.c | |||
@@ -38,6 +38,72 @@ void dumpStack(lua_State *L, int i) | |||
38 | } | 38 | } |
39 | } | 39 | } |
40 | 40 | ||
41 | static int traceBack(lua_State *L) | ||
42 | { | ||
43 | const char *msg = ""; | ||
44 | int top = lua_gettop(L); | ||
45 | // int i; | ||
46 | |||
47 | // printf("Stack is %d deep\n", top); | ||
48 | // for (i = 1; i <= top; i++) | ||
49 | // dumpStack(L, i); | ||
50 | |||
51 | if (top) | ||
52 | msg = lua_tostring(L, 1); | ||
53 | lua_getglobal(L, "debug"); | ||
54 | push_lua(L, "@ ( )", lua_gettop(L), "traceback", 1); | ||
55 | lua_pushstring(L, "\n"); | ||
56 | lua_pushstring(L, msg); | ||
57 | lua_concat(L, 3); | ||
58 | |||
59 | return 1; | ||
60 | } | ||
61 | |||
62 | void doLuaString(lua_State *L, char *string, char *module) | ||
63 | { | ||
64 | int _T, _A, err; | ||
65 | |||
66 | lua_pushcfunction(L, traceBack); | ||
67 | _T = lua_gettop(L); | ||
68 | |||
69 | if (luaL_loadstring(L, string)) | ||
70 | { | ||
71 | const char *err = lua_tostring(L, 1); | ||
72 | |||
73 | printf("Error parsing - %s, ERROR %s", string, err); | ||
74 | } | ||
75 | else | ||
76 | { | ||
77 | _A = lua_gettop(L); | ||
78 | if (module) | ||
79 | { | ||
80 | lua_getfield(L, LUA_REGISTRYINDEX, module); | ||
81 | |||
82 | // Consistancy would be good, just sayin'. | ||
83 | if (0 == lua_setfenv(L, _A)) | ||
84 | { | ||
85 | printf("Error setting environment for - %s", string); | ||
86 | return; | ||
87 | } | ||
88 | } | ||
89 | |||
90 | if ((err = lua_pcall(L, 0, LUA_MULTRET, _T))) | ||
91 | { | ||
92 | const char *err_type; | ||
93 | |||
94 | switch (err) | ||
95 | { | ||
96 | case LUA_ERRRUN: err_type = "runtime"; break; | ||
97 | case LUA_ERRSYNTAX: err_type = "syntax"; break; | ||
98 | case LUA_ERRMEM: err_type = "memory allocation"; break; | ||
99 | case LUA_ERRERR: err_type = "error handler"; break; | ||
100 | default: err_type = "unknown"; break; | ||
101 | } | ||
102 | printf("Error running - %s, \n%s - %s", string, err_type, lua_tostring(L, -1)); | ||
103 | } | ||
104 | } | ||
105 | } | ||
106 | |||
41 | 107 | ||
42 | // These are what the various symbols are for each type - | 108 | // These are what the various symbols are for each type - |
43 | // int % | 109 | // int % |
diff --git a/src/libraries/Runnr.h b/src/libraries/Runnr.h index d7386f6..5e3629d 100644 --- a/src/libraries/Runnr.h +++ b/src/libraries/Runnr.h | |||
@@ -13,6 +13,7 @@ | |||
13 | 13 | ||
14 | 14 | ||
15 | void dumpStack(lua_State *L, int i); | 15 | void dumpStack(lua_State *L, int i); |
16 | void doLuaString(lua_State *L, char *string, char *module); | ||
16 | int pull_lua(lua_State *L, int i, char *params, ...); | 17 | int pull_lua(lua_State *L, int i, char *params, ...); |
17 | int push_lua(lua_State *L, char *params, ...); | 18 | int push_lua(lua_State *L, char *params, ...); |
18 | 19 | ||