aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/love
diff options
context:
space:
mode:
authorDavid Walter Seikel2016-01-19 02:40:23 +1000
committerDavid Walter Seikel2016-01-19 02:40:23 +1000
commit022ec48aa446dce7fb97023a206d0f1479e63d82 (patch)
treef27cf4215ecc904c0ff5f9449fddf947519a7dbe /src/love
parentFix up events. (diff)
downloadSledjHamr-022ec48aa446dce7fb97023a206d0f1479e63d82.zip
SledjHamr-022ec48aa446dce7fb97023a206d0f1479e63d82.tar.gz
SledjHamr-022ec48aa446dce7fb97023a206d0f1479e63d82.tar.bz2
SledjHamr-022ec48aa446dce7fb97023a206d0f1479e63d82.tar.xz
Clean up LSL command and argument passing.
Diffstat (limited to 'src/love')
-rw-r--r--src/love/love.c123
1 files changed, 57 insertions, 66 deletions
diff --git a/src/love/love.c b/src/love/love.c
index e6f5b6e..9ad9842 100644
--- a/src/love/love.c
+++ b/src/love/love.c
@@ -199,14 +199,14 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
199 199
200//PD("COMMAND - %s - %s", SID, command); 200//PD("COMMAND - %s - %s", SID, command);
201 me = eina_hash_find(ourGlobals->scripts, SID); 201 me = eina_hash_find(ourGlobals->scripts, SID);
202 if (0 == strncmp(command, "compilerWarning(", 16)) 202 if (0 == strcmp(command, "compilerWarning"))
203 { 203 {
204 char *temp; 204 char *temp;
205 char *line; 205 char *line;
206 char *column; 206 char *column;
207 char *text; 207 char *text;
208 208
209 strcpy(buf, &command[16]); 209 strcpy(buf, arguments);
210 temp = buf; 210 temp = buf;
211 line = temp; 211 line = temp;
212 while (',' != temp[0]) 212 while (',' != temp[0])
@@ -224,14 +224,14 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
224 if (me) 224 if (me)
225 me->warnings++; 225 me->warnings++;
226 } 226 }
227 else if (0 == strncmp(command, "compilerError(", 14)) 227 else if (0 == strcmp(command, "compilerError"))
228 { 228 {
229 char *temp; 229 char *temp;
230 char *line; 230 char *line;
231 char *column; 231 char *column;
232 char *text; 232 char *text;
233 233
234 strcpy(buf, &command[14]); 234 strcpy(buf, arguments);
235 temp = buf; 235 temp = buf;
236 line = temp; 236 line = temp;
237 while (',' != temp[0]) 237 while (',' != temp[0])
@@ -249,9 +249,8 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
249 if (me) 249 if (me)
250 me->bugs++; 250 me->bugs++;
251 } 251 }
252 else if (0 == strcmp(command, "compiled(false)")) 252 else if (0 == strcmp(command, "compiled"))
253 { 253 {
254// PE("The compile of %s failed!", SID);
255 if (me) 254 if (me)
256 { 255 {
257 struct timeval now; 256 struct timeval now;
@@ -263,67 +262,61 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
263 PI("Compile speed scripts: %d time: %fs total: %f scripts per second", compiledCount, total, compiledCount / total); 262 PI("Compile speed scripts: %d time: %fs total: %f scripts per second", compiledCount, total, compiledCount / total);
264 } 263 }
265 } 264 }
266 }
267 else if (0 == strcmp(command, "compiled(true)"))
268 {
269 if (me)
270 {
271 struct timeval now;
272 265
273 compiledCount++; 266 if ('t' == arguments[0])
274 if (compiledCount == scriptCount) 267 {
275 {
276 float total = timeDiff(&now, &startTime);
277 PI("Compile speed scripts: %d time: %fs total: %f scripts per second", compiledCount, total, compiledCount / total);
278 }
279 }
280//PD("About to run %s", me->fileName); 268//PD("About to run %s", me->fileName);
281 send2(ourGlobals->serverLuaSL, SID, "run(%s)", me->fileName); 269 send2(ourGlobals->serverLuaSL, SID, "run(%s)", me->fileName);
270 }
271 else
272 {
273// PE("The compile of %s failed!", SID);
274 }
282 } 275 }
283 else 276 else
284 { 277 {
285//PD("FAKING (maybe) %s", command); 278//PD("FAKING (maybe) %s", command);
286 // Send back some random or fixed values for testing. 279 // Send back some random or fixed values for testing.
287 if (0 == strcmp(command, "llGetKey()")) 280 if (0 == strcmp(command, "llGetKey"))
288 send2(ourGlobals->serverLuaSL, SID, "return \"%08lx-%04lx-%04lx-%04lx-%012lx\"", random(), random() % 0xFFFF, random() % 0xFFFF, random() % 0xFFFF, random()); 281 send2(ourGlobals->serverLuaSL, SID, "return \"%08lx-%04lx-%04lx-%04lx-%012lx\"", random(), random() % 0xFFFF, random() % 0xFFFF, random() % 0xFFFF, random());
289 else if (0 == strcmp(command, "llGetOwner()")) 282 else if (0 == strcmp(command, "llGetOwner"))
290 send2(ourGlobals->serverLuaSL, SID, "return \"%s\"", ownerKey); 283 send2(ourGlobals->serverLuaSL, SID, "return \"%s\"", ownerKey);
291 else if (0 == strcmp(command, "llGetPermissionsKey()")) 284 else if (0 == strcmp(command, "llGetPermissionsKey"))
292 send2(ourGlobals->serverLuaSL, SID, "return \"%s\"", ownerKey); 285 send2(ourGlobals->serverLuaSL, SID, "return \"%s\"", ownerKey);
293 else if (0 == strncmp(command, "llRequestPermissions(", 21)) 286 else if (0 == strcmp(command, "llRequestPermissions"))
294 PI("Faked %s", command); 287 PI("Faked %s(%s", command, arguments);
295 else if (0 == strcmp(command, "llGetPos()")) 288 else if (0 == strcmp(command, "llGetPos"))
296 send2(ourGlobals->serverLuaSL, SID, "return {x=128.0, y=128.0, z=128.0}"); 289 send2(ourGlobals->serverLuaSL, SID, "return {x=128.0, y=128.0, z=128.0}");
297 else if (0 == strcmp(command, "llGetRot()")) 290 else if (0 == strcmp(command, "llGetRot"))
298 send2(ourGlobals->serverLuaSL, SID, "return {x=0.0, y=0.0, z=0.0, s=1.0}"); 291 send2(ourGlobals->serverLuaSL, SID, "return {x=0.0, y=0.0, z=0.0, s=1.0}");
299 else if (0 == strcmp(command, "llGetFreeMemory()")) 292 else if (0 == strcmp(command, "llGetFreeMemory"))
300 send2(ourGlobals->serverLuaSL, SID, "return 654321"); 293 send2(ourGlobals->serverLuaSL, SID, "return 654321");
301 else if (0 == strcmp(command, "llGetObjectDesc()")) 294 else if (0 == strcmp(command, "llGetObjectDesc"))
302 send2(ourGlobals->serverLuaSL, SID, "return \"\""); 295 send2(ourGlobals->serverLuaSL, SID, "return \"\"");
303 else if (0 == strncmp(command, "llGetAlpha(", 11)) 296 else if (0 == strcmp(command, "llGetAlpha"))
304 send2(ourGlobals->serverLuaSL, SID, "return 1.0"); 297 send2(ourGlobals->serverLuaSL, SID, "return 1.0");
305 else if (0 == strcmp(command, "llGetInventoryNumber(7)")) 298 else if (0 == strcmp(command, "llGetInventoryNumber") && (0 == strcmp(arguments, "7)")))
306 send2(ourGlobals->serverLuaSL, SID, "return 3"); 299 send2(ourGlobals->serverLuaSL, SID, "return 3");
307 else if (0 == strcmp(command, "llGetLinkNumber()")) 300 else if (0 == strcmp(command, "llGetLinkNumber"))
308 send2(ourGlobals->serverLuaSL, SID, "return 1"); 301 send2(ourGlobals->serverLuaSL, SID, "return 1");
309 else if (0 == strcmp(command, "llGetInventoryName(7, 2)")) 302 else if (0 == strcmp(command, "llGetInventoryName") && (0 == strcmp(arguments, "7, 2)")))
310 send2(ourGlobals->serverLuaSL, SID, "return \".readme\""); 303 send2(ourGlobals->serverLuaSL, SID, "return \".readme\"");
311 else if (0 == strcmp(command, "llGetInventoryName(7, 1)")) 304 else if (0 == strcmp(command, "llGetInventoryName") && (0 == strcmp(arguments, "7, 1)")))
312 send2(ourGlobals->serverLuaSL, SID, "return \".POSITIONS\""); 305 send2(ourGlobals->serverLuaSL, SID, "return \".POSITIONS\"");
313 else if (0 == strcmp(command, "llGetInventoryName(7, 0)")) 306 else if (0 == strcmp(command, "llGetInventoryName") && (0 == strcmp(arguments, "7, 0)")))
314 send2(ourGlobals->serverLuaSL, SID, "return \".MENUITEMS\""); 307 send2(ourGlobals->serverLuaSL, SID, "return \".MENUITEMS\"");
315 else if (0 == strncmp(command, "llListen(", 9)) 308 else if (0 == strcmp(command, "llListen"))
316 { 309 {
317 PI("Faked %s", command); 310 PI("Faked %s(%s", command, arguments);
318 send2(ourGlobals->serverLuaSL, SID, "return %d", random()); 311 send2(ourGlobals->serverLuaSL, SID, "return %d", random());
319 } 312 }
320 else if (0 == strncmp(command, "llSameGroup(", 12)) 313 else if (0 == strcmp(command, "llSameGroup"))
321 send2(ourGlobals->serverLuaSL, SID, "return true"); 314 send2(ourGlobals->serverLuaSL, SID, "return true");
322 else if (0 == strncmp(command, "llKey2Name(", 11)) 315 else if (0 == strcmp(command, "llKey2Name"))
323 { 316 {
324 char *temp; 317 char *temp;
325 318
326 strcpy(buf, &command[12]); 319 strcpy(buf, arguments);
327 temp = buf; 320 temp = buf;
328 while (')' != temp[0]) 321 while (')' != temp[0])
329 temp++; 322 temp++;
@@ -342,57 +335,55 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
342 // Extantz registering any channel it wants to listen to, mostly for client side scripts. 335 // Extantz registering any channel it wants to listen to, mostly for client side scripts.
343 // Extantz is then only responsible for the registered channels, it can do what it likes with them. 336 // Extantz is then only responsible for the registered channels, it can do what it likes with them.
344 // Dialogs, notifications, and other stuff goes through some other functions. 337 // Dialogs, notifications, and other stuff goes through some other functions.
345 else if (0 == strncmp(command, "llOwnerSay(", 11)) 338 else if (0 == strcmp(command, "llOwnerSay"))
346 { 339 {
347 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 340 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
348 else PW("No where to send %s", command); 341 else PW("No where to send %s(%s", command, arguments);
349 } 342 }
350 else if (0 == strncmp(command, "llWhisper(", 10)) 343 else if (0 == strcmp(command, "llWhisper"))
351 { 344 {
352 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 345 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
353 else PW("No where to send %s", command); 346 else PW("No where to send %s(%s", command, arguments);
354 } 347 }
355 else if (0 == strncmp(command, "llRegionSay(", 12)) 348 else if (0 == strcmp(command, "llRegionSay"))
356 { 349 {
357 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 350 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
358 else PW("No where to send %s", command); 351 else PW("No where to send %s(%s", command, arguments);
359 } 352 }
360 else if (0 == strncmp(command, "llSay(", 6)) 353 else if (0 == strcmp(command, "llSay"))
361 { 354 {
362 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 355 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
363 else PW("No where to send %s", command); 356 else PW("No where to send %s(%s", command, arguments);
364 } 357 }
365 else if (0 == strncmp(command, "llShout(", 8)) 358 else if (0 == strcmp(command, "llShout"))
366 { 359 {
367 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 360 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
368 else PW("No where to send %s", command); 361 else PW("No where to send %s(%s", command, arguments);
369 // TODO - Temporary so we have a place to log stuff from LSL. 362 // TODO - Temporary so we have a place to log stuff from LSL.
370 PD("SHOUTING %s", command); 363 PD("SHOUTING %s", command);
371 } 364 }
372 else if (0 == strncmp(command, "llDialog(", 9)) 365 else if (0 == strcmp(command, "llDialog"))
373 { 366 {
374 if (ourGlobals->client) send2(ourGlobals->client, SID, command); 367 if (ourGlobals->client) send2(ourGlobals->client, SID, "%s(%s", command, arguments);
375 else PW("No where to send %s", command);
376 } 368 }
377 else if (0 == strncmp(command, "llMessageLinked(", 16)) 369 else if (0 == strcmp(command, "llMessageLinked"))
378 { 370 {
379 Eina_Iterator *scripts; 371 Eina_Iterator *scripts;
380 LoveScript *me; 372 LoveScript *me;
381
382 // TODO - For now, just send it to everyone. 373 // TODO - For now, just send it to everyone.
383 scripts = eina_hash_iterator_data_new(ourGlobals->scripts); 374 scripts = eina_hash_iterator_data_new(ourGlobals->scripts);
384 while(eina_iterator_next(scripts, (void **) &me)) 375 while(eina_iterator_next(scripts, (void **) &me))
385 { 376 {
386 send2(ourGlobals->serverLuaSL, me->SID, "events.link_message%s", &command[15]); 377 send2(ourGlobals->serverLuaSL, me->SID, "events.link_message(%s", arguments);
387 } 378 }
388 eina_iterator_free(scripts); 379 eina_iterator_free(scripts);
389 } 380 }
390 else if (0 == strncmp(command, "llGetNotecardLine(", 18)) 381 else if (0 == strcmp(command, "llGetNotecardLine"))
391 { 382 {
392 char *notecard, *temp, *line, key[PATH_MAX]; 383 char *notecard, *temp, *line, key[PATH_MAX];
393 int lineNo, fd; 384 int lineNo, fd;
394 385
395 strcpy(buf, &command[19]); 386 strcpy(buf, &arguments[1]);
396 notecard = buf; 387 notecard = buf;
397 temp = notecard; 388 temp = notecard;
398 while ('"' != temp[0]) 389 while ('"' != temp[0])
@@ -462,7 +453,7 @@ static Eina_Bool LuaSLParser(void *data, Connection *conn, char *SID, char *comm
462 453
463 } 454 }
464 else 455 else
465 PI("Script %s sent command %s", SID, command); 456 PI("Script %s sent command %s(%s", SID, command, arguments);
466 } 457 }
467 458
468 return ECORE_CALLBACK_RENEW; 459 return ECORE_CALLBACK_RENEW;
@@ -502,7 +493,7 @@ static Eina_Bool clientParser(void *data, Connection *conn, char *SID, char *com
502{ 493{
503 gameGlobals *ourGlobals = data; 494 gameGlobals *ourGlobals = data;
504 495
505 if (0 == strncmp(command, "events.touch_start(", 19)) 496 if (0 == strcmp(command, "events.touch_start"))
506 { 497 {
507 Eina_Iterator *scripts; 498 Eina_Iterator *scripts;
508 LoveScript *me; 499 LoveScript *me;
@@ -517,7 +508,7 @@ static Eina_Bool clientParser(void *data, Connection *conn, char *SID, char *com
517 } 508 }
518 eina_iterator_free(scripts); 509 eina_iterator_free(scripts);
519 } 510 }
520 else if (0 == strncmp(command, "events.listen(", 14)) 511 else if (0 == strcmp(command, "events.listen"))
521 { 512 {
522 Eina_Iterator *scripts; 513 Eina_Iterator *scripts;
523 LoveScript *me; 514 LoveScript *me;