diff options
author | Denis Vlasenko <vda.linux@googlemail.com> | 2007-07-24 15:54:42 +0000 |
---|---|---|
committer | Denis Vlasenko <vda.linux@googlemail.com> | 2007-07-24 15:54:42 +0000 |
commit | 990d0f63eeb502c8762076e5c5499196e09cba55 (patch) | |
tree | 30a2091a8159b1694d65f9952e2aba2667d7dc11 /libbb | |
parent | bcb66ec22e82f6b1ab93f3aec917269393a5b464 (diff) | |
download | busybox-w32-990d0f63eeb502c8762076e5c5499196e09cba55.tar.gz busybox-w32-990d0f63eeb502c8762076e5c5499196e09cba55.tar.bz2 busybox-w32-990d0f63eeb502c8762076e5c5499196e09cba55.zip |
Replace index_in_[sub]str_array with index_in_[sub]strings,
which scans thru "abc\0def\0123\0\0" type strings. Saves 250 bytes.
text data bss dec hex filename
781266 1328 11844 794438 c1f46 busybox_old
781010 1328 11844 794182 c1e46 busybox_unstripped
Diffstat (limited to 'libbb')
-rw-r--r-- | libbb/compare_string_array.c | 33 | ||||
-rw-r--r-- | libbb/dump.c | 2 | ||||
-rw-r--r-- | libbb/getopt32.c | 2 |
3 files changed, 35 insertions, 2 deletions
diff --git a/libbb/compare_string_array.c b/libbb/compare_string_array.c index 077a280a2..e873d7cc3 100644 --- a/libbb/compare_string_array.c +++ b/libbb/compare_string_array.c | |||
@@ -19,8 +19,23 @@ int index_in_str_array(const char * const string_array[], const char *key) | |||
19 | return -1; | 19 | return -1; |
20 | } | 20 | } |
21 | 21 | ||
22 | int index_in_strings(const char *strings, const char *key) | ||
23 | { | ||
24 | int idx = 0; | ||
25 | |||
26 | while (strings[0]) { | ||
27 | if (strcmp(strings, key) == 0) { | ||
28 | return idx; | ||
29 | } | ||
30 | strings += strlen(strings) + 1; /* skip NUL */ | ||
31 | idx++; | ||
32 | } | ||
33 | return -1; | ||
34 | } | ||
35 | |||
22 | /* returns the array index of the string, even if it matches only a beginning */ | 36 | /* returns the array index of the string, even if it matches only a beginning */ |
23 | /* (index of first match is returned, or -1) */ | 37 | /* (index of first match is returned, or -1) */ |
38 | #ifdef UNUSED | ||
24 | int index_in_substr_array(const char * const string_array[], const char *key) | 39 | int index_in_substr_array(const char * const string_array[], const char *key) |
25 | { | 40 | { |
26 | int i; | 41 | int i; |
@@ -34,3 +49,21 @@ int index_in_substr_array(const char * const string_array[], const char *key) | |||
34 | } | 49 | } |
35 | return -1; | 50 | return -1; |
36 | } | 51 | } |
52 | #endif | ||
53 | |||
54 | int index_in_substrings(const char *strings, const char *key) | ||
55 | { | ||
56 | int len = strlen(key); | ||
57 | |||
58 | if (len) { | ||
59 | int idx = 0; | ||
60 | while (strings[0]) { | ||
61 | if (strncmp(strings, key, len) == 0) { | ||
62 | return idx; | ||
63 | } | ||
64 | strings += strlen(strings) + 1; /* skip NUL */ | ||
65 | idx++; | ||
66 | } | ||
67 | } | ||
68 | return -1; | ||
69 | } | ||
diff --git a/libbb/dump.c b/libbb/dump.c index 6dbbd9f84..5ddbbaaf6 100644 --- a/libbb/dump.c +++ b/libbb/dump.c | |||
@@ -449,7 +449,7 @@ static const char conv_str[] = | |||
449 | "\r\\r\0" | 449 | "\r\\r\0" |
450 | "\t\\t\0" | 450 | "\t\\t\0" |
451 | "\v\\v\0" | 451 | "\v\\v\0" |
452 | "\0"; | 452 | ; |
453 | 453 | ||
454 | 454 | ||
455 | static void conv_c(PR * pr, unsigned char * p) | 455 | static void conv_c(PR * pr, unsigned char * p) |
diff --git a/libbb/getopt32.c b/libbb/getopt32.c index 25eb113df..107102329 100644 --- a/libbb/getopt32.c +++ b/libbb/getopt32.c | |||
@@ -79,7 +79,7 @@ const char *applet_long_options | |||
79 | static const char applet_longopts[] = | 79 | static const char applet_longopts[] = |
80 | //"name\0" has_arg val | 80 | //"name\0" has_arg val |
81 | "verbose\0" No_argument "v" | 81 | "verbose\0" No_argument "v" |
82 | "\0"; | 82 | ; |
83 | applet_long_options = applet_longopts; | 83 | applet_long_options = applet_longopts; |
84 | 84 | ||
85 | The last member of struct option (val) typically is set to | 85 | The last member of struct option (val) typically is set to |