Skip to content
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

Fix Issue 21058 - __traits(getOverloads) forgets "this" with third ar… #11432

Merged
merged 2 commits into from
Jul 27, 2020

Conversation

rmanthorpe
Copy link
Contributor

…gument or if first overload is a template

@dlang-bot
Copy link
Contributor

Thanks for your pull request and interest in making D better, @rmanthorpe! We are looking forward to reviewing it, and you should be hearing from a maintainer soon.
Please verify that your PR follows this checklist:

  • My PR is fully covered with tests (you can see the coverage diff by visiting the details link of the codecov check)
  • My PR is as minimal as possible (smaller, focused PRs are easier to review than big ones)
  • I have provided a detailed rationale explaining my changes
  • New or modified functions have Ddoc comments (with Params: and Returns:)

Please see CONTRIBUTING.md for more information.


If you have addressed all reviews or aren't sure how to proceed, don't hesitate to ping us with a simple comment.

Bugzilla references

Auto-close Bugzilla Severity Description
21058 normal __traits(getOverloads) forgets "this" with third argument or if first overload is a template

Testing this PR locally

If you don't have a local development environment setup, you can use Digger to test this PR:

dub run digger -- build "master + dmd#11432"

@UplinkCoder
Copy link
Member

can you do it without changing the name e to exp ?

@rmanthorpe
Copy link
Contributor Author

The local e was shadowing another e. Is it a problem? I can just rearrange to put more into the if(fd) block.

@rmanthorpe rmanthorpe force-pushed the fix-b21058 branch 3 times, most recently from 9cdd075 to b54fcb1 Compare July 20, 2020 12:35
src/dmd/traits.d Outdated Show resolved Hide resolved
Copy link
Member

@UplinkCoder UplinkCoder left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me.
Except for one comment I made.

…gument or if first overload is a template

When the target of `getOverloads` is a `dotTemplateDeclaration` we weren't
propagating the context to the overloads. Similarly when including templates
we weren't propagating the context even if we had one. This fixed both those
problems.
@UplinkCoder
Copy link
Member

very nice and small now

src/dmd/traits.d Outdated Show resolved Hide resolved
@ghost
Copy link

ghost commented Jul 27, 2020

Thanks for this bugfix @rmanthorpe, just one thing is that for small fixups to the main commit you should rather amend, but the "auto-merge-squash" label should have more or less the same effect.

@rmanthorpe
Copy link
Contributor Author

Thanks @NilsLankila I'll bear that in mind in the future!

@dlang-bot dlang-bot merged commit 00e2aa9 into dlang:master Jul 27, 2020
ghost pushed a commit to WalterBright/dmd that referenced this pull request Aug 12, 2020
dlang#11432)

Fix Issue 21058 - __traits(getOverloads) forgets "this" with third ar…
merged-on-behalf-of: Nils Lankila <NilsLankila@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants