aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-03-08 18:50:10 +0000
committergingerBill <bill@gingerbill.org>2020-03-08 18:50:10 +0000
commitd1e670335f714875a2fe583fd7b04a78fb4812ac (patch)
tree5e66c9d682c585dd134d7e37bae586fea700fe61 /src/llvm_backend.cpp
parentc6c6c56ba997a5150462ec5d6cada973888b42c4 (diff)
Fix lb_find_or_add_entity_string_byte_slice
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp34
1 files changed, 32 insertions, 2 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 0aecebf83..a3820fa13 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -3543,8 +3543,9 @@ lbValue lb_find_or_add_entity_string(lbModule *m, String const &str) {
res.value = LLVMConstNamedStruct(lb_type(m, t_string), values, 2);
res.type = t_string;
return res;
+ } else {
+ return lb_const_value(m, t_string, exact_value_string(str));
}
- return lb_const_value(m, t_string, exact_value_string(str));
}
lbValue lb_find_or_add_entity_string_byte_slice(lbModule *m, String const &str) {
@@ -3559,8 +3560,37 @@ lbValue lb_find_or_add_entity_string_byte_slice(lbModule *m, String const &str)
res.value = LLVMConstNamedStruct(lb_type(m, t_u8_slice), values, 2);
res.type = t_u8_slice;
return res;
+ } else {
+ LLVMValueRef indices[2] = {llvm_zero32(m), llvm_zero32(m)};
+ LLVMValueRef data = LLVMConstStringInContext(m->ctx,
+ cast(char const *)str.text,
+ cast(unsigned)str.len,
+ false);
+
+
+ isize max_len = 7+8+1;
+ char *name = gb_alloc_array(heap_allocator(), char, max_len);
+ isize len = gb_snprintf(name, max_len, "csbs$%x", m->global_array_index);
+ len -= 1;
+ m->global_array_index++;
+
+ LLVMValueRef global_data = LLVMAddGlobal(m->mod, LLVMTypeOf(data), name);
+ LLVMSetInitializer(global_data, data);
+
+ LLVMValueRef ptr = LLVMConstInBoundsGEP(global_data, indices, 2);
+
+ LLVMValueRef str_len = LLVMConstInt(lb_type(m, t_int), str.len, true);
+ LLVMValueRef values[2] = {ptr, str_len};
+
+ Type *original_type = t_u8_slice;
+ lbValue res = {};
+ res.value = LLVMConstNamedStruct(lb_type(m, original_type), values, 2);
+ res.type = default_type(original_type);
+
+ map_set(&m->const_strings, key, ptr);
+
+ return res;
}
- return lb_const_value(m, t_u8_slice, exact_value_string(str));
}
isize lb_type_info_index(CheckerInfo *info, Type *type, bool err_on_not_found=true) {