aboutsummaryrefslogtreecommitdiff
path: root/src/compile/indexing.c
diff options
context:
space:
mode:
authorBruce Hill <bruce@bruce-hill.com>2025-09-01 13:20:17 -0400
committerBruce Hill <bruce@bruce-hill.com>2025-09-01 13:20:17 -0400
commitc778c8822f1c8acf981e26f7b860a384c94cff6f (patch)
tree550e52a4037b202de00d9f43321c996fd964c2a9 /src/compile/indexing.c
parent639d5ddfca562e5b3645955551be244b5e8ca9c6 (diff)
parentee020c72d92c3807fa4afcd1e170d3df81688b97 (diff)
Merge branch 'main' into optional-list-indexing
Diffstat (limited to 'src/compile/indexing.c')
-rw-r--r--src/compile/indexing.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/src/compile/indexing.c b/src/compile/indexing.c
index 9d3501c9..9d21eb4b 100644
--- a/src/compile/indexing.c
+++ b/src/compile/indexing.c
@@ -43,8 +43,8 @@ Text_t compile_indexing(env_t *env, ast_t *ast, bool checked) {
: Texts("(Int64_t)(", compile(env, indexing->index), ")"));
if (checked) {
int64_t start = (int64_t)(ast->start - ast->file->text), end = (int64_t)(ast->end - ast->file->text);
- return Texts("List_get_checked(", list, ", ", index_code, ", ", compile_type(item_type), ", ",
- String(start), ", ", String(end), ")");
+ return Texts("List_get_checked(", list, ", ", index_code, ", ", compile_type(item_type), ", ", start, ", ",
+ end, ")");
} else {
return Texts("List_get(", list, ", ", index_code, ", ", compile_type(item_type), ", value, ",
promote_to_optional(item_type, Text("value")), ", ", compile_none(item_type), ")");
@@ -61,8 +61,8 @@ Text_t compile_indexing(env_t *env, ast_t *ast, bool checked) {
int64_t start = (int64_t)(ast->start - ast->file->text), end = (int64_t)(ast->end - ast->file->text);
return Texts("Table$get_checked(", compile_to_pointer_depth(env, indexing->indexed, 0, false), ", ",
compile_type(table_type->key_type), ", ", compile_type(table_type->value_type), ", ",
- compile(env, indexing->index), ", ", String(start), ", ", String(end), ", ",
- compile_type_info(container_t), ")");
+ compile(env, indexing->index), ", ", start, ", ", end, ", ", compile_type_info(container_t),
+ ")");
} else {
return Texts("Table$get_optional(", compile_to_pointer_depth(env, indexing->indexed, 0, false), ", ",
compile_type(table_type->key_type), ", ", compile_type(table_type->value_type), ", ",
@@ -76,8 +76,7 @@ Text_t compile_indexing(env_t *env, ast_t *ast, bool checked) {
if (checked) {
int64_t start = (int64_t)(ast->start - ast->file->text), end = (int64_t)(ast->end - ast->file->text);
return Texts("Text$cluster_checked(", compile_to_pointer_depth(env, indexing->indexed, 0, false), ", ",
- compile_to_type(env, indexing->index, Type(BigIntType)), ", ", String(start), ", ",
- String(end), ")");
+ compile_to_type(env, indexing->index, Type(BigIntType)), ", ", start, ", ", end, ")");
} else {
return Texts("Text$cluster(", compile_to_pointer_depth(env, indexing->indexed, 0, false), ", ",
compile_to_type(env, indexing->index, Type(BigIntType)), ")");