const assert = @import("std").debug.assert; test "nullableType" { const x : ?bool = @generatedCode(true); if (const y ?= x) { if (y) { // OK } else { unreachable; } } else { unreachable; } const next_x : ?i32 = @generatedCode(null); const z = next_x ?? 1234; assert(z == 1234); const final_x : ?i32 = @generatedCode(13); const num = final_x ?? unreachable; assert(num == 13); } test "assignToIfVarPtr" { var maybe_bool: ?bool = true; if (const *b ?= maybe_bool) { *b = false; } assert(??maybe_bool == false); } test "rhsMaybeUnwrapReturn" { const x: ?bool = @generatedCode(true); const y = x ?? return; } test "maybe return" { maybeReturnImpl(); comptime maybeReturnImpl(); } fn maybeReturnImpl() { assert(??foo(1235)); assert(if (const _ ?= foo(null)) false else true); assert(!??foo(1234)); } fn foo(x: ?i32) -> ?bool { const value = x ?? return null; return value > 1234; } test "ifVarMaybePointer" { assert(shouldBeAPlus1(Particle {.a = 14, .b = 1, .c = 1, .d = 1}) == 15); } fn shouldBeAPlus1(p: &const Particle) -> u64 { var maybe_particle: ?Particle = *p; if (const *particle ?= maybe_particle) { particle.a += 1; } if (const particle ?= maybe_particle) { return particle.a; } return 0; } const Particle = struct { a: u64, b: u64, c: u64, d: u64, }; test "nullLiteralOutsideFunction" { const is_null = here_is_a_null_literal.context == null; assert(is_null); const is_non_null = here_is_a_null_literal.context != null; assert(!is_non_null); } const SillyStruct = struct { context: ?i32, }; const here_is_a_null_literal = SillyStruct { .context = null, }; test "testNullRuntime" { testTestNullRuntime(null); } fn testTestNullRuntime(x: ?i32) { assert(x == null); assert(!(x != null)); } test "nullableVoid" { nullableVoidImpl(); comptime nullableVoidImpl(); } fn nullableVoidImpl() { assert(bar(null) == null); assert(bar({}) != null); } fn bar(x: ?void) -> ?void { if (const _ ?= x) { return {}; } else { return null; } }