Files
sx/examples/protocols/0411-protocols-impl-duplicate.sx
agra 66bdc70bf1 test: group examples into per-category folders
Move examples/*.sx and their expected/ snapshots into per-category
subfolders (examples/<category>/...). Folder = leading filename token,
with ffi-objc/ffi-jni kept whole; filenames are unchanged. The corpus
runner and LSP sweep now discover each category's expected/ dir, while
issues/ stays flat. Example 1058's repo-root-relative companion import
is made file-relative. Path strings embedded in 164 snapshots were
regenerated (path-only changes). Test-layout docs in CLAUDE.md updated.
2026-06-21 14:41:34 +03:00

27 lines
1.0 KiB
Plaintext

// Duplicate impl detection — two impls for the same (Source, Target)
// pair are both visible from the same `xx` site (because both their
// defining modules are transitively imported). The compiler must
// emit a "duplicate xx conversion" diagnostic naming both modules,
// not silently pick one or the other.
//
// Setup:
// - 180-impl-duplicate-impl-a.sx: `impl Into(Wrap) for i64` (mul by 10).
// - 180-impl-duplicate-impl-b.sx: `impl Into(Wrap) for i64` (add 100).
// - Main imports both; the `xx 7 : Wrap` site must error.
//
// Expected exit = 1, expected output = the focused diagnostic naming
// both impl modules.
#import "modules/std.sx";
// `Wrap` is declared in the shared types module; bare-import visibility is
// non-transitive, so naming it here means importing it here (not via impl-a/b).
#import "./0411-protocols-impl-duplicate-types.sx";
#import "./0411-protocols-impl-duplicate-impl-a.sx";
#import "./0411-protocols-impl-duplicate-impl-b.sx";
main :: () -> i32 {
w : Wrap = xx 7;
print("w.v = {}\n", w.v);
0
}