mirror of
https://github.com/ziglang/zig.git
synced 2026-02-14 05:20:34 +00:00
added error for implicit cast from *const T to *[1]T. credit: @kristate
This commit is contained in:
parent
a4afacd182
commit
4a64f26627
@ -11090,6 +11090,7 @@ static IrInstruction *ir_analyze_ptr_to_array(IrAnalyze *ira, IrInstruction *sou
|
||||
Error err;
|
||||
if ((err = type_resolve(ira->codegen, target->value.type->data.pointer.child_type, ResolveStatusAlignmentKnown)))
|
||||
return ira->codegen->invalid_instruction;
|
||||
assert((wanted_type->data.pointer.is_const && target->value.type->data.pointer.is_const) || !target->value.type->data.pointer.is_const);
|
||||
wanted_type = adjust_ptr_align(ira->codegen, wanted_type, get_ptr_align(ira->codegen, target->value.type));
|
||||
ZigType *array_type = wanted_type->data.pointer.child_type;
|
||||
assert(array_type->id == ZigTypeIdArray);
|
||||
@ -11651,7 +11652,11 @@ static IrInstruction *ir_analyze_cast(IrAnalyze *ira, IrInstruction *source_inst
|
||||
if (array_type->id == ZigTypeIdArray && array_type->data.array.len == 1 &&
|
||||
types_match_const_cast_only(ira, array_type->data.array.child_type,
|
||||
actual_type->data.pointer.child_type, source_node,
|
||||
!wanted_type->data.pointer.is_const).id == ConstCastResultIdOk)
|
||||
!wanted_type->data.pointer.is_const).id == ConstCastResultIdOk &&
|
||||
// This should be the job of `types_match_const_cast_only`
|
||||
// but `types_match_const_cast_only` only gets info for child_types
|
||||
((wanted_type->data.pointer.is_const && actual_type->data.pointer.is_const) ||
|
||||
!actual_type->data.pointer.is_const))
|
||||
{
|
||||
if ((err = type_resolve(ira->codegen, wanted_type->data.pointer.child_type,
|
||||
ResolveStatusAlignmentKnown)))
|
||||
|
||||
@ -5869,4 +5869,27 @@ pub fn addCases(cases: *tests.CompileErrorContext) void {
|
||||
\\ comptime testCompileLog(Bar{.X = 123});
|
||||
\\}
|
||||
, "tmp.zig:6:5: error: found compile log statement");
|
||||
|
||||
cases.add(
|
||||
"attempted implicit cast from *const T to *[1]T",
|
||||
\\export fn entry(byte: u8) void {
|
||||
\\ const w: i32 = 1234;
|
||||
\\ var x: *const i32 = &w;
|
||||
\\ var y: *[1]i32 = x;
|
||||
\\ y[0] += 1;
|
||||
\\}
|
||||
,
|
||||
"tmp.zig:4:22: error: expected type '*[1]i32', found '*const i32'",
|
||||
"tmp.zig:4:22: note: pointer type child 'i32' cannot cast into pointer type child '[1]i32'",
|
||||
);
|
||||
|
||||
cases.add(
|
||||
"attempted implicit cast from *const T to []T",
|
||||
\\export fn entry() void {
|
||||
\\ const u: u32 = 42;
|
||||
\\ const x: []u32 = &u;
|
||||
\\}
|
||||
,
|
||||
"tmp.zig:3:23: error: expected type '[]u32', found '*const u32'",
|
||||
);
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user