Difference between revisions of "LlStringTrim"
Tapple Gao (talk | contribs) (Noted that llList2Json also trims strings) |
(Added llReplaceSubString as modern solution for removing in-sentence spaces.) |
||
Line 101: | Line 101: | ||
</source> | </source> | ||
Finally, [[llReplaceSubString]] is probably the easiest way to trim spaces from a string: | |||
<source lang="lsl2">llReplaceSubString("some words to remove the spaces from", " ", "", 0);</source> | |||
|deprecated | |deprecated |
Revision as of 05:44, 11 February 2024
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Summary
Function: string llStringTrim( string src, integer type );0.0 | Forced Delay |
10.0 | Energy |
Returns a string that is src with leading and/or trailing white space (spaces, tabs, and line feeds) trimmed from it.
• string | src | |||
• integer | type | – | STRING_TRIM* flag(s) |
Constant | Description | |
---|---|---|
STRING_TRIM_HEAD | 0x1 | Trims white space off the beginning. |
STRING_TRIM_TAIL | 0x2 | Trims white space off the end. |
STRING_TRIM | 0x3 | Trims white space off the beginning and end. |
Examples
Whenever you are accepting unstructured input from a user -- whether via chat or via a notecard -- it is a good idea to always full trim it:
llStringTrim("User input", STRING_TRIM);
This example returns the number of leading and trailing 'white space' characters on a string that were removed (not particularly useful but shows how to use the function).
default
{
state_entry()
{
llListen(4, "", llGetOwner(), "");
}
on_rez(integer start_param)
{
llResetScript();
}
listen(integer channel, string name, key id, string message)
{
//track the length
integer length = llStringLength(message);
//trim message (not necessary to store these to variables but makes reading easier)
string trim_left = llStringTrim(message, STRING_TRIM_HEAD);
string trim_right = llStringTrim(message, STRING_TRIM_TAIL);
string trim_both = llStringTrim(message, STRING_TRIM);
//output the results
llOwnerSay("Initial length = " + (string)length +
"\nLeading Spaces = " + (string)(length - llStringLength(trim_left))+
"\nTrailing Spaces = " + (string)(length - llStringLength(trim_right))+
"\nTrimmed Message = \"" + trim_both + "\"");
}
}
Notes
Aside from white space at the beginning and / or end, the actual string will be unaffected. This means too, though, that extraneous spaces within the string -- for instance, a mistaken double-space type -- will not be corrected.
The following will remove all double spaces and leading and trailing spaces.
llDumpList2String(llParseString2List(src, [" "], []), " "); //works but can use a large quantity of memory
This method strips spaces from the sentence and may use less memory
//Added By To-mos Codewarrior
string str1 = "some words to remove the spaces from";
integer index;
while(~index=llSubStringIndex(str1," ")) {
data=llDeleteSubString(str1,index,index);
}
The following will do the same:
(string)llParseString2List(src, [" "], []); //works but can use a large quantity of memory
llList2Json also trims strings contained in the list. Thus, an easy way to trim an entire list of strings is:
list l = [" a ", " b", "c ", " d "];
list trimmedList = llJson2List(llList2Json(JSON_ARRAY, l));
Finally, llReplaceSubString is probably the easiest way to trim spaces from a string:
llReplaceSubString("some words to remove the spaces from", " ", "", 0);