Difference between revisions of "LlList2Rot"

From Second Life Wiki
Jump to navigation Jump to search
m
m
Line 7: Line 7:
|spec
|spec
|caveats=*When used to typecast from a string it will result in a [[ZERO_ROTATION]]
|caveats=*When used to typecast from a string it will result in a [[ZERO_ROTATION]]
**A true typecast will solves this: ([[rotation]]){{LSLG|llList2String}}(src, index);
**A true typecast will solves this: ([[rotation]])[[llList2String]](src, index);
|constants
|constants
|examples=
|examples=
<lsl>
<lsl>// Best viewed in Chat History (ctrl-h)
// Best viewed in Chat History (ctrl-h)
default
default
{
{
Line 17: Line 16:
     {
     {
         list my_list = ["a", 1, 2.0, <1,2,3>, <1,2,3,4>, llGetOwner()];
         list my_list = ["a", 1, 2.0, <1,2,3>, <1,2,3,4>, llGetOwner()];
         integer i;
         integer i = ~llGetListLength(my_list);
        for (i=0;i<llGetListLength(my_list); ++i)
        while (++i)
         {
         {
             llOwnerSay("string=" + llList2String(my_list,i)
             llOwnerSay("string=" + llList2String(my_list,i)
Line 28: Line 27:
         }
         }
     }
     }
}
}</lsl>
</lsl>
|helpers
|helpers
|also_functions={{LSL DefineRow||{{LSLG|llGetListEntryType}}|}}
|also_functions=
{{LSL DefineRow||{{LSLG|llList2String}}|}}
{{LSL DefineRow||[[llGetListEntryType]]|}}
{{LSL DefineRow||[[llList2String]]|}}
|also_events
|also_events
|also_tests
|also_tests
|also_articles
|also_articles
|notes
|notes
|bugs=
|issues=
{{LSL Bug|SVC-798|Perform typecasting with all {{LSLGC|List/Read Element|llList2*}} functions}}
{{LSL Bug|SVC-798|Perform typecasting with all {{LSLGC|List/Read Element|llList2*}} functions}}
|cat1=List
|cat1=List

Revision as of 20:28, 30 June 2008

Summary

Function: rotation llList2Rot( list src, integer index );
0.0 Forced Delay
10.0 Energy

Returns a rotation that is at index in src.

• list src List containing the element of interest.
• integer index Index of the element of interest.

index supports negative indexes.
If index describes a location not in src then <span title="<0.0, 0.0, 0.0, 1.0>">ZERO_ROTATION is returned.
If the type of the element at index in src is not a rotation then <span title="<0.0, 0.0, 0.0, 1.0>">ZERO_ROTATION is returned.
Here is a workaround: (rotation)llList2String(src, index);

Specification

Index Positive Negative
First 0 -length
Last length - 1 -1

Indexes

  • Positive indexes count from the beginning, the first item being indexed as 0, the last as (length - 1).
  • Negative indexes count from the far end, the first item being indexed as -length, the last as -1.

Caveats

  • If index is out of bounds the script continues to execute without an error message.
  • When used to typecast from a string it will result in a ZERO_ROTATION

Examples

<lsl>// Best viewed in Chat History (ctrl-h) default {

   state_entry()
   {
       list my_list = ["a", 1, 2.0, <1,2,3>, <1,2,3,4>, llGetOwner()];
       integer i = ~llGetListLength(my_list);
       while (++i)
       {
           llOwnerSay("string=" + llList2String(my_list,i)
                       + "\n   integer=" + (string)llList2Integer(my_list,i)
                       + "\n   float=" + (string)llList2Float(my_list,i)
                       + "\n   vector=" + (string)llList2Vector(my_list,i)
                       + "\n   rot=" + (string)llList2Rot(my_list,i)
                       + "\n   key=" + (string)llList2Key(my_list,i) );
       }
   }
}</lsl>

See Also

Functions

•  llGetListEntryType
•  llList2String

Articles

•  Negative Index

Deep Notes

Signature

function rotation llList2Rot( list src, integer index );