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

Tracking issue for attributes on generic parameters (generic_param_attrs) #48848

Closed
petrochenkov opened this issue Mar 8, 2018 · 14 comments
Closed
Labels
C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC final-comment-period In the final comment period and will be merged soon unless new substantive objections are raised. T-lang Relevant to the language team, which will review and decide on the PR/issue.

Comments

@petrochenkov
Copy link
Contributor

petrochenkov commented Mar 8, 2018

Attributes on generic parameters (both types and lifetimes) were introduced in #34764. Extensive tests for them were added in the same PR.

// Example
fn f<#[my_type_attr] T, #[my_lifetime_attr] 'a>() {}

Notable build-in attribute accepted in this position is #[may_dangle] (#34761) supplying information for drop checking.
However, custom attributes interpreted in custom ways by procedural macros can be used in this position as well.

Stabilization PR: #48851

@petrochenkov petrochenkov added the T-lang Relevant to the language team, which will review and decide on the PR/issue. label Mar 8, 2018
@petrochenkov
Copy link
Contributor Author

@rfcbot fcp merge

@petrochenkov
Copy link
Contributor Author

ping @nikomatsakis

rfcbot doesn't listen to me

@Centril Centril added the C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC label Mar 8, 2018
@cramertj
Copy link
Member

cramertj commented Mar 8, 2018

@rfcbot fcp merge

@rfcbot
Copy link

rfcbot commented Mar 8, 2018

Team member @cramertj has proposed to merge this. The next step is review by the rest of the tagged teams:

No concerns currently listed.

Once a majority of reviewers approve (and none object), this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up!

See this document for info about what commands tagged team members can give me.

@rfcbot rfcbot added the proposed-final-comment-period Proposed to merge/close by relevant subteam, see T-<team> label. Will enter FCP once signed off. label Mar 8, 2018
@nrc
Copy link
Member

nrc commented Mar 8, 2018

My gut instinct is that this is a bad idea - I think attributes work pretty well for item-like things, but are pretty confusing for expression-like things (the technical issue is scoping, but I at least have mental model issues too). So, I'd prefer not to stabilise and instead deprecate, however, it seems like may_dangle is something we want to keep long term and that attributes on formal generics is a prereq for that? (@pnkfelix could you confirm?) In which case, I guess we should stabilise.

@petrochenkov
Copy link
Contributor Author

My intuition so far is that any part of source code may require annotations of some kind (aka passive attributes), so we eventually end up with attributes permitted almost anywhere, like C++.
As a recent example, rust-lang/stdarch#319 would benefit from attributes on function parameters.

@hanna-kruppe
Copy link
Contributor

Aside from may_dangle: I believe the concrete impetus for requesting this stabilizations were attributes on ADT type parameters to guide derives (rust-lang/rfcs#2353). @petrochenkov makes a good case for even more attribute positions, though. I'm not a huge fan of how it winds up looking (puts a lot of noise into the angle brackets), but as they say, we need some way to add annotations to these things.

@nikomatsakis
Copy link
Contributor

nikomatsakis commented Mar 9, 2018

@nrc

but are pretty confusing for expression-like things

In what way are generic parameters expression-like? They seem more analagous to item-like -- that is, they are declarations.

@nrc
Copy link
Member

nrc commented Mar 11, 2018

In what way are generic parameters expression-like?

This is all very vague and non-technical, but:

  • they can only appear within items (not at 'module scope') and can't contain items themselves
  • they are 'small' - they can only contain sequences of types, not sequences of statements

@nikomatsakis
Copy link
Contributor

@nrc It seems to me that there are a few things which can make attributes on expressions confusing. The most important of course is precedence. But I think attributes in general tend also to make the most sense when attached to "declarations", since those often have other "properties" to them and you can think of attributes as being one of those properties. (Hence I suppose something like #[foo] (x + 3) could be sort of confusing -- what is #[foo] annotating? The result? The computation?)

But neither of these concerns seem to apply to type parameters. There's no real ambiguity, and they feel to me like a "declaration of a thing" that can have properties (e.g., it has a list of bounds attached to it).

Rather than look in the abstract, perhaps you could comment on the "derive" use case (rust-lang/rfcs#2353) and if you find that confusing?

@nrc
Copy link
Member

nrc commented Mar 15, 2018

There's no real ambiguity, and they feel to me like a "declaration of a thing" that can have properties

This is convincing. There is something about the 'deepness' of them that still irks, but I think it is not worse than fields, for example.

Rather than look in the abstract, perhaps you could comment on the "derive" use case (rust-lang/rfcs#2353) and if you find that confusing?

I do, but I think that is mostly because of the formatting?

With:

#[derive(Clone, PartialEq)]
struct MyArc<
    #[derive_no_bound(Clone)]
    T,
>(Arc<T>);

It feels fine (although it is arguably worse formatting in that it is ugly and uses a lot of vertical space).

Given that I wouldn't want to block an RFC on how to format the code, I think it's fine.

@rfcbot
Copy link

rfcbot commented Mar 15, 2018

🔔 This is now entering its final comment period, as per the review above. 🔔

@rfcbot rfcbot added final-comment-period In the final comment period and will be merged soon unless new substantive objections are raised. and removed proposed-final-comment-period Proposed to merge/close by relevant subteam, see T-<team> label. Will enter FCP once signed off. labels Mar 15, 2018
@rfcbot
Copy link

rfcbot commented Mar 25, 2018

The final comment period is now complete.

alexcrichton added a commit to alexcrichton/rust that referenced this issue Apr 5, 2018
…akis

Stabilize attributes on generic parameters

Closes rust-lang#48848
bors added a commit that referenced this issue Apr 5, 2018
Stabilize attributes on generic parameters

Closes #48848
@kennytm
Copy link
Member

kennytm commented Jun 1, 2018

I tried this today on 1.27-beta and found that #[cfg] is ignored. Is this expected for stabilization?

struct Foo<#[cfg(not(unix))] H>(H);
fn main() {
    let _: Foo<u32> = Foo::<u32>(1);
}
warning: unused attribute
 --> src/main.rs:1:12
  |
1 | struct Foo<#[cfg(not(unix))] H>(H);
  |            ^^^^^^^^^^^^^^^^^
  |
  = note: #[warn(unused_attributes)] on by default

    Finished dev [unoptimized + debuginfo] target(s) in 0.65s
     Running `target/debug/playground`

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC final-comment-period In the final comment period and will be merged soon unless new substantive objections are raised. T-lang Relevant to the language team, which will review and decide on the PR/issue.
Projects
None yet
Development

No branches or pull requests

8 participants