mirror of
https://codeberg.org/ziglang/zig.git
synced 2025-12-06 05:44:20 +00:00
This was done by regex substitution with `sed`. I then manually went over the entire diff and fixed any incorrect changes. This diff also changes a lot of `callconv(.C)` to `callconv(.c)`, since my regex happened to also trigger here. I opted to leave these changes in, since they *are* a correct migration, even if they're not the one I was trying to do!
59 lines
2.1 KiB
Zig
59 lines
2.1 KiB
Zig
const builtin = @import("builtin");
|
|
const std = @import("std");
|
|
const expect = std.testing.expect;
|
|
|
|
test "anyopaque extern symbol" {
|
|
if (builtin.zig_backend == .stage2_c) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_x86_64 and builtin.target.ofmt != .elf and builtin.target.ofmt != .macho) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_spirv64) return error.SkipZigTest;
|
|
|
|
const a = @extern(*anyopaque, .{ .name = "a_mystery_symbol" });
|
|
const b: *i32 = @alignCast(@ptrCast(a));
|
|
try expect(b.* == 1234);
|
|
}
|
|
|
|
export var a_mystery_symbol: i32 = 1234;
|
|
|
|
test "function extern symbol" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_x86_64 and builtin.target.ofmt != .elf and builtin.target.ofmt != .macho) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_spirv64) return error.SkipZigTest;
|
|
|
|
const a = @extern(*const fn () callconv(.c) i32, .{ .name = "a_mystery_function" });
|
|
try expect(a() == 4567);
|
|
}
|
|
|
|
export fn a_mystery_function() i32 {
|
|
return 4567;
|
|
}
|
|
|
|
test "function extern symbol matches extern decl" {
|
|
if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_x86_64 and builtin.target.ofmt != .elf and builtin.target.ofmt != .macho) return error.SkipZigTest;
|
|
if (builtin.zig_backend == .stage2_spirv64) return error.SkipZigTest;
|
|
|
|
const S = struct {
|
|
extern fn another_mystery_function() u32;
|
|
const same_thing = @extern(*const fn () callconv(.c) u32, .{ .name = "another_mystery_function" });
|
|
};
|
|
try expect(S.another_mystery_function() == 12345);
|
|
try expect(S.same_thing() == 12345);
|
|
}
|
|
|
|
export fn another_mystery_function() u32 {
|
|
return 12345;
|
|
}
|
|
|
|
extern fn c_extern_function() [*c]u32;
|
|
|
|
test "coerce extern function types" {
|
|
const S = struct {
|
|
export fn c_extern_function() [*c]u32 {
|
|
return null;
|
|
}
|
|
};
|
|
_ = S;
|
|
|
|
_ = @as(fn () callconv(.c) ?*u32, c_extern_function);
|
|
}
|