diff options
| author | Tyge Løvset <[email protected]> | 2022-05-06 17:42:58 +0200 |
|---|---|---|
| committer | Tyge Løvset <[email protected]> | 2022-05-06 17:42:58 +0200 |
| commit | d9dc93a90e1ac0a42e946be52b169e1175377c4f (patch) | |
| tree | 255b12b7313d1a85d0a2147f27404d59e40ae43c /include/stc | |
| parent | 9df37980d5801d4251db29fb33d8f8fa94570a2b (diff) | |
| download | STC-modified-d9dc93a90e1ac0a42e946be52b169e1175377c4f.tar.gz STC-modified-d9dc93a90e1ac0a42e946be52b169e1175377c4f.zip | |
Changed find_if() again. Now 3 iterator variants only.
Diffstat (limited to 'include/stc')
| -rw-r--r-- | include/stc/ccommon.h | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/include/stc/ccommon.h b/include/stc/ccommon.h index c00023ce..b0342928 100644 --- a/include/stc/ccommon.h +++ b/include/stc/ccommon.h @@ -149,11 +149,9 @@ STC_INLINE char* c_strnstrn(const char *s, const char *needle, size_t slen, cons }
#define c_foreach(...) c_MACRO_OVERLOAD(c_foreach, __VA_ARGS__)
-
#define c_foreach3(it, C, cnt) \
for (C##_iter it = C##_begin(&cnt), it##_end_ = C##_end(&cnt) \
; it.ref != it##_end_.ref; C##_next(&it))
-
#define c_foreach4(it, C, start, finish) \
for (C##_iter it = start, it##_end_ = finish \
; it.ref != it##_end_.ref; C##_next(&it))
@@ -213,19 +211,17 @@ STC_INLINE char* c_strnstrn(const char *s, const char *needle, size_t slen, cons } while (0)
#define c_pair(v) (v).first, (v).second
-#define c_find_it(C, cnt, it, pred) do { \
- size_t index = 0; \
- C##_iter _end = C##_end(&cnt); \
- for (it = C##_begin(&cnt); it.ref != _end.ref && !(pred); C##_next(&it)) \
- ++index; \
-} while (0)
-
-#define c_find_if(C, cnt, vp, pred) do { \
+#define c_find_if(C, cnt, it, pred) \
+ c_find_in(C, C##_begin(&cnt), C##_end(&cnt), it, pred)
+#define c_find_from(C, cnt, it, pred) \
+ c_find_in(C, it, C##_end(&cnt), it, pred)
+// NB: it.ref == NULL when not found, not end.ref:
+#define c_find_in(C, start, end, it, pred) do { \
size_t index = 0; \
- C##_iter _it = C##_begin(&cnt), _end = C##_end(&cnt); \
- for (; vp = _it.ref, vp != _end.ref && !(pred); C##_next(&_it)) \
+ C##_iter _end = end; \
+ for (it = start; it.ref != _end.ref && !(pred); C##_next(&it)) \
++index; \
- if (vp == _end.ref) vp = NULL; \
+ if (it.ref == _end.ref) it.ref = NULL; \
} while (0)
#define c_drop(C, ...) do { \
|
