mirror of
https://github.com/minetest/irrlicht.git
synced 2025-01-26 01:30:23 +01:00
Change string::split once more
- Delimiters now end up in their own token when keepSeparators is true. - When ignoreEmptyTokens is false we now add a token at the end when the last character is a delimiter. While this means some changes, the ignoreEmptyTokens=false didn't work correct in 1.8 anyway, so another change shouldn't break much. Thanks @manni63 for bringing this up in forum: http://irrlicht.sourceforge.net/forum/viewtopic.php?f=7&t=51584&p=299634#p299634 git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6007 dfc29bdd-3216-0410-991c-e03cc46cb475
This commit is contained in:
parent
421000e00d
commit
44fd5d37ea
@ -1376,8 +1376,9 @@ public:
|
|||||||
\param delimiter C-style string of delimiter characters
|
\param delimiter C-style string of delimiter characters
|
||||||
\param countDelimiters Number of delimiter characters
|
\param countDelimiters Number of delimiter characters
|
||||||
\param ignoreEmptyTokens Flag to avoid empty substrings in the result
|
\param ignoreEmptyTokens Flag to avoid empty substrings in the result
|
||||||
container. If two delimiters occur without a character in between, an
|
container. If two delimiters occur without a character in between or an
|
||||||
empty substring would be placed in the result. If this flag is set,
|
empty substring would be placed in the result. Or if a delimiter is the last
|
||||||
|
character an empty substring would be added at the end. If this flag is set,
|
||||||
only non-empty strings are stored.
|
only non-empty strings are stored.
|
||||||
\param keepSeparators Flag which allows to add the separator to the
|
\param keepSeparators Flag which allows to add the separator to the
|
||||||
result string. If this flag is true, the concatenation of the
|
result string. If this flag is true, the concatenation of the
|
||||||
@ -1399,18 +1400,16 @@ public:
|
|||||||
for (u32 j=0; j<countDelimiters; ++j)
|
for (u32 j=0; j<countDelimiters; ++j)
|
||||||
{
|
{
|
||||||
if (array[i] == delimiter[j])
|
if (array[i] == delimiter[j])
|
||||||
{
|
|
||||||
if ( keepSeparators )
|
|
||||||
{
|
|
||||||
ret.push_back(string<T,TAlloc>(&array[tokenStartIdx], i+1 - tokenStartIdx));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
if (i - tokenStartIdx > 0)
|
if (i - tokenStartIdx > 0)
|
||||||
ret.push_back(string<T,TAlloc>(&array[tokenStartIdx], i - tokenStartIdx));
|
ret.push_back(string<T,TAlloc>(&array[tokenStartIdx], i - tokenStartIdx));
|
||||||
else if ( !ignoreEmptyTokens )
|
else if ( !ignoreEmptyTokens )
|
||||||
ret.push_back(string<T,TAlloc>());
|
ret.push_back(string<T,TAlloc>());
|
||||||
|
if ( keepSeparators )
|
||||||
|
{
|
||||||
|
ret.push_back(string<T,TAlloc>(&array[i], 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
tokenStartIdx = i+1;
|
tokenStartIdx = i+1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -1418,6 +1417,8 @@ public:
|
|||||||
}
|
}
|
||||||
if ((used - 1) > tokenStartIdx)
|
if ((used - 1) > tokenStartIdx)
|
||||||
ret.push_back(string<T,TAlloc>(&array[tokenStartIdx], (used - 1) - tokenStartIdx));
|
ret.push_back(string<T,TAlloc>(&array[tokenStartIdx], (used - 1) - tokenStartIdx));
|
||||||
|
else if ( !ignoreEmptyTokens )
|
||||||
|
ret.push_back(string<T,TAlloc>());
|
||||||
|
|
||||||
return ret.size()-oldSize;
|
return ret.size()-oldSize;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user