vec.c 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #include "vec.h"
  2. #include <string.h>
  3. #include "stdlib.h"
  4. struct vec {
  5. size_t length;
  6. size_t capacity;
  7. void** buf;
  8. };
  9. static void vec_enlarge(struct vec* self) {
  10. self->buf = realloc(self->buf, self->capacity * sizeof(void*) * 2);
  11. self->capacity = self->capacity * 2;
  12. }
  13. void *new_vec() {
  14. struct vec* vec = malloc(sizeof(struct vec));
  15. vec->length = 0;
  16. vec->capacity = 16;
  17. vec->buf = malloc(16 * sizeof(void*));
  18. return vec;
  19. }
  20. void vec_push_back(void *self_, void* obj) {
  21. struct vec *self = self_;
  22. if (self->length == self->capacity) vec_enlarge(self);
  23. self->buf[self->length] = obj;
  24. self->length++;
  25. }
  26. void* vec_get(void *self_, size_t n) {
  27. struct vec *self = self_;
  28. if (n < 0 || n >= self->length) return NULL;
  29. return self->buf[n];
  30. }
  31. void vec_erase(void *self_, size_t n) {
  32. struct vec *self = self_;
  33. if (self->length <= n) {
  34. return;
  35. }
  36. memmove(self->buf + n, self->buf + n + 1, (self->length - n - 1) * sizeof(void*));
  37. self->length--;
  38. }
  39. size_t vec_size(void *self_) {
  40. struct vec *self = self_;
  41. return self->length;
  42. }
  43. void vec_reserve(void *self_, size_t n) {
  44. struct vec *self = self_;
  45. if (n <= self->capacity) {
  46. return;
  47. }
  48. self->buf = malloc(sizeof(void*) * n);
  49. self->capacity = n;
  50. }
  51. void vec_insert(void *self_, size_t pos, void *obj) {
  52. struct vec *self = self_;
  53. if (self->length == self->capacity) {
  54. vec_enlarge(self);
  55. }
  56. if (pos > self->length || pos < 0) return;
  57. memmove(self->buf + pos + 1, self->buf + pos, sizeof(void*) * (self->length - pos));
  58. self->buf[pos] = obj;
  59. self->length++;
  60. }