aboutsummaryrefslogtreecommitdiff
path: root/test/runtime_safety.zig
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2019-05-08 17:39:00 -0400
committerAndrew Kelley <andrew@ziglang.org>2019-05-08 17:39:00 -0400
commit0099583bd3eccbecbb827edbde46a40cf821fecf (patch)
treecb52a8242e85f3afd3343687efd79d2d1182bb97 /test/runtime_safety.zig
parent50bbb34594eedf7a978c00edb525bcea472b554b (diff)
downloadzig-0099583bd3eccbecbb827edbde46a40cf821fecf.tar.gz
zig-0099583bd3eccbecbb827edbde46a40cf821fecf.zip
C pointers support .? operator
see #1967
Diffstat (limited to 'test/runtime_safety.zig')
-rw-r--r--test/runtime_safety.zig20
1 files changed, 20 insertions, 0 deletions
diff --git a/test/runtime_safety.zig b/test/runtime_safety.zig
index 78b45ac05f..b10accd213 100644
--- a/test/runtime_safety.zig
+++ b/test/runtime_safety.zig
@@ -1,6 +1,26 @@
const tests = @import("tests.zig");
pub fn addCases(cases: *tests.CompareOutputContext) void {
+ cases.addRuntimeSafety(".? operator on null pointer",
+ \\pub fn panic(message: []const u8, stack_trace: ?*@import("builtin").StackTrace) noreturn {
+ \\ @import("std").os.exit(126);
+ \\}
+ \\pub fn main() void {
+ \\ var ptr: ?*i32 = null;
+ \\ var b = ptr.?;
+ \\}
+ );
+
+ cases.addRuntimeSafety(".? operator on C pointer",
+ \\pub fn panic(message: []const u8, stack_trace: ?*@import("builtin").StackTrace) noreturn {
+ \\ @import("std").os.exit(126);
+ \\}
+ \\pub fn main() void {
+ \\ var ptr: [*c]i32 = null;
+ \\ var b = ptr.?;
+ \\}
+ );
+
cases.addRuntimeSafety("@ptrToInt address zero to non-optional pointer",
\\pub fn panic(message: []const u8, stack_trace: ?*@import("builtin").StackTrace) noreturn {
\\ @import("std").os.exit(126);