summaryrefslogtreecommitdiff
path: root/lib/linux_string.c
diff options
context:
space:
mode:
authorSimon Glass <sjg@chromium.org>2025-05-01 05:10:08 -0600
committerSimon Glass <sjg@chromium.org>2025-05-16 06:21:36 +0200
commitaea684a0c31cb2b0442eab965c2b08ed8d1abfd0 (patch)
tree61ca10f06bdf9de0227508d469f4249034285a2d /lib/linux_string.c
parent4c26de2eea6bcf5f27b13da0372d27d767cd38e3 (diff)
strim: Sync up with Linux version
Linux changed the behaviour of strim() so that a string with only spaces reduces places the terminator at the start of the string, rather than returning a pointer to the end of the string. Bring in this version, from Linux v6.14 Add a comment about the new behaviour. Signed-off-by: Simon Glass <sjg@chromium.org>
Diffstat (limited to 'lib/linux_string.c')
-rw-r--r--lib/linux_string.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/lib/linux_string.c b/lib/linux_string.c
index d5a5e08d98c..4b92cd923f2 100644
--- a/lib/linux_string.c
+++ b/lib/linux_string.c
@@ -31,13 +31,15 @@ char *skip_spaces(const char *str)
* Note that the first trailing whitespace is replaced with a %NUL-terminator
* in the given string @s. Returns a pointer to the first non-whitespace
* character in @s.
+ *
+ * Note that if the string consist of only spaces, then the terminator is placed
+ * at the start of the string, with the return value pointing there also.
*/
char *strim(char *s)
{
size_t size;
char *end;
- s = skip_spaces(s);
size = strlen(s);
if (!size)
return s;
@@ -47,5 +49,5 @@ char *strim(char *s)
end--;
*(end + 1) = '\0';
- return s;
+ return skip_spaces(s);
}