mirror of
https://codeberg.org/ziglang/zig.git
synced 2025-12-06 13:54:21 +00:00
parent
bce6a7c215
commit
e664bf4d81
2 changed files with 39 additions and 11 deletions
41
src/Sema.zig
41
src/Sema.zig
|
|
@ -28733,17 +28733,36 @@ fn coerceExtra(
|
||||||
break :int;
|
break :int;
|
||||||
};
|
};
|
||||||
const result_val = try val.floatFromIntAdvanced(sema.arena, inst_ty, dest_ty, pt, .sema);
|
const result_val = try val.floatFromIntAdvanced(sema.arena, inst_ty, dest_ty, pt, .sema);
|
||||||
// TODO implement this compile error
|
const fits: bool = switch (ip.indexToKey(result_val.toIntern())) {
|
||||||
//const int_again_val = try result_val.intFromFloat(sema.arena, inst_ty);
|
else => unreachable,
|
||||||
//if (!int_again_val.eql(val, inst_ty, zcu)) {
|
.undef => true,
|
||||||
// return sema.fail(
|
.float => |float| fits: {
|
||||||
// block,
|
var buffer: InternPool.Key.Int.Storage.BigIntSpace = undefined;
|
||||||
// inst_src,
|
const operand_big_int = val.toBigInt(&buffer, zcu);
|
||||||
// "type '{f}' cannot represent integer value '{f}'",
|
switch (float.storage) {
|
||||||
// .{ dest_ty.fmt(pt), val },
|
inline else => |x| {
|
||||||
// );
|
if (!std.math.isFinite(x)) break :fits false;
|
||||||
//}
|
var result_big_int: std.math.big.int.Mutable = .{
|
||||||
return Air.internedToRef(result_val.toIntern());
|
.limbs = try sema.arena.alloc(std.math.big.Limb, std.math.big.int.calcLimbLen(x)),
|
||||||
|
.len = undefined,
|
||||||
|
.positive = undefined,
|
||||||
|
};
|
||||||
|
switch (result_big_int.setFloat(x, .nearest_even)) {
|
||||||
|
.inexact => break :fits false,
|
||||||
|
.exact => {},
|
||||||
|
}
|
||||||
|
break :fits result_big_int.toConst().eql(operand_big_int);
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
};
|
||||||
|
if (!fits) return sema.fail(
|
||||||
|
block,
|
||||||
|
inst_src,
|
||||||
|
"type '{f}' cannot represent integer value '{f}'",
|
||||||
|
.{ dest_ty.fmt(pt), val.fmtValue(pt) },
|
||||||
|
);
|
||||||
|
return .fromValue(result_val);
|
||||||
},
|
},
|
||||||
else => {},
|
else => {},
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,9 @@
|
||||||
|
export fn foo() void {
|
||||||
|
const int: u16 = 65535;
|
||||||
|
const float: f16 = int;
|
||||||
|
_ = float;
|
||||||
|
}
|
||||||
|
|
||||||
|
// error
|
||||||
|
//
|
||||||
|
// :3:24: error: type 'f16' cannot represent integer value '65535'
|
||||||
Loading…
Add table
Reference in a new issue