- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
Refactor macro resolution errors + add derive macro suggestions #39752
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
Conversation
| All tests pass expect a few compile-fail tests. For some reason some macro invocations are no longer giving an error, I suspect this is a bug in my code (eg: src/test/compile-fail/macro-error.rs). Also type errors are also occuring in some tests, which leads to interesting bugs with dummy expansions (eg. src/test/compile-fail/macro-expansion-tests.rs). | 
        
          
                src/librustc_resolve/macros.rs
              
                Outdated
          
        
      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.
nit: I'd refactor away this function now that it is a one-liner.
        
          
                src/librustc_resolve/macros.rs
              
                Outdated
          
        
      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.
We could probably mem::replace the builtins -- I think the clone on an error path is fine though.
        
          
                src/libsyntax/ext/base.rs
              
                Outdated
          
        
      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.
nit: I'd name this MacroKind to be more general -- for example, it also describes macro definitions. Also, the current name is pretty close to expand::InvocationKind.
        
          
                src/libsyntax/ext/base.rs
              
                Outdated
          
        
      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.
I'd instead add a method fn kind(&self) -> MacroKind { ... } to SyntaxExtension.
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.
I didn't think that there was a 1-1 mapping, but I can see that there seems to be.
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.
Not sure that this is an improvement -- I think we should use "derive macro" (status quo) or "custom derive" here.
cc @nrc
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.
I actually agree with this, and I was meaning to change it back. Should attribute macros show something different to "macro"?
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.
I think attribute macros should say "cannot find attribute macro `...` in this scope".
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.
+1
        
          
                src/librustc_resolve/macros.rs
              
                Outdated
          
        
      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.
nit: indent
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.
I'd remove this -- confusing to have erroneous code that doesn't emit errors since we abort early.
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.
I was actually a bit confused about why we don't see a resolve error here.
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.
I believe it's because we abort here due to other errors during expansion, so we never get to finalize_current_module_macro_resolutions.
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.
Could we move the struct Self; in this test into a sub-module to avoid these extra errors?
| @keeperofdakeys It looks like all test failures are due 
 I think the best solution would be to make sure we abort before ast->hir lowering if there were unresolved macro errors, at least until we figure out how to suppress the spurious type errors. | 
| That sounds good, but I don't know what to change to do that. Where is the code that starts the lowering? | 
| I would add a  Btw, import resolution happens during expansion today, so this comment is outdated. | 
| Are attribute macros stored in  | 
| @keeperofdakeys Normally,  | 
| Also, we can import proc macro derives today via  I think the best path forward here (in this PR or later) is to check  | 
| ☔ The latest upstream changes (presumably #39572) made this pull request unmergeable. Please resolve the merge conflicts. | 
| That sounds like a good idea, however I'm unsure how to go from a  | 
a1898f4    to
    479c781      
    Compare
  
    | Mmm, for some reason the  | 
| Oh I see now,  | 
| 
 This should do the trick. 
 Right, I don't think this is too hard to fix -- wherever we add  This should actually be a simplification, since we could use e.g.  | 
a8f30a6    to
    71679b5      
    Compare
  
    | It seems like it will be a bit of work to support  | 
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.
Nice! r=me modulo comments
        
          
                src/librustc_driver/driver.rs
              
                Outdated
          
        
      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.
I would just remove this comment -- since expansion and import resolution are interleaved, there's no way to perform after_expand before import resolution, so we don't need to warn people about this.
Also, we can move after_expand(&krate)? outside of  time(time_passes, "name resolution", ...) now, I think it would be best to put it just before expansion debugging diagnostics ("Post-expansion node count", etc.).
        
          
                src/libsyntax/ext/base.rs
              
                Outdated
          
        
      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.
nit: I'd add Eq just to be idiomatic.
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.
(optional) Could we avoid these extra errors by moving `struct (from earlier in the file) into a sub-module?
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.
I'd remove this -- it's only not an error here since we abort early.
| @bors delegate=keeperofdakeys | 
| ✌️ @keeperofdakeys can now approve this pull request | 
71679b5    to
    2d91e7a      
    Compare
  
    | @bors r+ | 
| 📌 Commit 2d91e7a has been approved by  | 
Refactor macro resolution errors + add derive macro suggestions Move legacy macro resolution error reporting to `finalize_current_module_macro_resolutions`, and provide suggestions for derive macros. Fixes #39323 cc #30197 r? @jseyfried
| 💔 Test failed - status-appveyor | 
| 
@bors: retry
* appveyor timeout… On Thu, Feb 16, 2017 at 10:47 AM, bors ***@***.***> wrote:
 💔 Test failed - status-appveyor
 <https://ci.appveyor.com/project/rust-lang/rust/build/1.0.1980>
 —
 You are receiving this because you are subscribed to this thread.
 Reply to this email directly, view it on GitHub
 <#39752 (comment)>, or mute
 the thread
 <https://github.com/notifications/unsubscribe-auth/AAD95CTYupbGjZxeqlDAVuPhuO7BqsXcks5rdH2JgaJpZM4L-WDv>
 .
 | 
Refactor macro resolution errors + add derive macro suggestions Move legacy macro resolution error reporting to `finalize_current_module_macro_resolutions`, and provide suggestions for derive macros. Fixes #39323 cc #30197 r? @jseyfried
| ☀️ Test successful - status-appveyor, status-travis | 
Move legacy macro resolution error reporting to
finalize_current_module_macro_resolutions, and provide suggestions for derive macros.Fixes #39323
cc #30197
r? @jseyfried