diff options
| author | Eric Andersen <andersen@codepoet.org> | 2001-04-26 15:56:47 +0000 |
|---|---|---|
| committer | Eric Andersen <andersen@codepoet.org> | 2001-04-26 15:56:47 +0000 |
| commit | c1bdffe99b6fa6fdb0f43e0dec85d8bbfcab1572 (patch) | |
| tree | 3cf5b7c0c69bd8c802c4b080b6a5e94a4a401831 /libbb | |
| parent | 3c3277f0bda79b66b35e5e965e5340624d29a459 (diff) | |
| download | busybox-w32-c1bdffe99b6fa6fdb0f43e0dec85d8bbfcab1572.tar.gz busybox-w32-c1bdffe99b6fa6fdb0f43e0dec85d8bbfcab1572.tar.bz2 busybox-w32-c1bdffe99b6fa6fdb0f43e0dec85d8bbfcab1572.zip | |
Another nice cleanup from Larry. This adds a new last_char_is() function and
uses it to avoid possible buffer underruns whn strlen is zero, and avoid the
possible space-hogging inline of strlen() in several cases.
-Erik
Diffstat (limited to 'libbb')
| -rw-r--r-- | libbb/last_char_is.c | 33 | ||||
| -rw-r--r-- | libbb/libbb.h | 1 |
2 files changed, 34 insertions, 0 deletions
diff --git a/libbb/last_char_is.c b/libbb/last_char_is.c new file mode 100644 index 000000000..b4bb7ec32 --- /dev/null +++ b/libbb/last_char_is.c | |||
| @@ -0,0 +1,33 @@ | |||
| 1 | /* | ||
| 2 | * busybox library eXtended function | ||
| 3 | * | ||
| 4 | * Copyright (C) 2001 Larry Doolittle, <ldoolitt@recycle.lbl.gov> | ||
| 5 | * | ||
| 6 | * This program is free software; you can redistribute it and/or modify | ||
| 7 | * it under the terms of the GNU General Public License as published by | ||
| 8 | * the Free Software Foundation; either version 2 of the License, or | ||
| 9 | * (at your option) any later version. | ||
| 10 | * | ||
| 11 | * This program is distributed in the hope that it will be useful, | ||
| 12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
| 14 | * General Public License for more details. | ||
| 15 | * | ||
| 16 | * You should have received a copy of the GNU General Public License | ||
| 17 | * along with this program; if not, write to the Free Software | ||
| 18 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | ||
| 19 | * | ||
| 20 | */ | ||
| 21 | |||
| 22 | #include "libbb.h" | ||
| 23 | |||
| 24 | /* Find out if the last character of a string matches the one given Don't | ||
| 25 | * underrun the buffer if the string length is 0. Also avoids a possible | ||
| 26 | * space-hogging inline of strlen() per usage. | ||
| 27 | */ | ||
| 28 | int last_char_is(const char *s, const int c) | ||
| 29 | { | ||
| 30 | int l = strlen(s); | ||
| 31 | if (l==0) return 0; | ||
| 32 | return (s[l-1] == c); | ||
| 33 | } | ||
diff --git a/libbb/libbb.h b/libbb/libbb.h index 2937b4863..0ceb983cd 100644 --- a/libbb/libbb.h +++ b/libbb/libbb.h | |||
| @@ -218,6 +218,7 @@ int klogctl(int type, char * b, int len); | |||
| 218 | 218 | ||
| 219 | char *xgetcwd(char *cwd); | 219 | char *xgetcwd(char *cwd); |
| 220 | char *concat_path_file(const char *path, const char *filename); | 220 | char *concat_path_file(const char *path, const char *filename); |
| 221 | int last_char_is(const char *s, const int c); | ||
| 221 | 222 | ||
| 222 | typedef struct ar_headers_s { | 223 | typedef struct ar_headers_s { |
| 223 | char *name; | 224 | char *name; |
