First test added, changed signature for using pointers beacause i forgot you can't actually change a parameter because c copies everything, stupid from me to forget that

This commit is contained in:
2026-03-05 08:27:36 -06:00
parent 3126be5782
commit 79f7e327ff
4 changed files with 91 additions and 24 deletions

View File

@@ -23,58 +23,77 @@ void ASTNodeArray_free(ASTNodeArray *arr) {
arr->len = 0;
}
ASTNodeArrayErr ASTNodeArray_get(const ASTNodeArray arr, size_t index, ASTNode *out) {
ASTNodeArrayErr ASTNodeArray_get(const ASTNodeArray *arr, size_t index, ASTNode *out) {
if (arr == NULL) {
return ARRAY_NULL;
}
if (out == NULL) {
return ARRAY_NULL_ARG;
}
if (arr.len == 0) {
if (arr->len == 0) {
return ARRAY_EMPTY;
}
if (index >= arr.len) {
if (index >= arr->len) {
return ARRAY_OUT_OF_BOUNDS;
}
*out = arr.data[index];
*out = arr->data[index];
return ARRAY_OK;
}
ASTNodeArrayErr ASTNodeArray_push(ASTNodeArray arr, ASTNode node) {
if (arr.len >= arr.cap) {
size_t new_cap = arr.cap * 2;
ASTNode *tmp = realloc(arr.data, new_cap * sizeof(ASTNode));
ASTNodeArrayErr ASTNodeArray_push(ASTNodeArray *arr, ASTNode node) {
if (arr == NULL) {
return ARRAY_NULL;
}
if (arr->len >= arr->cap) {
size_t new_cap = arr->cap * 2;
ASTNode *tmp = realloc(arr->data, new_cap * sizeof(ASTNode));
if (tmp == NULL) {
return ARRAY_ALLOC;
}
arr.data = tmp;
arr.cap = new_cap;
arr->data = tmp;
arr->cap = new_cap;
}
arr.data[arr.len] = node;
arr.len += 1;
arr->data[arr->len] = node;
arr->len = arr->len + 1;
return ARRAY_OK;
}
ASTNodeArrayErr ASTNodeArray_pop(ASTNodeArray arr, size_t index, ASTNode *out) {
if (arr.len == 0) {
ASTNodeArrayErr ASTNodeArray_pop(ASTNodeArray *arr, size_t index, ASTNode *out) {
if (arr == NULL) {
return ARRAY_NULL;
}
if (arr->len == 0) {
return ARRAY_EMPTY;
}
if (index >= arr.len) {
if (index >= arr->len) {
return ARRAY_OUT_OF_BOUNDS;
}
if (out != NULL) {
ASTNode node_to_delete = arr.data[index];
ASTNode node_to_delete = arr->data[index];
*out = node_to_delete;
}
for (size_t i = index; i < arr.len - 1; i++) {
arr.data[index] = arr.data[index + 1];
for (size_t i = index; i < arr->len - 1; i++) {
arr->data[index] = arr->data[index + 1];
}
return ARRAY_OK;
}
size_t ASTNodeArray_len(ASTNodeArray *arr) {
if (arr == NULL) {
return 0;
}
return arr->len;
}