From 65cf5a8e44f299bb24e139cc25df717f1ddba455 Mon Sep 17 00:00:00 2001 From: Jimmi Holst Christensen Date: Sat, 6 Apr 2019 11:04:55 +0200 Subject: [PATCH] removed todo comment and added test --- src/ir.cpp | 3 --- test/stage1/behavior/for.zig | 6 ++++++ 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/ir.cpp b/src/ir.cpp index 102ccc6f4a..c572e3c885 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -16309,9 +16309,6 @@ static IrInstruction *ir_analyze_instruction_to_ptr_type(IrAnalyze *ira, ZigType *ptr_type; if (type_entry->id == ZigTypeIdArray) { - // TODO: Allow capturing pointer to const array. - // const a = "123"; for (a) |*c| continue; - // error: expected type '*u8', found '*const u8' ptr_type = get_pointer_to_type(ira->codegen, type_entry->data.array.child_type, ptr_ptr_type->data.pointer.is_const); } else if (is_array_ref(type_entry)) { ptr_type = get_pointer_to_type(ira->codegen, diff --git a/test/stage1/behavior/for.zig b/test/stage1/behavior/for.zig index b10dd14fa4..45a5334d1a 100644 --- a/test/stage1/behavior/for.zig +++ b/test/stage1/behavior/for.zig @@ -27,7 +27,13 @@ test "for loop with pointer elem var" { mem.copy(u8, target[0..], source); mangleString(target[0..]); expect(mem.eql(u8, target, "bcdefgh")); + + for (source) |*c, i| + expect(@typeOf(c) == *const u8); + for (target) |*c, i| + expect(@typeOf(c) == *u8); } + fn mangleString(s: []u8) void { for (s) |*c| { c.* += 1;