diff options
| author | Vexu <git@vexu.eu> | 2020-10-16 23:11:35 +0300 |
|---|---|---|
| committer | Vexu <git@vexu.eu> | 2020-10-30 15:58:13 +0200 |
| commit | 4155d2ae242d18c0bc280aa22f733bf7dcb6e1f0 (patch) | |
| tree | f63b33a1ebb55b9c74f90bfd230b55104d9da473 /src/codegen.zig | |
| parent | 3c96d799531dbfaf4127ed2fcaa0e69658f90e23 (diff) | |
| download | zig-4155d2ae242d18c0bc280aa22f733bf7dcb6e1f0.tar.gz zig-4155d2ae242d18c0bc280aa22f733bf7dcb6e1f0.zip | |
stage2: switch ranges and multi item prongs
Diffstat (limited to 'src/codegen.zig')
| -rw-r--r-- | src/codegen.zig | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/src/codegen.zig b/src/codegen.zig index 0fea2ae216..1745f86a94 100644 --- a/src/codegen.zig +++ b/src/codegen.zig @@ -758,6 +758,8 @@ fn Function(comptime arch: std.Target.Cpu.Arch) type { .br => return self.genBr(inst.castTag(.br).?), .breakpoint => return self.genBreakpoint(inst.src), .brvoid => return self.genBrVoid(inst.castTag(.brvoid).?), + .booland => return self.genBoolOp(inst.castTag(.booland).?), + .boolor => return self.genBoolOp(inst.castTag(.boolor).?), .call => return self.genCall(inst.castTag(.call).?), .cmp_lt => return self.genCmp(inst.castTag(.cmp_lt).?, .lt), .cmp_lte => return self.genCmp(inst.castTag(.cmp_lte).?, .lte), @@ -782,11 +784,11 @@ fn Function(comptime arch: std.Target.Cpu.Arch) type { .retvoid => return self.genRetVoid(inst.castTag(.retvoid).?), .store => return self.genStore(inst.castTag(.store).?), .sub => return self.genSub(inst.castTag(.sub).?), + .switchbr => return self.genSwitch(inst.castTag(.switchbr).?), .unreach => return MCValue{ .unreach = {} }, .unwrap_optional => return self.genUnwrapOptional(inst.castTag(.unwrap_optional).?), .wrap_optional => return self.genWrapOptional(inst.castTag(.wrap_optional).?), .varptr => return self.genVarPtr(inst.castTag(.varptr).?), - .switchbr => return self.genSwitch(inst.castTag(.switchbr).?), } } @@ -2030,6 +2032,12 @@ fn Function(comptime arch: std.Target.Cpu.Arch) type { return self.brVoid(inst.base.src, inst.block); } + fn genBoolOp(self: *Self, inst: *ir.Inst.BinOp) !MCValue { + switch (arch) { + else => return self.fail(inst.base.src, "TODO genBoolOp for {}", .{self.target.cpu.arch}), + } + } + fn brVoid(self: *Self, src: usize, block: *ir.Inst.Block) !MCValue { // Emit a jump with a relocation. It will be patched up after the block ends. try block.codegen.relocs.ensureCapacity(self.gpa, block.codegen.relocs.items.len + 1); |
