Debugging Tips

From Second Life Wiki
Revision as of 10:17, 23 June 2012 by Myopic Mole (talk | contribs) (Created page with "One of the hardest things with scripting anything non trivial in LSL, especially if you come from an software development environment where you're used to combined editor and deb…")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

One of the hardest things with scripting anything non trivial in LSL, especially if you come from an software development environment where you're used to combined editor and debugger, is the seeming inability to debug LSL code.

Simple Example

The solution is to define a simple debugging utility function as follows.

<lsl> notify(string msg) { llOwnerSay(msg); } </lsl>

then whenever we need to check the value of a variable simple call

<lsl> notify("your debug message here"); </lsl>

don't forget to typecast as necessary, for example:

<lsl> integer a = 3; integer b = 4; integer result = a * b; notify((string)result); </lsl>

This allows us to reuse the same function for reporting anything to the owner of the object, rather than using public chat. The advantage to doing this is we can comment out a single line in the code function as follows to disable all debugging, or we can search and replace and instance of "notify" with "//notify".

<lsl> notify(string msg) { //llOwnerSay(msg); } </lsl>

if you're working with list use something along the lines of:

notify(llList2String(listName, integerIndex)); // notification contains one list element or notify(llDumpList2String(listName, ",")); notification contains entire list as a string

Error Reporting and Debugging

We can use the same concept for tracking issues after the code is complete as follows

<lsl> notify(string genus, string msg) { key creator = "a822ff2b-ff02-461d-b45d-dcd10a2de0c2"; //genus = "off" //uncoment this line to turn notifications off if (genus == "dbg") { llInstantMessage(creator, "DEBUG: " + msg); } else if (genus == "err") { llOwnerSay("ERROR: " + msg); llInstantMessage(creator, "ERROR: " + msg + " in object " + llGetObjectName() + " that belongs to " + llKey2Name(llGetOwner()) + " in region " + llGetRegionName()); } else if (genus == "info") { llOwnerSay(msg); } else { //do nothing, notifications were turned off } } </lsl>

We're doing a number of things here: handling different kids of messages, informational for normal running, error reporting to the owner and creator and debug messages. To turn off debug simply comment out the debug line as shown in the code, and uncomment the genus="off" line to disable all notifications.

We're using llOwner for the current owner and llInstantMessage for contacting the script creator that will continue to work after ownership has passed - you just have insert your own key at the top.

Other mechanism that could be used include llEmail or llHTTPRequest to post a message to an external logging system perhaps.