Commit dcfdd31
committed
Make typealias_unfold transitive
PR #5145 stopped expanding type aliases during name resolution, leaving
them as TK_TYPEALIASREF in the AST. Every site that needs the underlying
concrete type calls typealias_unfold on demand. The helper unfolded
exactly one level, so chained aliases (`type A is B; type B is (U64,
U64)`) returned another TK_TYPEALIASREF and any caller that inspected
the head of the result crashed or miscompiled. PRs #5193 and #5196
fixed two crash sites with per-site unfolds, but the same bug class
kept surfacing elsewhere.
Make typealias_unfold transitive: if reify and apply_cap produce another
TK_TYPEALIASREF, recurse until the head is concrete. The helper now
guarantees its result has a non-alias head, so callers can rely on that
postcondition. Termination is bounded by the alias chain length, which
is finite because pass/names.c rejects cyclic alias defs via
AST_FLAG_RECURSE_1 before any TK_TYPEALIASREF is emitted. A coupling
comment in names.c documents this dependency for future maintainers.
Also fixes a related #5145 regression in gentrace_needed's TRACE_TUPLE
branch, which iterated tuple element children without unfolding the
operand types and crashed on both single-level and chained tuple
aliases (found during review via an asymmetric argument/parameter
pattern). And removes the now-stale "known gap" comment in
trace_dynamic_tuple's TRACE_TUPLE branch (added by #5196) since chained
aliases now resolve to a concrete TK_TUPLETYPE through the transitive
unfold.
The new full-program-tests cover the affected codegen and expression
paths at specific exit codes so they catch both assertion crashes and
silent miscompilation.
Closes #51951 parent 4b85f11 commit dcfdd31
File tree
30 files changed
+555
-15
lines changed- src/libponyc
- codegen
- pass
- type
- test/full-program-tests
- type-alias-chained-actor-message
- type-alias-chained-array-element
- type-alias-chained-class-cap
- type-alias-chained-digestof
- type-alias-chained-dynamic-trace
- type-alias-chained-element-tuple-is-box
- type-alias-chained-self-construction
- type-alias-chained-static-trace
- type-alias-chained-triple-digestof
- type-alias-chained-tuple-destructure
- type-alias-chained-tuple-elem-access
- type-alias-chained-tuple-is
- type-alias-tuple-gentrace-needed
30 files changed
+555
-15
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
814 | 814 | | |
815 | 815 | | |
816 | 816 | | |
817 | | - | |
| 817 | + | |
818 | 818 | | |
819 | 819 | | |
820 | 820 | | |
821 | 821 | | |
822 | | - | |
823 | | - | |
824 | | - | |
825 | | - | |
826 | | - | |
827 | | - | |
828 | | - | |
829 | | - | |
830 | | - | |
| 822 | + | |
| 823 | + | |
| 824 | + | |
831 | 825 | | |
832 | 826 | | |
833 | 827 | | |
| |||
1048 | 1042 | | |
1049 | 1043 | | |
1050 | 1044 | | |
| 1045 | + | |
| 1046 | + | |
| 1047 | + | |
| 1048 | + | |
| 1049 | + | |
| 1050 | + | |
| 1051 | + | |
| 1052 | + | |
| 1053 | + | |
| 1054 | + | |
| 1055 | + | |
| 1056 | + | |
| 1057 | + | |
| 1058 | + | |
| 1059 | + | |
| 1060 | + | |
| 1061 | + | |
| 1062 | + | |
| 1063 | + | |
| 1064 | + | |
| 1065 | + | |
| 1066 | + | |
| 1067 | + | |
| 1068 | + | |
| 1069 | + | |
| 1070 | + | |
1051 | 1071 | | |
1052 | 1072 | | |
| 1073 | + | |
1053 | 1074 | | |
1054 | 1075 | | |
1055 | 1076 | | |
1056 | 1077 | | |
1057 | 1078 | | |
1058 | | - | |
| 1079 | + | |
| 1080 | + | |
| 1081 | + | |
| 1082 | + | |
1059 | 1083 | | |
1060 | 1084 | | |
1061 | 1085 | | |
1062 | | - | |
| 1086 | + | |
| 1087 | + | |
| 1088 | + | |
| 1089 | + | |
| 1090 | + | |
1063 | 1091 | | |
1064 | 1092 | | |
1065 | | - | |
| 1093 | + | |
1066 | 1094 | | |
1067 | 1095 | | |
1068 | | - | |
| 1096 | + | |
| 1097 | + | |
| 1098 | + | |
| 1099 | + | |
| 1100 | + | |
| 1101 | + | |
1069 | 1102 | | |
1070 | 1103 | | |
1071 | 1104 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
8 | 14 | | |
9 | 15 | | |
10 | 16 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
75 | 75 | | |
76 | 76 | | |
77 | 77 | | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
78 | 92 | | |
79 | 93 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
13 | 23 | | |
14 | 24 | | |
15 | 25 | | |
| |||
Lines changed: 1 addition & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
Lines changed: 38 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
Lines changed: 1 addition & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
Lines changed: 33 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
Lines changed: 1 addition & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
Lines changed: 48 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
0 commit comments