- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
          Merge check_mod_impl_wf and check_mod_type_wf
          #121154
        
          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
| @bors try @rust-timer queue | 
| rustbot has assigned @compiler-errors. Use r? to explicitly pick a reviewer | 
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
Merge `check_mod_impl_wf` and `check_mod_type_wf` This still causes some funny diagnostics, but I'm not sure they can be fixed without a larger change, which I'd like to avoid here.
| // Check impls constrain their parameters | ||
| let res = | ||
| tcx.hir().try_par_for_each_module(|module| tcx.ensure().check_mod_impl_wf(module)); | ||
| tcx.hir().par_for_each_module(|module| { | ||
| let _ = tcx.ensure().check_mod_type_wf(module); | ||
| }); | ||
|  | ||
| for &trait_def_id in tcx.all_local_trait_impls(()).keys() { | ||
| let _ = tcx.ensure().coherent_trait(trait_def_id); | ||
| } | ||
| // these queries are executed for side-effects (error reporting): | ||
| let _ = tcx.ensure().crate_inherent_impls(()); | ||
| let _ = tcx.ensure().crate_inherent_impls_overlap_check(()); | ||
| res | ||
| })?; | ||
| }); | 
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.
Just removing this early abort causes annoying diagnostics that are hard to make good. So what I did instead was to inline the check_mod_impl_wf checks directly into the individual check_well_formed of impl items and early abort per item. So that only items with errors in impl_wf checks don't get their type_wf run, but other items do
| if let GenericParamKind::Lifetime = param.kind { | ||
| // Record lifetime res, so lowering knows there is something fishy. | ||
| self.record_lifetime_param(param.id, LifetimeRes::Error); | ||
| } | ||
| let rib = match param.kind { | ||
| GenericParamKind::Lifetime => { | ||
| // Record lifetime res, so lowering knows there is something fishy. | ||
| self.record_lifetime_param(param.id, LifetimeRes::Error); | ||
| continue; | ||
| } | ||
| GenericParamKind::Type { .. } => &mut function_type_rib, | ||
| GenericParamKind::Const { .. } => &mut function_value_rib, | ||
| }; | ||
|  | ||
| self.r.record_partial_res(param.id, PartialRes::new(Res::Err)); | ||
| rib.bindings.insert(ident, Res::Err); | 
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.
Without this change we'd get a "duplicate generic param T" error followed by an "unused generic param T" error for
struct Foo<T, T>(T);The latter error makes no sense, so I turned the second T into a Res::Err, which hides follow-up errors
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.
Add as a comment too.
| if impl_source.has_infer() { | ||
| infcx.tcx.dcx().has_errors().unwrap(); | ||
| return Err(CodegenObligationError::FulfillmentError); | ||
| } | 
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.
Unused lifetimes on an impl get replaced with inference vars, but never resolved, causing the return value of a query to contain inference vars, which is
- bad
- ICEs in stable hashing (good!)
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.
Can we put this comment as a comment in the code?
| error[E0282]: type annotations needed | ||
| --> $DIR/issue-87340.rs:11:23 | ||
| | | ||
| LL | fn f() -> Self::I {} | ||
| | ^^ cannot infer type for type parameter `T` | 
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.
annoying to prevent, but I'll figure it out, preferably in a follow-up PR
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
| ☀️ Try build successful - checks-actions | 
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
| Finished benchmarking commit (24e3e17): comparison URL. Overall result: ✅ improvements - no action neededBenchmarking this pull request likely means that it is perf-sensitive, so we're automatically marking it as not fit for rolling up. While you can manually mark this PR as fit for rollup, we strongly recommend not doing so since this PR may lead to changes in compiler perf. @bors rollup=never Instruction countThis is a highly reliable metric that was used to determine the overall result at the top of this comment. 
 Max RSS (memory usage)ResultsThis is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment. 
 CyclesResultsThis is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment. 
 Binary sizeThis benchmark run did not return any relevant results for this metric. Bootstrap: 638.252s -> 637.587s (-0.10%) | 
ade1cd7    to
    13d26b3      
    Compare
  
    | ☔ The latest upstream changes (presumably #121327) made this pull request unmergeable. Please resolve the merge conflicts. | 
13d26b3    to
    15c5aba      
    Compare
  
    | ☔ The latest upstream changes (presumably #121356) made this pull request unmergeable. Please resolve the merge conflicts. | 
15c5aba    to
    e58e32c      
    Compare
  
    | ☔ The latest upstream changes (presumably #121400) made this pull request unmergeable. Please resolve the merge conflicts. | 
e58e32c    to
    fbe7943      
    Compare
  
    Merge `collect_mod_item_types` query into `check_well_formed` follow-up to rust-lang#121154 r? `@ghost`
| ☔ The latest upstream changes (presumably #119106) made this pull request unmergeable. Please resolve the merge conflicts. | 
fbe7943    to
    5c27d71      
    Compare
  
    | ☔ The latest upstream changes (presumably #121870) made this pull request unmergeable. Please resolve the merge conflicts. | 
Merge `collect_mod_item_types` query into `check_well_formed` follow-up to rust-lang#121154 this removes more potential parallel-compiler bottlenecks and moves diagnostics for the same items next to each other, instead of grouping diagnostics by analysis kind
| Finished benchmarking commit (8c9a75b): comparison URL. Overall result: no relevant changes - no action needed@rustbot label: -perf-regression Instruction countThis benchmark run did not return any relevant results for this metric. Max RSS (memory usage)ResultsThis is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment. 
 CyclesResultsThis is a less reliable metric that may be of interest but was not used to determine the overall result at the top of this comment. 
 Binary sizeThis benchmark run did not return any relevant results for this metric. Bootstrap: 647.185s -> 648.501s (0.20%) | 
Merge `collect_mod_item_types` query into `check_well_formed` follow-up to rust-lang#121154 this removes more potential parallel-compiler bottlenecks and moves diagnostics for the same items next to each other, instead of grouping diagnostics by analysis kind
Merge `collect_mod_item_types` query into `check_well_formed` follow-up to rust-lang#121154 this removes more potential parallel-compiler bottlenecks and moves diagnostics for the same items next to each other, instead of grouping diagnostics by analysis kind
Merge `collect_mod_item_types` query into `check_well_formed` follow-up to rust-lang/rust#121154 this removes more potential parallel-compiler bottlenecks and moves diagnostics for the same items next to each other, instead of grouping diagnostics by analysis kind
Silence some follow-up errors on trait impls in case the trait has conflicting or otherwise incoherent impls fixes rust-lang#123292 Also removes a bunch of extra diagnostics that were introduced in rust-lang#121154 and rust-lang#120558
Silence some follow-up errors on trait impls in case the trait has conflicting or otherwise incoherent impls fixes rust-lang#123292 Also removes a bunch of extra diagnostics that were introduced in rust-lang#121154 and rust-lang#120558
Silence some follow-up errors on trait impls in case the trait has conflicting or otherwise incoherent impls fixes rust-lang#123292 Also removes a bunch of extra diagnostics that were introduced in rust-lang#121154 and rust-lang#120558
Silence some follow-up errors on trait impls in case the trait has conflicting or otherwise incoherent impls fixes #123292 Also removes a bunch of extra diagnostics that were introduced in rust-lang/rust#121154 and rust-lang/rust#120558
This still causes some funny diagnostics, but I'm not sure they can be fixed without a larger change, which I'd like to avoid here.
Reducing the number of times we iterate over the same items at this high level helps avoid parallel-compiler bottlenecks.