aboutsummaryrefslogtreecommitdiff
path: root/vec.c
blob: 84f694497886eeae02dba87ef0c8bded29a8a463 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* Copyright (C) 2025 Aryadev Chavali

 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the Unlicense
 * for details.

 * You may distribute and modify this code under the terms of the
 * Unlicense, which you should have received a copy of along with this
 * program.  If not, please go to <https://unlicense.org/>.

 * Created: 2025-08-20
 * Description: Stable Vector implementation
 */

#include <malloc.h>
#include <string.h>

#include "./alisp.h"

void vec_free(vec_t *vec)
{
  if (!vec)
    return;
  if (vec->data)
    free(vec->data);
  memset(vec, 0, sizeof(*vec));
}

void vec_ensure_free(vec_t *vec, u64 size)
{
  if (!vec)
    return;
  if (vec->capacity - vec->size < size)
  {
    vec->capacity = MAX(vec->capacity * VEC_MULT, vec->size + size);
    vec->data     = realloc(vec->data, vec->capacity);
  }
}

void vec_append(vec_t *vec, void *ptr, u64 size)
{
  if (!vec)
    return;
  vec_ensure_free(vec, size);
  memcpy(vec->data + vec->size, ptr, size);
  vec->size += size;
}

void vec_clone(vec_t *dest, vec_t *src)
{
  if (!src || !dest)
    return;
  dest       = src;
  dest->data = calloc(1, dest->capacity);
  memcpy(dest->data, src->data, src->size);
}