aboutsummaryrefslogtreecommitdiff
path: root/src/da.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/da.h')
-rw-r--r--src/da.h121
1 files changed, 0 insertions, 121 deletions
diff --git a/src/da.h b/src/da.h
deleted file mode 100644
index 8891971..0000000
--- a/src/da.h
+++ /dev/null
@@ -1,121 +0,0 @@
-/*
- * Simple & stupid dynamic array single-header implementation. You can use the
- * macros defined in this file with any structure that has the following fields:
- *
- * struct dyn_array {
- * T *buf // Array of items
- * N len // Length of array
- * N cap // Capacity of array
- * }
- *
- * The type ‘T’ is whatever type you want to store. The type ‘N’ is any numeric
- * type — most likely ‘size_t’ — but it could be sized as well.
- *
- * The daremove() macro also doesn’t bother with shrinking your array when the
- * length is far lower than the capacity. If you care about that, do it
- * yourself.
- *
- * Remember to call free() on your dynamic arrays ‘buf’ field after use.
- *
- *
- * Macro Overview
- * ――――――――――――――
- * The argument ‘a’ to all of the below macros is a pointer to the dynamic array
- * structure.
- *
- * dainit(a, n) Initialize the array with a capacity of ‘n’ items.
- * dapush(a, x) Append the item ‘x’ to the array
- * daremove(a, x) Remove the item at index ‘x’ from the array
- * da_remove_range(a, x, y) Remove the items between the range [x, y)
- * da_foreach(a, p) Iterate the pointer ‘p’ over each element of the
- * array. The type of ‘p’ is inferred.
- *
- * The ‘dapush()’ macro will double the arrays capacity when it gets full. If
- * you would like your arrays to grow with a different scale, edit this file.
- *
- *
- * Example
- * ―――――――
- *
- * struct {
- * int *buf;
- * size_t len, cap;
- * } nums;
- *
- * // Initialize nums with capacity == 4
- * dainit(&nums, 4);
- *
- * // Append 69, 1337, and 420 to nums
- * dapush(&nums, 69);
- * dapush(&nums, 1337);
- * dapush(&nums, 420);
- *
- * da_foreach (&nums, n) {
- * int x = *n << 1;
- * printf("n = %d; n² = %d\n", *n, x);
- * }
- *
- * // Remove 1337 and 420 from nums
- * da_remove_range(&nums, 1, 3);
- *
- * // Remove 69 from nums
- * daremove(&nums, 0);
- */
-
-#ifndef MANGO_DA_H
-#define MANGO_DA_H
-
-#include <err.h>
-#include <errno.h>
-#include <stddef.h>
-#include <stdint.h>
-#include <stdlib.h>
-#include <string.h>
-
-#if __STDC_VERSION__ >= 202311L
-# define DA_NULL nullptr
-#else
-# define DA_NULL NULL
-#endif
-
-#define DA_ALLOC(p, n) \
- do { \
- if ((n) && SIZE_MAX / (n) < sizeof(*(p))) { \
- errno = EOVERFLOW; \
- err(EXIT_FAILURE, "realloc"); \
- } \
- if (!((p) = realloc((p), (n) * sizeof(*(p))))) \
- err(EXIT_FAILURE, "realloc"); \
- } while (0)
-
-#define dainit(a, n) \
- do { \
- (a)->buf = DA_NULL; \
- (a)->cap = (n); \
- (a)->len = 0; \
- if (n) \
- DA_ALLOC((a)->buf, (a)->cap); \
- } while (0)
-
-#define dapush(a, x) \
- do { \
- if ((a)->len >= (a)->cap) { \
- (a)->cap = (a)->cap ? (a)->cap * 2 : 1; \
- DA_ALLOC((a)->buf, (a)->cap); \
- } \
- (a)->buf[(a)->len++] = (x); \
- } while (0)
-
-#define daremove(a, i) da_remove_range((a), (i), (i) + 1)
-
-#define da_remove_range(a, i, j) \
- do { \
- memmove((a)->buf + (i), (a)->buf + (j), \
- ((a)->len - (j)) * sizeof(*(a)->buf)); \
- (a)->len -= j - i; \
- } while (0)
-
-#define da_foreach(a, p) \
- for (typeof((a)->buf) p = (a)->buf; (size_t)(p - (a)->buf) < (a)->len; p++)
-
-#endif /* !MANGO_DA_H */