Difference between revisions of "ListCompare"
Jump to navigation
Jump to search
(I'm pretty sure you need the zero condition test but i'm leaving it until i can test the behavior.) |
|||
Line 17: | Line 17: | ||
<lsl>integer ListCompare(list a, list b) { | <lsl>integer ListCompare(list a, list b) { | ||
integer aL = a != []; | integer aL = a != []; | ||
if (aL != (b != [])) return | if (aL != (b != [])) return FALSE; | ||
if (aL == 0) return | if (aL == 0) return TRUE; | ||
return !llListFindList((a = []) + a, (b = []) + b); | return !llListFindList((a = []) + a, (b = []) + b); | ||
}</lsl> | }</lsl> |
Revision as of 10:57, 4 January 2009
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Summary
Function: integer ListCompare( list a, list b );
Efficiently compares two lists for equality (same contents).
Returns an integer TRUE if the lists are equal, FALSE if not.
• list | a | – | The first list to compare. | |
• list | b | – | The second list to compare. |
Examples
<lsl>integer r = ListCompare([1, 2.0, "3"], [1, 2.0, "3"]); // Returns TRUE integer s = ListCompare([1, 2.0, 3], [1, 2.0, "3"]); // Returns FALSE
integer t = ListCompare([], [1, 2.0, "3"]); // Returns FALSE</lsl>Implementation
<lsl>integer ListCompare(list a, list b) {
integer aL = a != []; if (aL != (b != [])) return FALSE; if (aL == 0) return TRUE; return !llListFindList((a = []) + a, (b = []) + b);
}</lsl>