aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--src/extantz/extantz.c24
-rw-r--r--src/extantz/extantz.h2
-rw-r--r--src/extantz/scenri.c2
-rw-r--r--src/love/love.c61
4 files changed, 38 insertions, 51 deletions
diff --git a/src/extantz/extantz.c b/src/extantz/extantz.c
index 848bc9a..e16db3c 100644
--- a/src/extantz/extantz.c
+++ b/src/extantz/extantz.c
@@ -83,6 +83,27 @@ static Eina_Bool _del(void *data, int type, Ecore_Con_Event_Server_Del *ev)
83 return ECORE_CALLBACK_RENEW; 83 return ECORE_CALLBACK_RENEW;
84} 84}
85 85
86static void _onWorldClick(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void *einfo)
87{
88 Evas_3D_Node *n = data;
89// Evas_Event_Mouse_Down *ev = einfo;
90
91 if (n)
92 {
93 char *name = NULL;
94
95 name = evas_object_data_get(n, "Name");
96 if (strcmp("cube", name) == 0)
97 {
98 char SID[64];
99
100 // CUBE_UUID.events.touch_start(1), but we just make one up for now.
101 snprintf(SID, sizeof(SID), "%08lx-%04lx-%04lx-%04lx-%012lx", random(), random() % 0xFFFF, random() % 0xFFFF, random() % 0xFFFF, random());
102 sendForth(ourGlobals.server, SID, "events.touch_start(1)");
103 }
104 }
105}
106
86static void gldata_init(GLData *gld) 107static void gldata_init(GLData *gld)
87{ 108{
88 gld->useIrr = USE_IRR; 109 gld->useIrr = USE_IRR;
@@ -644,6 +665,9 @@ EAPI_MAIN int elm_main(int argc, char **argv)
644 else 665 else
645 PC("Failed to connect to server!"); 666 PC("Failed to connect to server!");
646 667
668 // Setup our callback for clicking in world.
669 ourGlobals.scene->clickCb = _onWorldClick;
670
647 elm_run(); 671 elm_run();
648 672
649 if (ourGlobals.server) ecore_con_server_del(ourGlobals.server); 673 if (ourGlobals.server) ecore_con_server_del(ourGlobals.server);
diff --git a/src/extantz/extantz.h b/src/extantz/extantz.h
index 0bbf76f..bfab4cb 100644
--- a/src/extantz/extantz.h
+++ b/src/extantz/extantz.h
@@ -158,6 +158,8 @@ typedef struct _Scene_Data
158 Evas_3D_Texture *texture_diffuse; 158 Evas_3D_Texture *texture_diffuse;
159 159
160 cameraMove *move; 160 cameraMove *move;
161
162 Evas_Object_Event_Cb clickCb;
161} Scene_Data; 163} Scene_Data;
162 164
163// Elm GL view related data here. 165// Elm GL view related data here.
diff --git a/src/extantz/scenri.c b/src/extantz/scenri.c
index 051d39f..eaec88e 100644
--- a/src/extantz/scenri.c
+++ b/src/extantz/scenri.c
@@ -75,6 +75,7 @@ static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void
75 { 75 {
76 name = evas_object_data_get(n, "Name"); 76 name = evas_object_data_get(n, "Name");
77 printf("Picked : "); 77 printf("Picked : ");
78 if (scene->clickCb) scene->clickCb(n, e, o, einfo);
78 } 79 }
79 else 80 else
80 printf("Not picked : "); 81 printf("Not picked : ");
@@ -83,6 +84,7 @@ static void _on_mouse_down(void *data, Evas *e EINA_UNUSED, Evas_Object *o, void
83 84
84 printf("output(%d, %d) canvas(%d, %d) object(%d, %d) scene(%f, %f) texcoord(%f, %f) node(%p) %s mesh(%p)\n", 85 printf("output(%d, %d) canvas(%d, %d) object(%d, %d) scene(%f, %f) texcoord(%f, %f) node(%p) %s mesh(%p)\n",
85 ev->output.x, ev->output.y, ev->canvas.x, ev->canvas.y, obj_x, obj_y, scene_x, scene_y, s, t, n, name, m); 86 ev->output.x, ev->output.y, ev->canvas.x, ev->canvas.y, obj_x, obj_y, scene_x, scene_y, s, t, n, name, m);
87
86} 88}
87 89
88Scene_Data *scenriAdd(Evas_Object *win) 90Scene_Data *scenriAdd(Evas_Object *win)
diff --git a/src/love/love.c b/src/love/love.c
index e30c292..5fe3c84 100644
--- a/src/love/love.c
+++ b/src/love/love.c
@@ -372,7 +372,7 @@ static Eina_Bool _addClient(void *data, int type, Ecore_Con_Event_Client_Add *ev
372 372
373static Eina_Bool _dataClient(void *data, int type, Ecore_Con_Event_Client_Data *ev) 373static Eina_Bool _dataClient(void *data, int type, Ecore_Con_Event_Client_Data *ev)
374{ 374{
375// gameGlobals *ourGlobals = data; 375 gameGlobals *ourGlobals = data;
376// char buf[PATH_MAX]; 376// char buf[PATH_MAX];
377 char SID[PATH_MAX]; 377 char SID[PATH_MAX];
378 const char *command; 378 const char *command;
@@ -393,63 +393,22 @@ static Eina_Bool _dataClient(void *data, int type, Ecore_Con_Event_Client_Data *
393 ext[0] = '\0'; 393 ext[0] = '\0';
394 command = ext + 1; 394 command = ext + 1;
395 395
396#if 0 // Replace this with code to parse what viewers send. 396 if (0 == strncmp(command, "events.touch_start(", 19))
397 if (0 == strncmp(command, "compile(", 8))
398 {
399 char *temp;
400 char *file;
401
402 strcpy(buf, &command[8]);
403 temp = buf;
404 file = temp;
405 while (')' != temp[0])
406 temp++;
407 temp[0] = '\0';
408
409 PD("Compiling %s, %s.", SID, file);
410 if (compileLSL(ourGlobals, ev->client, SID, file, FALSE))
411 {
412 script *me = calloc(1, sizeof(script));
413
414 gettimeofday(&me->startTime, NULL);
415 strncpy(me->SID, SID, sizeof(me->SID));
416 strncpy(me->fileName, file, sizeof(me->fileName));
417 me->game = ourGlobals;
418 me->client = ev->client;
419 eina_hash_add(ourGlobals->scripts, me->SID, me);
420 eina_hash_add(ourGlobals->names, me->fileName, me);
421 sendBack(ev->client, SID, "compiled(true)");
422 }
423 else
424 sendBack(ev->client, SID, "compiled(false)");
425 }
426 else if (0 == strcmp(command, "run()"))
427 { 397 {
398 Eina_Iterator *scripts;
428 script *me; 399 script *me;
429 char buf[PATH_MAX];
430 400
431 me = eina_hash_find(ourGlobals->scripts, SID); 401 // TODO - For now, just send it to everyone.
432 if (me) 402 scripts = eina_hash_iterator_data_new(ourGlobals->scripts);
403 while(eina_iterator_next(scripts, (void **) &me))
433 { 404 {
434 sprintf(buf, "%s.lua.out", me->fileName); 405 sendForth(ourGlobals->serverLuaSL, me->SID, "events.detectedKeys({\"%s\"})", ownerKey);
435 newProc(buf, TRUE, me); 406 sendForth(ourGlobals->serverLuaSL, me->SID, "events.detectedNames({\"%s\"})", ownerName);
407 sendForth(ourGlobals->serverLuaSL, me->SID, "events.touch_start(1)");
436 } 408 }
437 } 409 }
438 else if (0 == strcmp(command, "exit()"))
439 {
440 PD("Told to exit.");
441 ecore_main_loop_quit();
442 }
443 else 410 else
444 { 411 PW("Unknown command from client - %s", command);
445 const char *status = NULL;
446
447 status = sendToChannel(ourGlobals, SID, command);
448 if (status)
449 PE("Error sending command %s to script %s : %s", command, SID, status);
450 }
451#endif
452
453 } 412 }
454 413
455 // Get the next blob to check it. 414 // Get the next blob to check it.