Difference between revisions of "LlStringLength"
Jump to navigation
Jump to search
All Issues ~ Search JIRA for related Bugs
m |
(*To quickly find out the number of bytes (in UTF-8), you can use llStringToBase64 (see also snippet there)) |
||
(5 intermediate revisions by 5 users not shown) | |||
Line 4: | Line 4: | ||
|func_footnote | |func_footnote | ||
|func_desc | |func_desc | ||
|return_text=that is the number of characters in '''str''' | |return_text=that is the number of characters in '''str'''. | ||
|spec | |spec | ||
|caveats= | |caveats= | ||
*The index of the last character is not equal to the string length. | *The index of the last character is not equal to the string length. | ||
**Character indexs start at zero (the index of the first character is zero). | **Character indexs start at zero (the index of the first character is zero). | ||
*llStringLength() gets the number of characters, not bytes | |||
**LSL-2 sees all strings as UTF-8 | |||
**LSL-Mono sees all string as UTF-16 | |||
**Both UTF-8 and UTF-16 use multibyte characters | |||
*Some communication functions (e.g. llHTTPResponse) are limited by number of Bytes, and work with UTF-8 strings | |||
**To quickly find out the number of bytes (in UTF-8), you can use [[llStringToBase64]] (see also snippet there) | |||
|constants | |constants | ||
|examples= | |examples= | ||
< | <source lang="lsl2"> | ||
// assumptions: | // assumptions: | ||
// object name: LSLWiki | // object name: LSLWiki | ||
Line 27: | Line 33: | ||
} | } | ||
} | } | ||
</ | |||
</source> | |||
|helpers | |helpers | ||
|also_functions={{LSL DefineRow||[[llGetListLength]]|}} | |also_functions={{LSL DefineRow||[[llGetListLength]]|}} |
Latest revision as of 06:13, 24 January 2024
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Summary
Function: integer llStringLength( string str );128 | Function ID |
0.0 | Forced Delay |
10.0 | Energy |
Returns an integer that is the number of characters in str.
• string | str |
Caveats
- The index of the last character is not equal to the string length.
- Character indexs start at zero (the index of the first character is zero).
- llStringLength() gets the number of characters, not bytes
- LSL-2 sees all strings as UTF-8
- LSL-Mono sees all string as UTF-16
- Both UTF-8 and UTF-16 use multibyte characters
- Some communication functions (e.g. llHTTPResponse) are limited by number of Bytes, and work with UTF-8 strings
- To quickly find out the number of bytes (in UTF-8), you can use llStringToBase64 (see also snippet there)
Examples
// assumptions:
// object name: LSLWiki
// script name: _lslwiki
default
{
state_entry()
{
string HowLongAmI = "123";
integer strlen = llStringLength(HowLongAmI);
llOwnerSay( "'" + HowLongAmI + "' has " +(string) strlen + " characters.");
// The owner of object LSLWiki will hear
// LSLWiki: '123' has 3 characters.
}
}
See Also
Functions
• | llGetListLength |