libc/string: simplify strrchr
Do not call strlen() here. Old implementation iterated over string twice, if searched for position was at the beginning. This commit changes strrchr() to scan string only once, regardless of input. Signed-off-by: Juha Niskanen <juha.niskanen@haltian.com>
This commit is contained in:
parent
0c8d3489e6
commit
a17bfec43d
@ -39,7 +39,7 @@
|
|||||||
* considered to be part of the string.
|
* considered to be part of the string.
|
||||||
*
|
*
|
||||||
* Returned Value:
|
* Returned Value:
|
||||||
* Upon completion, strchrnull() returns a pointer to the byte, or a
|
* Upon completion, strchrnul() returns a pointer to the byte, or a
|
||||||
* pointer to null if the byte was not found.
|
* pointer to null if the byte was not found.
|
||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
@ -37,15 +37,16 @@
|
|||||||
#undef strrchr /* See mm/README.txt */
|
#undef strrchr /* See mm/README.txt */
|
||||||
FAR char *strrchr(FAR const char *s, int c)
|
FAR char *strrchr(FAR const char *s, int c)
|
||||||
{
|
{
|
||||||
FAR const char *p = &s[strlen(s)];
|
FAR const char *r = NULL;
|
||||||
|
|
||||||
for (; p >= s; p--)
|
do
|
||||||
{
|
{
|
||||||
if (*p == c)
|
if (*s == c)
|
||||||
{
|
{
|
||||||
return (FAR char *)p;
|
r = s;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
while (*s++ != '\0');
|
||||||
|
|
||||||
return NULL;
|
return (FAR char *)r;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user