This PR reverts #12000, which introduced a regression where `simp` incorrectly rejects valid rewrites for perm lemmas. The issue is that `NameGenerator.mkChild` creates names that don't maintain the ordering assumption used by `acLt` for perm lemma decisions. For example, after the change: - Child generator creates names like `_uniq.102.2` - Parent continues with `_uniq.7` - But `Name.lt (.num (.num `_uniq 102) 2) (.num `_uniq 7)` is true This causes fvars created later (in async tasks) to compare as smaller than fvars created earlier, breaking the assumption that later fvars compare greater according to `Name.lt`. Fixes #12136. 🤖 Prepared with [Claude Code](https://claude.com/claude-code) Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
20 lines
594 B
Text
20 lines
594 B
Text
{"textDocument": {"uri": "file:///533.lean"},
|
|
"position": {"line": 4, "character": 10}}
|
|
{"items":
|
|
[{"label": "Foo",
|
|
"kind": 6,
|
|
"data": ["«external:file:///533.lean»", 4, 10, 0, "f_uniq.3"]},
|
|
{"label": "F",
|
|
"kind": 6,
|
|
"data": ["«external:file:///533.lean»", 4, 10, 0, "f_uniq.7"]}],
|
|
"isIncomplete": false}
|
|
Resolution of Foo:
|
|
{"label": "Foo",
|
|
"kind": 6,
|
|
"detail": "Sort ?u",
|
|
"data": ["«external:file:///533.lean»", 4, 10, 0, "f_uniq.3"]}
|
|
Resolution of F:
|
|
{"label": "F",
|
|
"kind": 6,
|
|
"detail": "Sort ?u",
|
|
"data": ["«external:file:///533.lean»", 4, 10, 0, "f_uniq.7"]}
|