1 /* vi: set sw=4 ts=4: */
3 * Licensed under GPLv2 or later, see file LICENSE in this source tree.
8 * Return NULL if string is not prefixed with key. Return pointer to the
9 * first character in string after the prefix key. If key is an empty string,
10 * return pointer to the beginning of string.
12 char* FAST_FUNC
is_prefixed_with(const char *string
, const char *key
)
14 #if 0 /* Two passes over key - probably slower */
15 int len
= strlen(key
);
16 if (strncmp(string
, key
, len
) == 0)
19 #else /* Open-coded */
20 while (*key
!= '\0') {
31 * Return NULL if string is not suffixed with key. Return pointer to the
32 * beginning of prefix key in string. If key is an empty string return pointer
33 * to the end of string.
35 char* FAST_FUNC
is_suffixed_with(const char *string
, const char *key
)
37 size_t key_len
= strlen(key
);
38 ssize_t len_diff
= strlen(string
) - key_len
;
42 if (strcmp(string
, key
) == 0) {
50 /* returns the array index of the string */
51 /* (index of first match is returned, or -1) */
52 int FAST_FUNC
index_in_str_array(const char *const string_array
[], const char *key
)
56 for (i
= 0; string_array
[i
] != 0; i
++) {
57 if (strcmp(string_array
[i
], key
) == 0) {
64 int FAST_FUNC
index_in_strings(const char *strings
, const char *key
)
69 /* Do we see "key\0" at current position in strings? */
70 for (j
= 0; *strings
== key
[j
]; ++j
) {
71 if (*strings
++ == '\0') {
72 //bb_error_msg("found:'%s' i:%u", key, idx);
76 /* No. Move to the start of the next string. */
77 while (*strings
++ != '\0')
84 /* returns the array index of the string, even if it matches only a beginning */
85 /* (index of first match is returned, or -1) */
87 int FAST_FUNC
index_in_substr_array(const char *const string_array
[], const char *key
)
91 for (i
= 0; string_array
[i
] != 0; i
++) {
92 if (is_prefixed_with(string_array
[i
], key
)) {
101 int FAST_FUNC
index_in_substrings(const char *strings
, const char *key
)
103 int matched_idx
= -1;
104 const int len
= strlen(key
);
109 if (strncmp(strings
, key
, len
) == 0) {
110 if (strings
[len
] == '\0')
111 return idx
; /* exact match */
112 if (matched_idx
>= 0)
113 return -1; /* ambiguous match */
116 strings
+= strlen(strings
) + 1; /* skip NUL */
123 const char* FAST_FUNC
nth_string(const char *strings
, int n
)
126 if (*strings
++ == '\0') {
127 if (*strings
== '\0') /* reached end of strings */
135 #ifdef UNUSED_SO_FAR /* only brctl.c needs it yet */
136 /* Returns 0 for no, 1 for yes or a negative value on error. */
137 smallint FAST_FUNC
yesno(const char *str
)
139 static const char no_yes
[] ALIGN1
=
141 "1\0" "on\0" "yes\0";
142 int ret
= index_in_substrings(no_yes
, str
);
149 BBUNIT_DEFINE_TEST(is_prefixed_with
)
151 BBUNIT_ASSERT_STREQ(" bar", is_prefixed_with("foo bar", "foo"));
152 BBUNIT_ASSERT_STREQ("bar", is_prefixed_with("foo bar", "foo "));
153 BBUNIT_ASSERT_STREQ("", is_prefixed_with("foo", "foo"));
154 BBUNIT_ASSERT_STREQ("foo", is_prefixed_with("foo", ""));
155 BBUNIT_ASSERT_STREQ("", is_prefixed_with("", ""));
157 BBUNIT_ASSERT_NULL(is_prefixed_with("foo", "bar foo"));
158 BBUNIT_ASSERT_NULL(is_prefixed_with("foo foo", "bar"));
159 BBUNIT_ASSERT_NULL(is_prefixed_with("", "foo"));
164 BBUNIT_DEFINE_TEST(is_suffixed_with
)
166 BBUNIT_ASSERT_STREQ("bar", is_suffixed_with("foo bar", "bar"));
167 BBUNIT_ASSERT_STREQ("foo", is_suffixed_with("foo", "foo"));
168 BBUNIT_ASSERT_STREQ("", is_suffixed_with("foo", ""));
169 BBUNIT_ASSERT_STREQ("", is_suffixed_with("", ""));
170 BBUNIT_ASSERT_STREQ("foo", is_suffixed_with("barfoofoo", "foo"));
172 BBUNIT_ASSERT_NULL(is_suffixed_with("foo", "bar foo"));
173 BBUNIT_ASSERT_NULL(is_suffixed_with("foo foo", "bar"));
174 BBUNIT_ASSERT_NULL(is_suffixed_with("", "foo"));
179 #endif /* ENABLE_UNIT_TEST */