1 // Copyright (c) 2019 The Bitcoin Core developers
2 // Distributed under the MIT software license, see the accompanying
3 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5 #ifndef BITCOIN_TEST_UTIL_STR_H
6 #define BITCOIN_TEST_UTIL_STR_H
7
8 #include <string>
9
10 bool CaseInsensitiveEqual(const std::string& s1, const std::string& s2);
11
12 /**
13 * Increment a string. Useful to enumerate all fixed length strings with
14 * characters in [min_char, max_char].
15 */
16 template <typename CharType, size_t StringLength>
NextString(CharType (& string)[StringLength],CharType min_char,CharType max_char)17 bool NextString(CharType (&string)[StringLength], CharType min_char, CharType max_char)
18 {
19 for (CharType& elem : string) {
20 bool has_next = elem != max_char;
21 elem = elem < min_char || elem >= max_char ? min_char : CharType(elem + 1);
22 if (has_next) return true;
23 }
24 return false;
25 }
26
27 /**
28 * Iterate over string values and call function for each string without
29 * successive duplicate characters.
30 */
31 template <typename CharType, size_t StringLength, typename Fn>
ForEachNoDup(CharType (& string)[StringLength],CharType min_char,CharType max_char,Fn && fn)32 void ForEachNoDup(CharType (&string)[StringLength], CharType min_char, CharType max_char, Fn&& fn) {
33 for (bool has_next = true; has_next; has_next = NextString(string, min_char, max_char)) {
34 int prev = -1;
35 bool skip_string = false;
36 for (CharType c : string) {
37 if (c == prev) skip_string = true;
38 if (skip_string || c < min_char || c > max_char) break;
39 prev = c;
40 }
41 if (!skip_string) fn();
42 }
43 }
44
45 #endif // BITCOIN_TEST_UTIL_STR_H
46