diff options
author | David Walter Seikel | 2016-01-19 02:40:23 +1000 |
---|---|---|
committer | David Walter Seikel | 2016-01-19 02:40:23 +1000 |
commit | 022ec48aa446dce7fb97023a206d0f1479e63d82 (patch) | |
tree | f27cf4215ecc904c0ff5f9449fddf947519a7dbe /src/love | |
parent | Fix up events. (diff) | |
download | SledjHamr-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.c | 123 |
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; |