aboutsummaryrefslogtreecommitdiff
path: root/libbb
diff options
context:
space:
mode:
authorDenis Vlasenko <vda.linux@googlemail.com>2007-07-24 15:54:42 +0000
committerDenis Vlasenko <vda.linux@googlemail.com>2007-07-24 15:54:42 +0000
commit990d0f63eeb502c8762076e5c5499196e09cba55 (patch)
tree30a2091a8159b1694d65f9952e2aba2667d7dc11 /libbb
parentbcb66ec22e82f6b1ab93f3aec917269393a5b464 (diff)
downloadbusybox-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.c33
-rw-r--r--libbb/dump.c2
-rw-r--r--libbb/getopt32.c2
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
22int 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
24int index_in_substr_array(const char * const string_array[], const char *key) 39int 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
54int 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
455static void conv_c(PR * pr, unsigned char * p) 455static 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