aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/ClientHamr
diff options
context:
space:
mode:
Diffstat (limited to 'ClientHamr')
-rw-r--r--ClientHamr/GuiLua/GuiLua.c86
-rw-r--r--ClientHamr/GuiLua/GuiLua.h12
-rwxr-xr-xClientHamr/GuiLua/build.sh42
-rw-r--r--ClientHamr/GuiLua/skang.c11
4 files changed, 39 insertions, 112 deletions
diff --git a/ClientHamr/GuiLua/GuiLua.c b/ClientHamr/GuiLua/GuiLua.c
index 47f63d5..985d0c6 100644
--- a/ClientHamr/GuiLua/GuiLua.c
+++ b/ClientHamr/GuiLua/GuiLua.c
@@ -204,18 +204,6 @@ void loggingStartup(globals *ourGlobals)
204 eina_log_level_set(EINA_LOG_LEVEL_DBG); 204 eina_log_level_set(EINA_LOG_LEVEL_DBG);
205 eina_log_domain_level_set("GuiLua", EINA_LOG_LEVEL_DBG); 205 eina_log_domain_level_set("GuiLua", EINA_LOG_LEVEL_DBG);
206 eina_log_print_cb_set(_ggg_log_print_cb, stderr); 206 eina_log_print_cb_set(_ggg_log_print_cb, stderr);
207
208 // Shut up the excess debugging shit from EFL.
209 eina_log_domain_level_set("eo", EINA_LOG_LEVEL_WARN);
210 eina_log_domain_level_set("eet", EINA_LOG_LEVEL_WARN);
211 eina_log_domain_level_set("ecore", EINA_LOG_LEVEL_WARN);
212 eina_log_domain_level_set("ecore_audio", EINA_LOG_LEVEL_WARN);
213 eina_log_domain_level_set("ecore_evas", EINA_LOG_LEVEL_WARN);
214 eina_log_domain_level_set("ecore_input_evas", EINA_LOG_LEVEL_WARN);
215 eina_log_domain_level_set("ecore_system_upower", EINA_LOG_LEVEL_WARN);
216 eina_log_domain_level_set("ecore_x", EINA_LOG_LEVEL_WARN);
217 eina_log_domain_level_set("evas_main", EINA_LOG_LEVEL_WARN);
218 eina_log_domain_level_set("eldbus", EINA_LOG_LEVEL_WARN);
219} 207}
220 208
221char *getDateTime(struct tm **nowOut, char *dateOut, time_t *timeOut) 209char *getDateTime(struct tm **nowOut, char *dateOut, time_t *timeOut)
@@ -242,9 +230,11 @@ char *getDateTime(struct tm **nowOut, char *dateOut, time_t *timeOut)
242} 230}
243 231
244 232
245static void _on_delete(Ecore_Evas *ee /*__UNUSED__*/) 233static void _on_done(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
246{ 234{
247 ecore_main_loop_quit(); 235// globals *ourGlobals = data;
236
237 elm_exit();
248} 238}
249 239
250static int openWindow(lua_State *L) 240static int openWindow(lua_State *L)
@@ -255,36 +245,16 @@ static int openWindow(lua_State *L)
255 ourGlobals = lua_touserdata(L, -1); 245 ourGlobals = lua_touserdata(L, -1);
256 lua_pop(L, 1); 246 lua_pop(L, 1);
257 247
258 if ((ourGlobals->eina = eina_init())) 248 loggingStartup(ourGlobals);
259 { 249 PI("GuiLua running as an application.\n");
260 loggingStartup(ourGlobals);
261
262 PI("GuiLua running as an application.\n");
263 250
264 if ((ourGlobals->ecore_evas = ecore_evas_init())) 251 if ((ourGlobals->win = elm_win_util_standard_add("GuiLua", "GuiLua test harness")))
265 { 252 {
266 if ((ourGlobals->edje = edje_init())) 253 evas_object_smart_callback_add(ourGlobals->win, "delete,request", _on_done, ourGlobals);
267 { 254 evas_object_resize(ourGlobals->win, WIDTH, HEIGHT);
268 /* this will give you a window with an Evas canvas under the first engine available */ 255 evas_object_move(ourGlobals->win, 0, 0);
269 ourGlobals->ee = ecore_evas_new(NULL, 0, 0, WIDTH, HEIGHT, NULL); 256 evas_object_show(ourGlobals->win);
270 if (ourGlobals->ee)
271 {
272 ourGlobals->canvas = ecore_evas_get(ourGlobals->ee);
273 ecore_evas_title_set(ourGlobals->ee, "GuiLua test harness");
274 ecore_evas_show(ourGlobals->ee);
275 ecore_evas_callback_delete_request_set(ourGlobals->ee, _on_delete);
276 }
277 else
278 PC("You got to have at least one evas engine built and linked up to ecore-evas for this to run properly.");
279 }
280 else
281 PC("Failed to init edje!");
282 }
283 else
284 PC("Failed to init ecore_evas!");
285 } 257 }
286 else
287 fprintf(stderr, "Failed to init eina!\n");
288 258
289 return 0; 259 return 0;
290} 260}
@@ -297,8 +267,8 @@ static int loopWindow(lua_State *L)
297 ourGlobals = lua_touserdata(L, -1); 267 ourGlobals = lua_touserdata(L, -1);
298 lua_pop(L, 1); 268 lua_pop(L, 1);
299 269
300 if (ourGlobals->canvas) 270 if (ourGlobals->win)
301 ecore_main_loop_begin(); 271 elm_run();
302 272
303 return 0; 273 return 0;
304} 274}
@@ -311,29 +281,17 @@ static int closeWindow(lua_State *L)
311 ourGlobals = lua_touserdata(L, -1); 281 ourGlobals = lua_touserdata(L, -1);
312 lua_pop(L, 1); 282 lua_pop(L, 1);
313 283
314 if (ourGlobals->eina) 284 if (ourGlobals->win)
285 evas_object_del(ourGlobals->win);
286
287 if (ourGlobals->logDom >= 0)
315 { 288 {
316 if (ourGlobals->ecore_evas) 289 eina_log_domain_unregister(ourGlobals->logDom);
317 { 290 ourGlobals->logDom = -1;
318 if (ourGlobals->edje)
319 {
320 if (ourGlobals->ee)
321 {
322 ecore_evas_free(ourGlobals->ee);
323 ourGlobals->ee = NULL;
324 }
325 ourGlobals->edje = edje_shutdown();
326 }
327 ourGlobals->ecore_evas = ecore_evas_shutdown();
328 }
329 if (ourGlobals->logDom >= 0)
330 {
331 eina_log_domain_unregister(ourGlobals->logDom);
332 ourGlobals->logDom = -1;
333 }
334 ourGlobals->eina = eina_shutdown();
335 } 291 }
336 292
293 elm_shutdown();
294
337 return 0; 295 return 0;
338} 296}
339 297
diff --git a/ClientHamr/GuiLua/GuiLua.h b/ClientHamr/GuiLua/GuiLua.h
index 127841f..6debac5 100644
--- a/ClientHamr/GuiLua/GuiLua.h
+++ b/ClientHamr/GuiLua/GuiLua.h
@@ -1,11 +1,9 @@
1 1
2#include <Eet.h>
3#include <Ecore.h>
4#include <Ecore_Evas.h>
5#include <Edje.h>
6#include <stdio.h> 2#include <stdio.h>
7#include <ctype.h> 3#include <ctype.h>
8 4
5#include <Elementary.h>
6
9#include <lua.h> 7#include <lua.h>
10#include <luajit.h> 8#include <luajit.h>
11#include <lualib.h> 9#include <lualib.h>
@@ -47,11 +45,9 @@ typedef enum
47 45
48struct _globals 46struct _globals
49{ 47{
50 Ecore_Evas *ee; // Our window. 48 Evas_Object *win; // Our Elm window.
51 Evas *canvas; // The canvas for drawing directly onto.
52 Evas_Object *bg; // Our background edje.
53 lua_State *L; // Our Lua state. 49 lua_State *L; // Our Lua state.
54 int eina, logDom, ecore_evas, edje; 50 int logDom; // Our logging domain.
55}; 51};
56 52
57 53
diff --git a/ClientHamr/GuiLua/build.sh b/ClientHamr/GuiLua/build.sh
index 0ef46b9..076c106 100755
--- a/ClientHamr/GuiLua/build.sh
+++ b/ClientHamr/GuiLua/build.sh
@@ -4,49 +4,17 @@ export LOCALDIR=`pwd`
4 4
5# No need for a make file, or dependencies, the entire thing takes only a few seconds to build. 5# No need for a make file, or dependencies, the entire thing takes only a few seconds to build.
6 6
7# This assumes you have EFL installed in one of two standard places.
8if [ -d "/opt/EFL" ]
9then
10 export E17DIR="/opt/EFL"
11else
12 export E17DIR="/usr"
13fi
14 7
15CFLAGS="-g -Wall -I include -I $LOCALDIR" 8CFLAGS="-g -Wall -I include -I $LOCALDIR"
16CFLAGS="$CFLAGS -I ../../libraries" 9CFLAGS="$CFLAGS -I ../../libraries"
17#CFLAGS="$CFLAGS -I ../../libraries/LuaJIT-2.0.2/src"
18CFLAGS="$CFLAGS $(pkg-config --cflags luajit)" 10CFLAGS="$CFLAGS $(pkg-config --cflags luajit)"
19#CFLAGS="$CFLAGS -I /usr/include/lua5.1" 11CFLAGS="$CFLAGS $(pkg-config --cflags elementary)"
20CFLAGS="$CFLAGS -I $E17DIR/include/eo-1" 12CFLAGS="$CFLAGS -DPACKAGE_BIN_DIR=\"$LOCALDIR\""
21CFLAGS="$CFLAGS -I $E17DIR/include/eina-1" 13CFLAGS="$CFLAGS -DPACKAGE_LIB_DIR=\"$LOCALDIR\""
22CFLAGS="$CFLAGS -I $E17DIR/include/eina-1/eina"
23CFLAGS="$CFLAGS -I $E17DIR/include/eet-1"
24CFLAGS="$CFLAGS -I $E17DIR/include/embryo-1"
25CFLAGS="$CFLAGS -I $E17DIR/include/edje-1"
26CFLAGS="$CFLAGS -I $E17DIR/include/evas-1"
27CFLAGS="$CFLAGS -I $E17DIR/include/ecore-1"
28CFLAGS="$CFLAGS -I $E17DIR/include/efl-1"
29CFLAGS="$CFLAGS -I $E17DIR/include/ecore-con-1"
30CFLAGS="$CFLAGS -I $E17DIR/include/ecore-evas-1"
31CFLAGS="$CFLAGS -I $E17DIR/include/ecore-file-1"
32CFLAGS="$CFLAGS -I $E17DIR/include"
33CFLAGS="$CFLAGS -DPACKAGE_DATA_DIR=\"$LOCALDIR\" $CFLAGOPTS" 14CFLAGS="$CFLAGS -DPACKAGE_DATA_DIR=\"$LOCALDIR\" $CFLAGOPTS"
34 15
35#LDFLAGS="-L ../../libraries/LuaJIT-2.0.2/src -L lib -L /usr/lib -L /lib -L $E17DIR/lib" 16LDFLAGS="-L $LOCALDIR $(pkg-config --libs-only-L luajit) -L lib -L /usr/lib -L /lib"
36#libs="-leo -lecore -levas -ledje -lembryo -leet -leina -lluajit -lpthread -lm" 17libs="$(pkg-config --cflags --libs elementary) $(pkg-config --libs luajit) -lpthread -lm -ldl"
37LDFLAGS="-L $LOCALDIR $(pkg-config --libs-only-L luajit) -L lib -L /usr/lib -L /lib -L $E17DIR/lib"
38libs="-leo -lecore -levas -ledje -lembryo -leet -leina $(pkg-config --libs luajit) -lpthread -lm -ldl"
39#LDFLAGS="-L /usr/lib/lua/5.1 -L lib -L /usr/lib -L /lib -L $E17DIR/lib"
40#libs="-lecore -levas -ledje -lembryo -leet -leina -llua5.1 -lpthread -lm"
41# These need to be added to libs if linking staticaly, though some parts of EFL don't like that.
42#-lecore_evas \
43#-lecore_file \
44#-ldl \
45#-lfontconfig \
46#-lfreetype \
47#-lexpat \
48#-lrt \
49#-lz
50 18
51echo "clean" 19echo "clean"
52rm -f test_c.so GuiLua.o libGuiLua.so skang 20rm -f test_c.so GuiLua.o libGuiLua.so skang
diff --git a/ClientHamr/GuiLua/skang.c b/ClientHamr/GuiLua/skang.c
index ed92ff9..facc239 100644
--- a/ClientHamr/GuiLua/skang.c
+++ b/ClientHamr/GuiLua/skang.c
@@ -1,11 +1,16 @@
1#include "GuiLua.h" 1#include "GuiLua.h"
2 2
3 3
4int main(int argc, char **argv) 4EAPI_MAIN int elm_main(int argc, char **argv)
5{ 5{
6 int result = EXIT_FAILURE; 6 elm_app_compile_bin_dir_set(PACKAGE_BIN_DIR);
7 elm_app_compile_data_dir_set(PACKAGE_DATA_DIR);
8 elm_app_compile_lib_dir_set(PACKAGE_LIB_DIR);
9 elm_app_info_set(elm_main, "GuiLua", "skang.lua");
7 10
8 GuiLuaDo(argc, argv); 11 GuiLuaDo(argc, argv);
9 12
10 return result; 13 return 0;
11} 14}
15
16ELM_MAIN()