feat(stdlib): per-decl nominal identity + same-name shadows — close 0105 [stdlib E2]
Make same-name top-level types in different sources DISTINCT nominal types instead of collapsing last-wins in the type table (issue 0105). Registration: - internNamedTypeDecl assigns a per-decl nominal_id and populates type_decl_tids. The first author of a name keeps nominal_id 0 (byte-identical to pre-E2); a genuine cross-module shadow (>=2 distinct normalized-path authors per the import facts) gets a fresh id -> a distinct TypeId. - mergeFlat/addOwnDecl stop first-wins-dropping per-source decls (named types + non-fn const_decls) so every same-name author reaches registration; functions and var_decls (incl. #foreign extern globals) keep first-wins. Resolution (selectNominalLeaf): - own-author wins; else flatTypeAuthorCount over the transitive flat closure: >=2 distinct -> .ambiguous (loud diagnostic + poison); exactly one -> resolved; a flat author not yet findByName-registered -> .undeclared stub (not a leak). - struct-literal type names route through the same source-aware leaf. - lazyLowerFunction pins the function's own source before resolving its return type, so a shadowed signature type resolves in its module, not the caller's. Codegen: - mangleTypeName appends __n<id> for nonzero nominal_id so same-name shadows get distinct monomorph symbols (struct_to_string__Box vs __Box__n1). Library hygiene: - rename trace.sx's compiler-contracted Frame -> TraceFrame (+ the two compiler findByName sites) so it never collides with a UI/geometry Frame; the layout is structural (getFrameStructType / SxFrame), name-independent. Examples: 0752-0756 pin the five 0105 cases (distinct fields / same fields / own-wins / ambiguous / alias per-source); 0170 pins the folded anon-struct-field regression.
This commit is contained in:
4
examples/0756-modules-same-name-alias-per-source/a.sx
Normal file
4
examples/0756-modules-same-name-alias-per-source/a.sx
Normal file
@@ -0,0 +1,4 @@
|
||||
// Module A aliases `Id` to `s32`. A bare `Id` in this module resolves to A's
|
||||
// alias regardless of B's same-name alias (per-source alias visibility).
|
||||
Id :: s32;
|
||||
a_val :: () -> s64 { x : Id = 100; y : s64 = xx x; return y; }
|
||||
5
examples/0756-modules-same-name-alias-per-source/b.sx
Normal file
5
examples/0756-modules-same-name-alias-per-source/b.sx
Normal file
@@ -0,0 +1,5 @@
|
||||
// Module B aliases the SAME name `Id` to a DIFFERENT type `f64`. A bare `Id` in
|
||||
// this module resolves to B's `f64` alias, not A's `s32` — each module's alias
|
||||
// is keyed to its own source, so the two never collide last-wins.
|
||||
Id :: f64;
|
||||
b_val :: () -> f64 { x : Id = 2; return x + 0.5; }
|
||||
Reference in New Issue
Block a user