Files
sx/examples/modules/0770-modules-type-fn-head-non-transitive.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

24 lines
1.1 KiB
Plaintext

// A type-returning FUNCTION head (`Make(i64)` where `Make :: ($T) -> Type`) is
// NON-transitive even when a DIRECT flat import authors the same name as a
// NON-function. `main` flat-imports `b.sx`; `b.sx` declares `Make :: 123` (a
// value const, not a type-fn) AND flat-imports `c.sx`, whose `Make` IS the
// type-returning function. The only TYPE-FN author of `Make` is two flat hops
// away (main → b → c), so the bare `Make(i64)` head must emit the
// "type 'Make' is not visible" diagnostic and poison — the visible 1-hop
// `Make :: 123` const must NOT vouch for it.
//
// Regression (Phase E4 attempt-7, finding E4-type-fn-head-hidden-by-visible-
// nonfn): before `headFnLeak` decided visibility from the ELIGIBLE FUNCTION
// authors it used the module-scope NAME predicate (`isNameVisible`), which the
// visible non-fn `Make :: 123` satisfied — so the global `fn_ast_map` type-fn
// silently instantiated and `size_of(Make(i64))` printed 8 at exit 0 instead of
// the visibility diagnostic.
#import "modules/std.sx";
#import "0770-modules-type-fn-head-non-transitive/b.sx";
main :: () -> i32 {
print("size={}\n", size_of(Make(i64)));
0
}