X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=libbb%2Ftrim.c;h=df00b846e967ce7ce39efabda19a7f13448c09d1;hb=9f5a577a3241597cb5e7ba9f6df33c2e3c440e44;hp=78cf235dd006cae01c326006d69e2d79e24f3e18;hpb=3c0364f3911ec9f43e1c8c96ec2c8e30b1b52c47;p=oweals%2Fbusybox.git diff --git a/libbb/trim.c b/libbb/trim.c index 78cf235dd..df00b846e 100644 --- a/libbb/trim.c +++ b/libbb/trim.c @@ -2,52 +2,29 @@ /* * Utility routines. * - * Copyright (C) tons of folks. Tracking down who wrote what - * isn't something I'm going to worry about... If you wrote something - * here, please feel free to acknowledge your work. - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU - * General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - * - * Based in part on code from sash, Copyright (c) 1999 by David I. Bell - * Permission has been granted to redistribute this code under the GPL. + * Copyright (C) many different people. + * If you wrote this, please acknowledge your work. * + * Licensed under GPLv2 or later, see file LICENSE in this tarball for details. */ -#include -#include -#include #include "libbb.h" - -void trim(char *s) +void FAST_FUNC trim(char *s) { - int len=strlen(s); + size_t len = strlen(s); /* trim trailing whitespace */ - while ( len > 0 && isspace(s[len-1])) - s[--len]='\0'; + while (len && isspace(s[len-1])) + --len; /* trim leading whitespace */ - memmove(s, &s[strspn(s, " \n\r\t\v")], len); + if (len) { + char *nws = skip_whitespace(s); + if ((nws - s) != 0) { + len -= (nws - s); + memmove(s, nws, len); + } + } + s[len] = '\0'; } - -/* END CODE */ -/* -Local Variables: -c-file-style: "linux" -c-basic-offset: 4 -tab-width: 4 -End: -*/