summaryrefslogtreecommitdiff
path: root/src/common
diff options
context:
space:
mode:
Diffstat (limited to 'src/common')
-rw-r--r--src/common/container.c14
-rw-r--r--src/common/container.h2
2 files changed, 16 insertions, 0 deletions
diff --git a/src/common/container.c b/src/common/container.c
index 6dae0bb932..659e1346d1 100644
--- a/src/common/container.c
+++ b/src/common/container.c
@@ -197,6 +197,20 @@ smartlist_string_isin(const smartlist_t *sl, const char *element)
return 0;
}
+/** Return true iff <b>sl</b> has some element E such that
+ * !strcasecmp(E,<b>element</b>)
+ */
+int
+smartlist_string_isin_case(const smartlist_t *sl, const char *element)
+{
+ int i;
+ if (!sl) return 0;
+ for (i=0; i < sl->num_used; i++)
+ if (strcasecmp((const char*)sl->list[i],element)==0)
+ return 1;
+ return 0;
+}
+
/** Return true iff <b>sl</b> has some element E such that E is equal
* to the decimal encoding of <b>num</b>.
*/
diff --git a/src/common/container.h b/src/common/container.h
index 5f0417cf4d..a6b7b56adb 100644
--- a/src/common/container.h
+++ b/src/common/container.h
@@ -35,6 +35,8 @@ void smartlist_string_remove(smartlist_t *sl, const char *element);
int smartlist_isin(const smartlist_t *sl, const void *element) ATTR_PURE;
int smartlist_string_isin(const smartlist_t *sl, const char *element)
ATTR_PURE;
+int smartlist_string_isin_case(const smartlist_t *sl, const char *element)
+ ATTR_PURE;
int smartlist_string_num_isin(const smartlist_t *sl, int num) ATTR_PURE;
int smartlist_overlap(const smartlist_t *sl1, const smartlist_t *sl2)
ATTR_PURE;