Difference between revisions of "ListCompare"
Jump to navigation
Jump to search
m (Wanted to add that the == 0 is not required, as the logical negation of the function means that any non-zero value will evaluate to FALSE, while /only/ zero will evaluate to TRUE.) |
|||
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 0; | ||
if (aL == 0) return | if (aL == 0) return 1; | ||
return !llListFindList((a = []) + a, (b = []) + b); | return !llListFindList((a = []) + a, (b = []) + b); | ||
}</lsl> | }</lsl> |
Revision as of 18:28, 17 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 0; if (aL == 0) return 1; return !llListFindList((a = []) + a, (b = []) + b);
}</lsl>