Commit 5d51d4474a
Changed files (2)
lib
std
zig
test
behavior
lib/std/zig/AstGen.zig
@@ -885,7 +885,7 @@ fn expr(gz: *GenZir, scope: *Scope, ri: ResultInfo, node: Ast.Node.Index) InnerE
const lhs_is_slice_sentinel = lhs_tag == .slice_sentinel;
const lhs_is_open_slice = lhs_tag == .slice_open or
(lhs_is_slice_sentinel and tree.fullSlice(full.ast.sliced).?.ast.end == 0);
- if (node_tags[node] != .slice_open and
+ if (full.ast.end != 0 and
lhs_is_open_slice and
nodeIsTriviallyZero(tree, full.ast.start))
{
@@ -897,7 +897,7 @@ fn expr(gz: *GenZir, scope: *Scope, ri: ResultInfo, node: Ast.Node.Index) InnerE
} else try expr(gz, scope, .{ .rl = .{ .coerced_ty = .usize_type } }, node_datas[full.ast.sliced].rhs);
const cursor = maybeAdvanceSourceCursorToMainToken(gz, node);
- const len = if (full.ast.end != 0) try expr(gz, scope, .{ .rl = .{ .coerced_ty = .usize_type } }, full.ast.end) else .none;
+ const len = try expr(gz, scope, .{ .rl = .{ .coerced_ty = .usize_type } }, full.ast.end);
const sentinel = if (full.ast.sentinel != 0) try expr(gz, scope, .{ .rl = .none }, full.ast.sentinel) else .none;
try emitDbgStmt(gz, cursor);
const result = try gz.addPlNode(.slice_length, node, Zir.Inst.SliceLength{
test/behavior/slice.zig
@@ -98,6 +98,23 @@ test "comptime slice of slice preserves comptime var" {
}
}
+test "open slice of open slice with sentinel" {
+ if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest; // TODO
+
+ var slice: [:0]const u8 = "hello";
+ _ = &slice;
+
+ comptime assert(@TypeOf(slice[0..][0.. :0]) == [:0]const u8);
+ try expect(slice[0..][0.. :0].len == 5);
+ try expect(slice[0..][0.. :0][0] == 'h');
+ try expect(slice[0..][0.. :0][5] == 0);
+
+ comptime assert(@TypeOf(slice[1..][0.. :0]) == [:0]const u8);
+ try expect(slice[1..][0.. :0].len == 4);
+ try expect(slice[1..][0.. :0][0] == 'e');
+ try expect(slice[1..][0.. :0][4] == 0);
+}
+
test "slice of type" {
comptime {
var types_array = [_]type{ i32, f64, type };