mirror of
https://github.com/ziglang/zig.git
synced 2026-02-12 20:37:54 +00:00
Refactor to sema.typeHasOnePossibleValue
This commit is contained in:
parent
870341e32e
commit
e99b1b398a
63
src/Sema.zig
63
src/Sema.zig
@ -13341,28 +13341,14 @@ fn zirTruncate(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Ai
|
||||
const target = sema.mod.getTarget();
|
||||
const dest_info = dest_scalar_ty.intInfo(target);
|
||||
|
||||
if (dest_info.bits == 0) {
|
||||
if (is_vector) {
|
||||
return sema.addConstant(
|
||||
dest_ty,
|
||||
try Value.Tag.repeated.create(sema.arena, Value.zero),
|
||||
);
|
||||
} else {
|
||||
return sema.addConstant(dest_ty, Value.zero);
|
||||
}
|
||||
if (try sema.typeHasOnePossibleValue(block, dest_ty_src, dest_ty)) |val| {
|
||||
return sema.addConstant(dest_ty, val);
|
||||
}
|
||||
|
||||
if (operand_scalar_ty.zigTypeTag() != .ComptimeInt) {
|
||||
const operand_info = operand_ty.intInfo(target);
|
||||
if (operand_info.bits == 0) {
|
||||
if (is_vector) {
|
||||
return sema.addConstant(
|
||||
dest_ty,
|
||||
try Value.Tag.repeated.create(sema.arena, Value.zero),
|
||||
);
|
||||
} else {
|
||||
return sema.addConstant(dest_ty, Value.zero);
|
||||
}
|
||||
if (try sema.typeHasOnePossibleValue(block, operand_src, operand_ty)) |val| {
|
||||
return sema.addConstant(operand_ty, val);
|
||||
}
|
||||
|
||||
if (operand_info.signedness != dest_info.signedness) {
|
||||
@ -13461,15 +13447,9 @@ fn zirBitCount(
|
||||
_ = try checkIntOrVector(sema, block, operand, operand_src);
|
||||
const target = sema.mod.getTarget();
|
||||
const bits = operand_ty.intInfo(target).bits;
|
||||
if (bits == 0) {
|
||||
switch (operand_ty.zigTypeTag()) {
|
||||
.Vector => return sema.addConstant(
|
||||
try Type.vector(sema.arena, operand_ty.vectorLen(), Type.comptime_int),
|
||||
try Value.Tag.repeated.create(sema.arena, Value.zero),
|
||||
),
|
||||
.Int => return Air.Inst.Ref.zero,
|
||||
else => unreachable,
|
||||
}
|
||||
|
||||
if (try sema.typeHasOnePossibleValue(block, operand_src, operand_ty)) |val| {
|
||||
return sema.addConstant(operand_ty, val);
|
||||
}
|
||||
|
||||
const result_scalar_ty = try Type.smallestUnsignedInt(sema.arena, bits);
|
||||
@ -13528,10 +13508,12 @@ fn zirByteSwap(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Ai
|
||||
);
|
||||
}
|
||||
|
||||
if (try sema.typeHasOnePossibleValue(block, operand_src, operand_ty)) |val| {
|
||||
return sema.addConstant(operand_ty, val);
|
||||
}
|
||||
|
||||
switch (operand_ty.zigTypeTag()) {
|
||||
.Int, .ComptimeInt => {
|
||||
if (bits == 0) return Air.Inst.Ref.zero;
|
||||
|
||||
const runtime_src = if (try sema.resolveMaybeUndefVal(block, operand_src, operand)) |val| {
|
||||
if (val.isUndef()) return sema.addConstUndef(operand_ty);
|
||||
const result_val = try val.byteSwap(operand_ty, target, sema.arena);
|
||||
@ -13542,13 +13524,6 @@ fn zirByteSwap(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!Ai
|
||||
return block.addTyOp(.byte_swap, operand_ty, operand);
|
||||
},
|
||||
.Vector => {
|
||||
if (bits == 0) {
|
||||
return sema.addConstant(
|
||||
operand_ty,
|
||||
try Value.Tag.repeated.create(sema.arena, Value.zero),
|
||||
);
|
||||
}
|
||||
|
||||
const runtime_src = if (try sema.resolveMaybeUndefVal(block, operand_src, operand)) |val| {
|
||||
if (val.isUndef())
|
||||
return sema.addConstUndef(operand_ty);
|
||||
@ -13578,21 +13553,13 @@ fn zirBitReverse(sema: *Sema, block: *Block, inst: Zir.Inst.Index) CompileError!
|
||||
const operand_src: LazySrcLoc = .{ .node_offset_builtin_call_arg1 = inst_data.src_node };
|
||||
const operand = sema.resolveInst(inst_data.operand);
|
||||
const operand_ty = sema.typeOf(operand);
|
||||
const scalar_ty = try sema.checkIntOrVectorAllowComptime(block, operand, operand_src);
|
||||
_ = try sema.checkIntOrVectorAllowComptime(block, operand, operand_src);
|
||||
|
||||
const target = sema.mod.getTarget();
|
||||
const bits = scalar_ty.intInfo(target).bits;
|
||||
if (bits == 0) {
|
||||
switch (operand_ty.zigTypeTag()) {
|
||||
.Vector => return sema.addConstant(
|
||||
operand_ty,
|
||||
try Value.Tag.repeated.create(sema.arena, Value.zero),
|
||||
),
|
||||
.Int => return Air.Inst.Ref.zero,
|
||||
else => unreachable,
|
||||
}
|
||||
if (try sema.typeHasOnePossibleValue(block, operand_src, operand_ty)) |val| {
|
||||
return sema.addConstant(operand_ty, val);
|
||||
}
|
||||
|
||||
const target = sema.mod.getTarget();
|
||||
switch (operand_ty.zigTypeTag()) {
|
||||
.Int, .ComptimeInt => {
|
||||
const runtime_src = if (try sema.resolveMaybeUndefVal(block, operand_src, operand)) |val| {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user