Difference between revisions of "LlStringTrim"

From Second Life Wiki
Jump to navigation Jump to search
(a much faster (~2x) and memory efficient (didn't measure exactly, but several kB on a 1 kB string) approach for removing doubled spaces; regrouped obsolete examples as "maybe don't use these")
 
(22 intermediate revisions by 15 users not shown)
Line 8: Line 8:
|func_footnote
|func_footnote
|func_desc
|func_desc
|return_text=that is '''src''' with leading and/or trailing white space (spaces, tabs, and line feeds) trimmed from it.
|return_text=that is {{LSLP|src}} with leading and/or trailing white space (spaces, tabs, and line feeds) trimmed from it.
|spec
|spec
|caveats
|caveats
|constants=
|constants=
{{{!}} class="sortable" {{Prettytable}}
{{{!}} class="sortable" {{Prettytable|style=margin-top:0;}}
{{!}}-{{Hl2}}
{{!}}-{{Hl2}}
! {{!}} Constant
! {{!}} Constant
Line 18: Line 18:
! class="unsortable"{{!}} Description
! class="unsortable"{{!}} Description
{{!}}-
{{!}}-
{{!}}{{LSL Const|STRING_TRIM_HEAD|integer|1|hex=0x1|c=Trims spaces off the beginning.}}
{{!}}{{LSL Const|STRING_TRIM_HEAD|integer|1|hex=0x1|c=Trims white space off the beginning.}}
{{!}}{{#var:value}}
{{!}}{{#var:value}}
{{!}}{{#var:comment}}
{{!}}{{#var:comment}}
{{!}}-
{{!}}-
{{!}}{{LSL Const|STRING_TRIM_TAIL|integer|2|hex=0x2|c=Trims spaces off the end.}}
{{!}}{{LSL Const|STRING_TRIM_TAIL|integer|2|hex=0x2|c=Trims white space off the end.}}
{{!}}{{#var:value}}
{{!}}{{#var:value}}
{{!}}{{#var:comment}}
{{!}}{{#var:comment}}
{{!}}-
{{!}}-
{{!}}{{LSL Const|STRING_TRIM|integer|3|hex=0x3|c=Trims spaces off the beginning and end.}}
{{!}}{{LSL Const|STRING_TRIM|integer|3|hex=0x3|c=Trims white space off the beginning and end.}}
{{!}}{{#var:value}}
{{!}}{{#var:value}}
{{!}}{{#var:comment}}
{{!}}{{#var:comment}}
{{!}}}
{{!}}}
|examples=
|examples=
Returns the number of leading and trailing spaces on a string (not particularly useful but shows how to use the function).
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:
<pre>
<syntaxhighlight lang="lsl2">llStringTrim("User input", STRING_TRIM);</syntaxhighlight>
 
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).
<syntaxhighlight lang="lsl2">
default
default
{
{
Line 39: Line 42:
         llListen(4, "", llGetOwner(), "");
         llListen(4, "", llGetOwner(), "");
     }
     }
     on_rez(integer a)
 
     on_rez(integer start_param)
     {
     {
         llResetScript();
         llResetScript();
     }
     }
     listen(integer chan, string name, key id, string msg)
 
     {
     listen(integer channel, string name, key id, string message)
        //test for and remove wrapping single or double quotes
     {      
        if(~llSubStringIndex("'\"", llGetSubString(msg,0,0)))
            if(llGetSubString(msg,-1,-1) == llGetSubString(msg,0,0))
                msg = llDeleteSubString(msg, -1, 0);
       
         //track the length
         //track the length
         integer length = llStringLength(msg);
         integer length = llStringLength(message);
          
          
         //trim msg (not necessary to store these to variables but makes reading easier)
         //trim message (not necessary to store these to variables but makes reading easier)
         string trim_left = llStringTrim(msg, STRING_TRIM_HEAD);
         string trim_left = llStringTrim(message, STRING_TRIM_HEAD);
         string trim_right = llStringTrim(msg, STRING_TRIM_HEAD);
         string trim_right = llStringTrim(message, STRING_TRIM_TAIL);
         string trim = llStringTrim(msg, STRING_TRIM);
         string trim_both  = llStringTrim(message, STRING_TRIM);


         //output the results
         //output the results
         llOwnerSay("Initial length = " + (string)length +
         llOwnerSay("Initial length = " + (string)length +
                 "\nLeading Spaces = " + (string)(length - llStringLength(trim_left))+
                 "\nLeading Spaces = " + (string)(length - llStringLength(trim_left))+
                 "\nTrailing Spaces = " + (string)(length - llStringLength(trim_right))+
                 "\nTrailing Spaces = " + (string)(length - llStringLength(trim_right))+
                 "\nTrimmed Message = \"" + trim + "\"");
                 "\nTrimmed Message = \"" + trim_both + "\"");
     }
     }
}
}
</pre>
</syntaxhighlight>
|helpers
|helpers
|also_functions
|also_functions
Line 71: Line 71:
|also_events
|also_events
|also_articles
|also_articles
|history
|history=
*Introduced in 1.13.4 onwards...
*Introduced in 1.13.4
Date of release [[ Release_Notes/Second_Life_Release/1.15#Release_Notes_for_Second_Life_1.15.0.282.29_April_25.2C_2007 | 25-04-2007 ]]
|notes=
|notes=
The following examples will make the same result.
*The exact set of characters stripped are 0x09 (tab), line feed (0x0a, "\n"), vertical tab (0x0b), form feed (0x0c), carriage return (0x0d) and space (0x20, " ").
<pre>
** Only line feed and space function as true whitespace within SL, the others will produce some manner of a printable character.
string src = "   Duh    ";
** The "\t" escape code doesn't actually represent the tab character, but several spaces instead.
st = llStringTrim(src, STRING_TRIM_HEAD);
** Other whitespace characters defined in Unicode, such as non-breaking space (0xa0) or specific-width spaces in the 0x2000 range are not stripped.
st = llStringTrim(st , STRING_TRIM_TAIL);
* 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.  
</pre>
* The following will remove all doubled (or further multiplied), leading and trailing spaces with iterated [[llReplaceSubString]]:
<pre>
<syntaxhighlight lang="lsl2">
string src = "   Duh    ";
while(llStringLength(s) != llStringLength(s = llReplaceSubString(s, "  ", " ", 0)));
st = llStringTrim(src, STRING_TRIM);
s = llStringTrim(s, STRING_TRIM);
</pre>
</syntaxhighlight>
 
* llReplaceSubString is also the easiest way to remove all spaces from a string:
This is because <code>(STRING_TRIM_HEAD {{!}} STRING_TRIM_TAIL) == STRING_TRIM</code>.
<syntaxhighlight lang="lsl2">llReplaceSubString("some words to remove the spaces from", " ", "", 0);</syntaxhighlight>
* [[llList2Json]] also trims strings contained in the list. Thus, an easy way to trim an entire list of strings is:
<syntaxhighlight lang="lsl2">
list l = ["  a  ", " b", "c ", " d "];
list trimmedList = llJson2List(llList2Json(JSON_ARRAY, l));
</syntaxhighlight>
* Some old, less efficient methods, no longer recommended for use:
:* Intra-string space trimming:
::<syntaxhighlight lang="lsl2">llDumpList2String(llParseString2List(src, [" "], []), " "); //works but can use a large quantity of memory</syntaxhighlight>
:* An method to strip spaces from the sentence:
::<syntaxhighlight lang="lsl2">
//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);
}
</syntaxhighlight>
:* Variant of above:
::<syntaxhighlight lang="lsl2">(string)llParseString2List(src, [" "], []); //works but can use a large quantity of memory</syntaxhighlight>
|deprecated
|deprecated
|cat1=String
|cat1=String

Latest revision as of 10:19, 13 January 2025

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

  • The exact set of characters stripped are 0x09 (tab), line feed (0x0a, "\n"), vertical tab (0x0b), form feed (0x0c), carriage return (0x0d) and space (0x20, " ").
    • Only line feed and space function as true whitespace within SL, the others will produce some manner of a printable character.
    • The "\t" escape code doesn't actually represent the tab character, but several spaces instead.
    • Other whitespace characters defined in Unicode, such as non-breaking space (0xa0) or specific-width spaces in the 0x2000 range are not stripped.
  • 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 doubled (or further multiplied), leading and trailing spaces with iterated llReplaceSubString:
while(llStringLength(s) != llStringLength(s = llReplaceSubString(s, "  ", " ", 0)));
s = llStringTrim(s, STRING_TRIM);
  • llReplaceSubString is also the easiest way to remove all spaces from a string:
llReplaceSubString("some words to remove the spaces from", " ", "", 0);
  • 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));
  • Some old, less efficient methods, no longer recommended for use:
  • Intra-string space trimming:
llDumpList2String(llParseString2List(src, [" "], []), " "); //works but can use a large quantity of memory
  • An method to strip spaces from the sentence:
//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);
}
  • Variant of above:
(string)llParseString2List(src, [" "], []); //works but can use a large quantity of memory

Deep Notes

History

  • Introduced in 1.13.4
Date of release 25-04-2007

Signature

function string llStringTrim( string src, integer type );