diff options
author | metagn <metagngn@gmail.com> | 2024-09-19 08:20:29 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-09-19 07:20:29 +0200 |
commit | 05a7a48a2bcc21c772bd35703fa52e374d25febe (patch) | |
tree | 6b02418bd9e9751b771ef7402d449ad6b35e1ded /compiler | |
parent | 84f5060e9478d1f627aadc1ff90228dc2f297028 (diff) | |
download | Nim-05a7a48a2bcc21c772bd35703fa52e374d25febe.tar.gz |
fix inverted order of resolved `tyFromExpr` match (#24138)
fixes #22276 When matching against `tyFromExpr`, the compiler tries to instantiate it then operates on the potentially instantiated type. But the way it does this is inverted, it checks if the instantiated type matches the argument type, not if the argument type matches the instantiated type. This has been the case since https://github.com/nim-lang/Nim/commit/ac271e76b18110bea8046af64ceccd6b804978dd#diff-251afcd01d239369019495096c187998dd6695b6457528953237a7e4a10f7138, which doesn't comment on it, so I'm guessing this isn't intended. I don't know if it would break anything though.
Diffstat (limited to 'compiler')
-rw-r--r-- | compiler/sigmatch.nim | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/compiler/sigmatch.nim b/compiler/sigmatch.nim index 873eefd76..96cbc6359 100644 --- a/compiler/sigmatch.nim +++ b/compiler/sigmatch.nim @@ -2113,15 +2113,15 @@ proc typeRel(c: var TCandidate, f, aOrig: PType, # not resolved result = isNone of tyTypeDesc: - result = typeRel(c, a, reevaluated.base, flags) + result = typeRel(c, reevaluated.base, a, flags) of tyStatic: - result = typeRel(c, a, reevaluated.base, flags) + result = typeRel(c, reevaluated.base, a, flags) if result != isNone and reevaluated.n != nil: if not exprStructuralEquivalent(aOrig.n, reevaluated.n): result = isNone else: # bug #14136: other types are just like 'tyStatic' here: - result = typeRel(c, a, reevaluated, flags) + result = typeRel(c, reevaluated, a, flags) if result != isNone and reevaluated.n != nil: if not exprStructuralEquivalent(aOrig.n, reevaluated.n): result = isNone |