From ca2283bdc00529967f9ccd9bf0097714447af351 Mon Sep 17 00:00:00 2001 From: Matthew Krupcale Date: Sun, 9 Aug 2020 09:37:19 -0400 Subject: Add iterator-based versions of find_option{,_prefix} This allows one to use all of the properties of iterators to manipulate the found option. --- libbuild2/utility.ixx | 48 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) (limited to 'libbuild2/utility.ixx') diff --git a/libbuild2/utility.ixx b/libbuild2/utility.ixx index da9f58b..9a77fae 100644 --- a/libbuild2/utility.ixx +++ b/libbuild2/utility.ixx @@ -139,6 +139,29 @@ namespace build2 return find_option (o, s[var], ic); } + inline bool + compare_option (const char* o, const char* s, bool ic) + { + return s != nullptr && (ic ? icasecmp (s, o) : strcmp (s, o)) == 0; + } + + inline bool + compare_option (const char* o, const string& s, bool ic) + { + return ic ? icasecmp (s, o) == 0 : s == o; + } + + template + inline I + find_option (const char* o, I b, I e, bool ic) + { + for (; b != e; ++b) + if (compare_option (o, *b, ic)) + return b; + + return e; + } + template inline bool find_options (const initializer_list& os, @@ -173,6 +196,31 @@ namespace build2 return find_option_prefix (p, s[var], ic); } + inline bool + compare_option_prefix (const char* p, size_t n, const char* s, bool ic) + { + return s != nullptr && (ic ? icasecmp (s, p, n) : strncmp (s, p, n)) == 0; + } + + inline bool + compare_option_prefix (const char* p, size_t n, const string& s, bool ic) + { + return (ic ? icasecmp (s, p, n) : s.compare (0, n, p)) == 0; + } + + template + inline I + find_option_prefix (const char* p, I b, I e, bool ic) + { + size_t n (strlen (p)); + + for (; b != e; ++b) + if (compare_option_prefix (p, n, *b, ic)) + return b; + + return e; + } + template inline const string* find_option_prefixes (const initializer_list& ps, -- cgit v1.1