-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
remove conflicting default
call in tables.getOrDefault
#24265
Conversation
default
call in tables.getOrDefaultdefault
call in tables.getOrDefault
@@ -434,7 +434,6 @@ proc getOrDefault*[A, B](t: Table[A, B], key: A, default: B): B = | |||
let a = {'a': 5, 'b': 9}.toTable | |||
doAssert a.getOrDefault('a', 99) == 5 | |||
doAssert a.getOrDefault('z', 99) == 99 | |||
result = default(B) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No. Instead the parameter default: B
should be def: B
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did both, and did it for all parameters named default
in tables (OrderedTable
had the same bug). There are others across the codebase but they're less harmful and this PR being simpler is better.
Unfortunately this breaks named argument usage (i.e. getOrDefault(foo, bar, default = val)
). We can change the code in this repo but it might still break packages.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah I know but it's a risk I'm willing to take.
Thanks for your hard work on this PR! Hint: mm: orc; opt: speed; options: -d:release |
) fixes CI after #24265, the CI passed in the original PR somehow
fixes #23587 As explained in the issue, `getOrDefault` has a parameter named `default` that can be a proc after generic instantiation. But the parameter having a proc type [overrides all other overloads](https://github.com/nim-lang/Nim/blob/f73e03b1323cf3ed65d6996f43c8e6891c40f924/compiler/semexprs.nim#L1203) including the magic `system.default` overload and causes a compile error if the proc doesn't match the normal use of `default`. To fix this, the `result = default(B)` initializer call is removed because it's not needed, `result` is always set in `getOrDefaultImpl` when a default value is provided. This is still a suspicious behavior of the compiler but `tables` working has a higher priority. (cherry picked from commit 67ea754)
fixes #23587
As explained in the issue,
getOrDefault
has a parameter nameddefault
that can be a proc after generic instantiation. But the parameter having a proc type overrides all other overloads including the magicsystem.default
overload and causes a compile error if the proc doesn't match the normal use ofdefault
. To fix this, theresult = default(B)
initializer call is removed because it's not needed,result
is always set ingetOrDefaultImpl
when a default value is provided.This is still a suspicious behavior of the compiler but
tables
working has a higher priority.