Commit 63807bf
committed
Address #49 code review: gitignore stub, reserved idents, collision/leak/polarity guards
Fixes the four review findings on the #39 views work, all with probe-derived
golden coverage (new case views-polarity locks the contract edges):
1. CI-red (vendor stub untracked): the vendor-views fixture's @floating-ui stub
was swallowed by the global node_modules/ ignore, so CI checked out a tree
without it, the vendor trial found nothing, and the golden diverged. Added a
gitignore exception for test/golden/cases/*/node_modules/ and committed the
stub. The Tainted rejection path is now actually exercised in CI.
2. Reserved-word literals compiled-broken: emit's lowerIdent used a hand-rolled
reserved regex that missed 'true'/'lazy' (emitted "let true: t", rejected by
ReScript) and disagreed with extract's note. Unified ONE RESCRIPT_RESERVED
set in stdlib-types, imported by both extract and emit, so output is true_ /
lazy_ and the prop note always matches the emitted code.
3. Silent variant drops now flag (all-cases-or-flag): two arms producing the
same constructor ident ('trap-focus' vs 'trapFocus', or two anonymous fns)
now REJECT the whole module (prop stays review) instead of emit's seen-dedup
quietly dropping the second variant. Anonymous __type fn/array members are
named Fn / derived from the element record name, so no fromType/fromTypes
leak reaches the output (real reach: react-day-picker Disabled.fromType is
now Disabled.fromFn).
4. Receive-position regression: construct-only views (literal/none arms) reaching
a callback PARAM produced an uninspectable black box. Added produce/receive
POLARITY tracking that flips at every fn boundary (params !P, return P) and no
longer leaks ctx.inFnReturn into nested params; construct-only views are gated
on a genuinely consumer-produced position, else the honest 'a salvage / flag.
Minors: trialVendorRecord now fully rolls back minted names + ctx.typeVars on a
failed trial (no Rect -> Rect2 pollution); dropped its unused depth param;
documented the vendor gate's real scope (@floating-ui + styled-components).
39 goldens match + compile; consumer-side usage compile-verified; base-ui
194/1/0 unchanged; bench 8/8 PASS, no DEGRADED. TYPE_MAPPING + CHANGELOG.1 parent 2f0f5b4 commit 63807bf
24 files changed
Lines changed: 229 additions & 59 deletions
File tree
- benchmark/baselines
- _base-ui-components_react/bindings
- react-day-picker/bindings
- docs
- src
- test/golden/cases
- vendor-views
- expected
- node_modules/@floating-ui/stub
- views-polarity
- expected
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
3 | 6 | | |
4 | 7 | | |
5 | 8 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
35 | | - | |
| 35 | + | |
36 | 36 | | |
37 | 37 | | |
38 | 38 | | |
| |||
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
| 6 | + | |
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
Lines changed: 3 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
| 13 | + | |
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| |||
36 | 36 | | |
37 | 37 | | |
38 | 38 | | |
39 | | - | |
| 39 | + | |
40 | 40 | | |
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
44 | 44 | | |
45 | 45 | | |
46 | 46 | | |
47 | | - | |
| 47 | + | |
48 | 48 | | |
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
| 6 | + | |
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
| 6 | + | |
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
| 6 | + | |
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
6 | | - | |
| 6 | + | |
7 | 7 | | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
Lines changed: 2 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
7 | | - | |
| 7 | + | |
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
13 | | - | |
| 13 | + | |
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
62 | 62 | | |
63 | 63 | | |
64 | 64 | | |
65 | | - | |
| 65 | + | |
66 | 66 | | |
67 | 67 | | |
68 | 68 | | |
| |||
0 commit comments