From 0e9dbb4f8a145022cba56de7692d4fe56aad7a3f Mon Sep 17 00:00:00 2001 From: Bruce Hill Date: Fri, 8 Mar 2024 13:33:20 -0500 Subject: Bugfix arrays --- builtins/array.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/builtins/array.c b/builtins/array.c index 93c20bab..4b557e1c 100644 --- a/builtins/array.c +++ b/builtins/array.c @@ -44,7 +44,7 @@ public void Array__compact(array_t *arr, const TypeInfo *type) public void Array__insert(array_t *arr, const void *item, int64_t index, const TypeInfo *type) { - if (index < 1) index = arr->length + index; + if (index <= 0) index = arr->length + index + 1; if (index < 1) index = 1; else if (index > (int64_t)arr->length + 1) index = (int64_t)arr->length + 1; @@ -79,7 +79,7 @@ public void Array__insert(array_t *arr, const void *item, int64_t index, const T public void Array__insert_all(array_t *arr, array_t to_insert, int64_t index, const TypeInfo *type) { - if (index < 1) index = arr->length + index; + if (index < 1) index = arr->length + index + 1; if (index < 1) index = 1; else if (index > (int64_t)arr->length + 1) index = (int64_t)arr->length + 1; @@ -112,7 +112,7 @@ public void Array__insert_all(array_t *arr, array_t to_insert, int64_t index, co public void Array__remove(array_t *arr, int64_t index, int64_t count, const TypeInfo *type) { - if (index < 1) index = arr->length + index; + if (index < 1) index = arr->length + index + 1; if (index < 1 || index > (int64_t)arr->length || count < 1) return; -- cgit v1.2.3