- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
          Explain why Self is invalid in generic parameters
          #90022
        
          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
  
    Explain why Self is invalid in generic parameters
  
  #90022
              Conversation
3127f9b    to
    cc572c7      
    Compare
  
    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.
This should likely be something like:
    Ok(GenericParam {
            ident: Ident::new(kw::SelfUpper, this.prev_token.span),
            id: ast::DUMMY_NODE_ID,
            attrs: vec![],
            bounds: vec![], //maybe even parse/skip bounds?
            kind: GenericParamKind::Type { default: None },
            is_placeholder: false,
        })
so that we still take Self as a type param (although this might actually bring worse diagnostics if valid uses of Self are seen as the param 🤔).
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.
(although this might actually bring worse diagnostics if valid uses of Self are seen as the param thinking).
I wonder if there could be a valid use of Self as a type parameter. Yes, one could write let a: Option<Self> = ... in assoc items, but that is a generic argument and will be parsed by a function other than parse_generic_params.
... so that we still take Self as a type param
Recovering by treating as if Self is a valid ident emits these diagnostics below, which I'm not very satisfied with; given Self is unusable here, parameter `Self` is never used sounds like we should use parameter Self, which isn't right.
error: unexpected keyword `Self` in generic parameters
  --> $DIR/keyword-self-as-type-param.rs:3:12
   |
LL | struct Foo<Self>(Self);
   |            ^^^^
   |
   = note: you cannot use `Self` as a generic parameter because it is reserved for associated items
error[E0392]: parameter `Self` is never used
  --> $DIR/keyword-self-as-type-param.rs:3:12
   |
LL | struct Foo<Self>(Self);
   |            ^^^^ unused parameter
The best-ish solution I come up with is that, when we see Self, emit the diagnostic and skip Self and the following comma as if the generic param never existed.
e39e41e    to
    d0a35c2      
    Compare
  
    
      
        
              This comment has been minimized.
        
        
      
    
  This comment has been minimized.
d0a35c2    to
    a72dd4a      
    Compare
  
    | @bors r+ This seems reasonable. | 
| 📌 Commit a72dd4a has been approved by  | 
…askrgr Rollup of 6 pull requests Successful merges: - rust-lang#89642 (environ on macos uses directly libc which has the correct signature.) - rust-lang#90022 (Explain why `Self` is invalid in generic parameters) - rust-lang#90023 (Postpone the evaluation of constant expressions that depend on inference variables) - rust-lang#91215 (Implement VecDeque::retain_mut) - rust-lang#91355 (std: Stabilize the `thread_local_const_init` feature) - rust-lang#91528 (LLVM support .insn directive) Failed merges: r? `@ghost` `@rustbot` modify labels: rollup
Close #89985.
r? @estebank