master
 1fn doTheTest() !void {
 2    const src = @src(); // do not move
 3
 4    try expect(src.line == 2);
 5    try expect(src.column == 17);
 6    try expect(std.mem.endsWith(u8, src.fn_name, "doTheTest"));
 7    try expect(std.mem.endsWith(u8, src.file, "src.zig"));
 8    try expect(src.fn_name[src.fn_name.len] == 0);
 9    try expect(src.file[src.file.len] == 0);
10    if (!std.mem.eql(u8, src.module, "test") and !std.mem.eql(u8, src.module, "root")) return error.TestFailure;
11}
12
13const std = @import("std");
14const builtin = @import("builtin");
15const expect = std.testing.expect;
16const expectEqualStrings = std.testing.expectEqualStrings;
17
18test "@src" {
19    if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest; // TODO
20    if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
21    if (builtin.zig_backend == .stage2_spirv) return error.SkipZigTest;
22
23    try doTheTest();
24}
25
26test "@src used as a comptime parameter" {
27    const S = struct {
28        fn Foo(comptime src: std.builtin.SourceLocation) type {
29            return struct {
30                comptime {
31                    _ = src;
32                }
33            };
34        }
35    };
36    const T1 = S.Foo(@src());
37    const T2 = S.Foo(@src());
38    try expect(T1 != T2);
39}
40
41test "@src in tuple passed to anytype function" {
42    if (builtin.zig_backend == .stage2_riscv64) return error.SkipZigTest; // TODO
43
44    const S = struct {
45        fn Foo(a: anytype) u32 {
46            return a[0].line;
47        }
48    };
49    const l1 = S.Foo(.{@src()});
50    const l2 = S.Foo(.{@src()});
51    try expect(l1 != l2);
52}