diff options
| author | Tyge Løvset <[email protected]> | 2022-09-28 14:54:27 +0200 |
|---|---|---|
| committer | Tyge Løvset <[email protected]> | 2022-09-28 14:54:27 +0200 |
| commit | e1a353c8a82315d9456c2f33e3e4416b5f444800 (patch) | |
| tree | f64bedff026faaa9c758b79200f2095122485059 /include | |
| parent | 9d51766d2e1d1c3c0d9550d0cb839203633d6ec6 (diff) | |
| download | STC-modified-e1a353c8a82315d9456c2f33e3e4416b5f444800.tar.gz STC-modified-e1a353c8a82315d9456c2f33e3e4416b5f444800.zip | |
Fixed bug in crange. Could only be iterated once.
Diffstat (limited to 'include')
| -rw-r--r-- | include/stc/ccommon.h | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/include/stc/ccommon.h b/include/stc/ccommon.h index bae0b68f..7b7dc283 100644 --- a/include/stc/ccommon.h +++ b/include/stc/ccommon.h @@ -217,7 +217,7 @@ STC_INLINE char* c_strnstrn(const char *s, const char *needle, ; (_inc > 0) ^ (i > _end); i += _inc) typedef long long crange_value; -struct {crange_value val, end, step; } typedef crange; +struct {crange_value start, end, step, val; } typedef crange; struct {crange_value *ref, end, step; } typedef crange_iter; #define crange_init() crange_make3(0, INTMAX_MAX, 1) #define crange_make(...) c_MACRO_OVERLOAD(crange_make, __VA_ARGS__) @@ -225,8 +225,8 @@ struct {crange_value *ref, end, step; } typedef crange_iter; #define crange_make2(start, stop) crange_make3(start, stop, 1) STC_INLINE crange crange_make3(crange_value start, crange_value stop, crange_value step) { crange r = {start, stop - (step > 0), step}; return r; } -STC_INLINE crange_iter crange_begin(crange* self) - { crange_iter it = {&self->val, self->end, self->step}; return it; } +STC_INLINE crange_iter crange_begin(crange* self) + { self->val = self->start; crange_iter it = {&self->val, self->end, self->step}; return it; } STC_INLINE crange_iter crange_end(crange* self) { crange_iter it = {NULL}; return it; } STC_INLINE void crange_next(crange_iter* it) |
