18 obj-c examples migrated (1308/1311-1317/1319/1320/1321/1341-1347): import
runtime classes '#foreign #objc_class("X") {' → '#objc_class("X") extern {'
(prefix→postfix) + fn/comment '#foreign'→'extern'. No 13xx snapshot asserts on
'foreign' text → all behavior-preserving; empty snapshot diff, corpus-validated.
Per the keep-list policy: KEPT identity-#foreign tests 1306/1318 (filename
ffi-*-foreign*); LEFT comment-only #foreign in the extern/export test files
1332/1348/1349 (no decls). Bare defined #objc_class examples (no #foreign) untouched
— not a purge target. Suite green (647 corpus / 444 unit, 0 failed).
26 lines
823 B
Plaintext
26 lines
823 B
Plaintext
// Phase 3 step 3.0: keyword count must equal call-site arity (excluding
|
|
// self). `something_extra(x)` — name split gives ["something", "extra"]
|
|
// = 2 keywords; arity = 1. Compiler must diagnose at the call site.
|
|
//
|
|
// Pre-3.0: bails at lower.zig with the generic Phase 3/4 diagnostic
|
|
// (which subsumes this case). Once 3.0 lands, the diagnostic becomes a
|
|
// specific "keyword count mismatch" message.
|
|
#import "modules/std.sx";
|
|
#import "modules/build.sx";
|
|
|
|
SxProbeMismatch :: #objc_class("SxProbeMismatch") extern {
|
|
something_extra :: (self: *Self, x: i32) -> i32;
|
|
}
|
|
|
|
main :: () -> i32 {
|
|
inline if OS == .macos {
|
|
inst : *SxProbeMismatch = null;
|
|
n := inst.something_extra(7);
|
|
print("n = {}\n", n);
|
|
}
|
|
inline if OS != .macos {
|
|
print("skipped (not macos)\n");
|
|
}
|
|
0
|
|
}
|