aboutsummaryrefslogtreecommitdiff
path: root/test/behavior/basic.zig
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2023-02-03 12:49:40 -0700
committerAndrew Kelley <andrew@ziglang.org>2023-02-03 12:49:40 -0700
commitfab9b7110ed1fa7bb082aad5e095047441db2b24 (patch)
tree81fef60aa45e7980dab8f3e23e5b5e92b40ee0a9 /test/behavior/basic.zig
parentd20d69b59e6b65a99f45cb6a45c14e887034dd18 (diff)
parent60935decd318498529a016eeb1379d943a7e830d (diff)
downloadzig-fab9b7110ed1fa7bb082aad5e095047441db2b24.tar.gz
zig-fab9b7110ed1fa7bb082aad5e095047441db2b24.zip
Merge remote-tracking branch 'origin/master' into llvm16
Diffstat (limited to 'test/behavior/basic.zig')
-rw-r--r--test/behavior/basic.zig20
1 files changed, 19 insertions, 1 deletions
diff --git a/test/behavior/basic.zig b/test/behavior/basic.zig
index ebca81be96..b82bfab99e 100644
--- a/test/behavior/basic.zig
+++ b/test/behavior/basic.zig
@@ -703,7 +703,7 @@ test "string concatenation" {
comptime try expect(@TypeOf(a) == *const [12:0]u8);
comptime try expect(@TypeOf(b) == *const [12:0]u8);
- const len = mem.len(b);
+ const len = b.len;
const len_with_null = len + 1;
{
var i: u32 = 0;
@@ -1125,3 +1125,21 @@ test "returning an opaque type from a function" {
};
try expect(S.foo(123).b == 123);
}
+
+test "orelse coercion as function argument" {
+ if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
+ if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
+
+ const Loc = struct { start: i32 = -1 };
+ const Container = struct {
+ a: ?Loc = null,
+ fn init(a: Loc) @This() {
+ return .{
+ .a = a,
+ };
+ }
+ };
+ var optional: ?Loc = .{};
+ var foo = Container.init(optional orelse .{});
+ try expect(foo.a.?.start == -1);
+}