diff options
| author | Tyge Løvset <[email protected]> | 2021-09-08 21:16:00 +0200 |
|---|---|---|
| committer | Tyge Løvset <[email protected]> | 2021-09-08 21:16:00 +0200 |
| commit | c86e3d30299baea44f98f153c4b01ea5e244feaa (patch) | |
| tree | 7de3a473408bdee0017d8efa452dd5a095b61177 /include | |
| parent | b9e58749fb77715f4635a45377350a75ce7e0948 (diff) | |
| download | STC-modified-c86e3d30299baea44f98f153c4b01ea5e244feaa.tar.gz STC-modified-c86e3d30299baea44f98f153c4b01ea5e244feaa.zip | |
Updated most examples to newstyle. Some changes in cpque/cstack.
Diffstat (limited to 'include')
| -rw-r--r-- | include/stc/cpque.h | 26 | ||||
| -rw-r--r-- | include/stc/cstack.h | 12 |
2 files changed, 23 insertions, 15 deletions
diff --git a/include/stc/cpque.h b/include/stc/cpque.h index 20bfdb6e..4f7e0003 100644 --- a/include/stc/cpque.h +++ b/include/stc/cpque.h @@ -45,7 +45,7 @@ STC_API Self cx_memb(_clone)(Self q); STC_INLINE Self cx_memb(_init)(void)
{ return (Self){0, 0, 0}; }
-STC_INLINE Self cx_memb(_init_with_capacity)(size_t cap) {
+STC_INLINE Self cx_memb(_with_capacity)(size_t cap) {
Self out = {(cx_value_t *) c_malloc(cap*sizeof(cx_value_t)), 0, cap};
return out;
}
@@ -84,6 +84,19 @@ STC_INLINE int cx_memb(_value_compare)(const cx_value_t* x, const cx_value_t* y) return i_cmp(&rx, &ry);
}
+STC_INLINE void
+cx_memb(_push_back)(Self* self, cx_value_t value) {
+ if (self->size == self->capacity) {
+ self->capacity = self->size*3/2 + 4;
+ self->data = (cx_value_t *)c_realloc(self->data, self->capacity*sizeof value);
+ }
+ self->data[ self->size++ ] = value;
+}
+
+STC_INLINE void
+cx_memb(_pop_back)(Self* self)
+ { --self->size; i_valdel(&self->data[self->size]); }
+
/* -------------------------- IMPLEMENTATION ------------------------- */
#if !defined(STC_HEADER) || defined(STC_IMPLEMENTATION) || defined(i_imp)
@@ -100,13 +113,6 @@ cx_memb(_sift_down_)(cx_value_t* arr, size_t i, size_t n) { }
}
-STC_INLINE void
-cx_memb(_push_back_)(Self* self, cx_value_t value) {
- if (self->size == self->capacity)
- self->data = (cx_value_t *) c_realloc(self->data, (self->capacity = self->size*3/2 + 4)*sizeof value);
- self->data[ self->size++ ] = value;
-}
-
STC_DEF void
cx_memb(_make_heap)(Self* self) {
size_t n = cx_memb(_size)(*self);
@@ -125,13 +131,13 @@ STC_DEF void cx_memb(_erase_at)(Self* self, size_t idx) {
size_t n = cx_memb(_size)(*self) - 1;
self->data[idx] = self->data[n];
- --self->size;
+ cx_memb(_pop_back)(self);
cx_memb(_sift_down_)(self->data - 1, idx + 1, n);
}
STC_DEF void
cx_memb(_push)(Self* self, cx_value_t value) {
- cx_memb(_push_back_)(self, value); /* sift-up the value */
+ cx_memb(_push_back)(self, value); /* sift-up the value */
size_t n = cx_memb(_size)(*self), c = n;
cx_value_t *arr = self->data - 1;
for (; c > 1 && i_cmp(&arr[c >> 1], &value) < 0; c >>= 1)
diff --git a/include/stc/cstack.h b/include/stc/cstack.h index 42717ee8..984b8fad 100644 --- a/include/stc/cstack.h +++ b/include/stc/cstack.h @@ -32,14 +32,14 @@ #include "template.h"
#if !defined i_fwd
- cx_deftypes(_c_cstack_types, Self, i_val);
+cx_deftypes(_c_cstack_types, Self, i_val);
#endif
typedef i_valraw cx_rawvalue_t;
STC_INLINE Self cx_memb(_init)(void)
{ return (Self){0, 0, 0}; }
-STC_INLINE Self cx_memb(_init_with_capacity)(size_t cap) {
+STC_INLINE Self cx_memb(_with_capacity)(size_t cap) {
Self out = {(cx_value_t *) c_malloc(cap*sizeof(cx_value_t)), 0, cap};
return out;
}
@@ -65,11 +65,13 @@ STC_INLINE cx_value_t* cx_memb(_top)(const Self* self) { return &self->data[self->size - 1]; }
STC_INLINE void cx_memb(_pop)(Self* self)
- { --self->size; }
+ { --self->size; i_valdel(&self->data[self->size]); }
STC_INLINE void cx_memb(_push)(Self* self, cx_value_t value) {
- if (self->size == self->capacity)
- self->data = (cx_value_t *) c_realloc(self->data, (self->capacity = self->size*3/2 + 4)*sizeof value);
+ if (self->size == self->capacity) {
+ self->capacity = self->size*3/2 + 4;
+ self->data = (cx_value_t *)c_realloc(self->data, self->capacity*sizeof value);
+ }
self->data[ self->size++ ] = value;
}
|
