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:
55
src/lexer.c
55
src/lexer.c
@@ -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;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user