aboutsummaryrefslogtreecommitdiff
path: root/src/codegen
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2021-10-02 16:05:12 -0400
committerGitHub <noreply@github.com>2021-10-02 16:05:12 -0400
commit468ed7ada50c743eabe01b36d0ee9f090d80e00a (patch)
treefc5a703aaf6211db25355fcf79a945696564f3df /src/codegen
parent05d36fce9c7fde223e6657b3dc47105fbf065695 (diff)
parent83dcd9f0386a6bd70cf8d7dee3892f3b8d31d506 (diff)
downloadzig-468ed7ada50c743eabe01b36d0ee9f090d80e00a.tar.gz
zig-468ed7ada50c743eabe01b36d0ee9f090d80e00a.zip
Merge pull request #9875 from g-w1/timestimes
stage2: emit Value.repeated for `**` with array len 1
Diffstat (limited to 'src/codegen')
-rw-r--r--src/codegen/llvm.zig19
1 files changed, 18 insertions, 1 deletions
diff --git a/src/codegen/llvm.zig b/src/codegen/llvm.zig
index d223569d0f..98e12f5430 100644
--- a/src/codegen/llvm.zig
+++ b/src/codegen/llvm.zig
@@ -1024,6 +1024,7 @@ pub const DeclGen = struct {
else => |tag| return self.todo("implement const of pointer type '{}' ({})", .{ tv.ty, tag }),
},
.Array => {
+ const gpa = self.gpa;
if (tv.val.castTag(.bytes)) |payload| {
const zero_sentinel = if (tv.ty.sentinel()) |sentinel| blk: {
if (sentinel.tag() == .zero) break :blk true;
@@ -1037,7 +1038,6 @@ pub const DeclGen = struct {
);
}
if (tv.val.castTag(.array)) |payload| {
- const gpa = self.gpa;
const elem_ty = tv.ty.elemType();
const elem_vals = payload.data;
const sento = tv.ty.sentinel();
@@ -1053,6 +1053,23 @@ pub const DeclGen = struct {
@intCast(c_uint, llvm_elems.len),
);
}
+ if (tv.val.castTag(.repeated)) |payload| {
+ const val = payload.data;
+ const elem_ty = tv.ty.elemType();
+ const len = tv.ty.arrayLen();
+
+ const llvm_elems = try gpa.alloc(*const llvm.Value, len);
+ defer gpa.free(llvm_elems);
+ var i: u64 = 0;
+ while (i < len) : (i += 1) {
+ llvm_elems[i] = try self.genTypedValue(.{ .ty = elem_ty, .val = val });
+ }
+ const llvm_elem_ty = try self.llvmType(elem_ty);
+ return llvm_elem_ty.constArray(
+ llvm_elems.ptr,
+ @intCast(c_uint, llvm_elems.len),
+ );
+ }
return self.todo("handle more array values", .{});
},
.Optional => {