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 infer_static_outlives_requirements (RFC 2093 spinoff) #54185

Closed
nikomatsakis opened this issue Sep 13, 2018 · 14 comments · Fixed by #97875
Closed

tracking issue for infer_static_outlives_requirements (RFC 2093 spinoff) #54185

nikomatsakis opened this issue Sep 13, 2018 · 14 comments · Fixed by #97875
Assignees
Labels
B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC disposition-close This PR / issue is in PFCP or FCP with a disposition to close it. E-help-wanted Call for participation: Help is requested to fix this issue. E-mentor Call for participation: This issue has a mentor. Use #t-compiler/help on Zulip for discussion. finished-final-comment-period The final comment period is finished for this PR / Issue. S-tracking-design-concerns Status: There are blocking design concerns. T-lang Relevant to the language team, which will review and decide on the PR/issue.

Comments

@nikomatsakis
Copy link
Contributor

nikomatsakis commented Sep 13, 2018

As part of the work on RFC 2093 (#44493), we encountered a specific sub-question that we decided to spin out into its own feature gate called infer_static_outlives_requirements (#52761). The question is whether to infer T: 'static requirements from structs.

For example, does this struct require T: 'static?

struct Foo<T> {
  x: &'static T
}

There is no real implementation work to be done here, this is simply a policy question.

@nikomatsakis nikomatsakis added T-lang Relevant to the language team, which will review and decide on the PR/issue. B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC labels Sep 13, 2018
@Centril
Copy link
Contributor

Centril commented Sep 13, 2018

Are there particular strong reasons to treat 'static any different than other lifetimes here?
Otherwise, for reasons of uniformity/consistency, I'm strongly inclined that T: 'static should be inferred.

@nikomatsakis
Copy link
Contributor Author

I'm not sure what you mean by "strong" — the inference itself has no problem with 'static. I think the motivation is that it is somehow surprising, but it's tricky to put my finger on why.

@Centril
Copy link
Contributor

Centril commented Sep 13, 2018

@nikomatsakis by strong I mean "very compelling" rather than "a bit compelling" :)

@withoutboats
Copy link
Contributor

I don't know what we should do necessarily, but two reasons not to infer 'static right now:

  • For lifetimes other than 'static, there is some indication in the public signature that the type parameters are bound by those lifetimes, because they are also parameters. That is, given Iter<'a, T>, its almost always the case that there's a &'a T somewhere in the struct, and users expect that. But there's no visual distinction between a Foo<T> above and, for example, Vec<T>, indicating that T: 'static is implied.
  • Having decided to stabilize this for everything else, we'll be able to get more feedback on whether or not this is expected. That is, now that you never need to write T: 'a, we'll see if we get more user confusion about T: 'static suggesting that we should make this change.

@scottmcm
Copy link
Member

Hmm, there's some precedent that Box<T> differs from Box<T + 'a> here, right?

But I agree that waiting for additional feedback here is the right plan.

@Centril
Copy link
Contributor

Centril commented Nov 19, 2018

I did some looking around and thus far it doesn't seem like anyone has used #![feature(infer_static_outlives_requirements)] and I don't expect the feature gate will ever see much usage because taking a dependency on nightly just for this seems unlikely when it's relatively easy to write T: 'static. Thus, the additional feedback we want may sadly never develop.

That said, I'm coming around to the idea that T: 'static should be inferred to keep the ruleset of the language smaller and thus make Rust easier to learn.

With respect to @withoutboats's first point, while I initially found it compelling, I've thought some more about it... Given that for a type Foo<'a, T> it's not given that T: 'a, since you may have struct Foo<'a, T>(&'a ConcreteType, T);, I think that there is really no fundamental difference for T: 'static. This becomes even clearer if we consider Foo<'a, T, U>; with such a type, I don't think the user should have expectations that T: 'a and U: 'a both hold; having that bound of one type parameter is not so uncommon imo.

@scottmcm
Copy link
Member

I feel that not having the feature might be good for onboarding, as otherwise people who try to put references into types will get implicitly guided towards &'static, which is probably not what they actually wanted. This reminds me of elision, which also won't default to &'static for something like fn foo() -> &i32.

This issue hasn't been around for all that long; I think we should wait more time to see if anyone whos up saying it would be particularly helpful to them.

@cramertj
Copy link
Member

We discussed this in the lang team meeting and the general consensus was that, while we generally prefer to avoid special-cases in the language, 'static feels "different" than other lifetimes, and allowing inference for this particular bound could cause confusion.

Rather than FCP close'ing, we decided to leave this open and wait to see if users are confused by this special case. One thing that was pointed out was that users might not find this issue because the current error doesn't suggest using a feature gate nor point users towards this tracking issue-- this should be fixed.

@joshtriplett
Copy link
Member

It's been 3.5 years, and it doesn't seem like we've had any further reports about this being confusing. We can always make this change later, if we change our minds or new information comes to light.

Any concerns from @rust-lang/lang about closing this?

@rfcbot close

@rfcbot
Copy link

rfcbot commented May 11, 2022

Team member @joshtriplett has proposed to close this. The next step is review by the rest of the tagged team members:

No concerns currently listed.

Once a majority of reviewers approve (and at most 2 approvals are outstanding), 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 proposed-final-comment-period Proposed to merge/close by relevant subteam, see T-<team> label. Will enter FCP once signed off. disposition-close This PR / issue is in PFCP or FCP with a disposition to close it. 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 May 11, 2022
@rfcbot
Copy link

rfcbot commented May 17, 2022

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

@rfcbot rfcbot added finished-final-comment-period The final comment period is finished for this PR / Issue. and removed final-comment-period In the final comment period and will be merged soon unless new substantive objections are raised. labels May 27, 2022
@rfcbot
Copy link

rfcbot commented May 27, 2022

The final comment period, with a disposition to close, as per the review above, is now complete.

As the automated representative of the governance process, I would like to thank the author for their work and everyone else who contributed.

@rfcbot rfcbot added the to-announce Announce this issue on triage meeting label May 27, 2022
@joshtriplett joshtriplett added the S-tracking-design-concerns Status: There are blocking design concerns. label Jun 1, 2022
@JohnTitor
Copy link
Member

@joshtriplett What should we do about the infer_static_outlives_requirements feature? Could we remove the support and feature?

@pnkfelix
Copy link
Member

pnkfelix commented Jun 7, 2022

@JohnTitor that's right: at this point, we would welcome a Pull Request that removes the #![feature(infer_static_outlives_requirements)] and all the code guared by that feature gate.

As a related task, we would also want to update rust-lang/rfcs#2093 ("Infer T: 'x outlives requirements on structs") to explicitly state that we decided not to move ahead with the infer_static_outlives_requirements part of the feature.

I would be happy to help mentor someone with that task.

@rustbot label: +E-help-wanted +E-mentor

@rustbot rustbot added E-help-wanted Call for participation: Help is requested to fix this issue. E-mentor Call for participation: This issue has a mentor. Use #t-compiler/help on Zulip for discussion. labels Jun 7, 2022
@JohnTitor JohnTitor self-assigned this Jun 7, 2022
@JohnTitor JohnTitor moved this to 📋 TODO in @JohnTitor's backlog Jun 7, 2022
@JohnTitor JohnTitor moved this from 📋 TODO to 👀 Waiting for a response in @JohnTitor's backlog Jun 8, 2022
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this issue Jun 13, 2022
…requirements, r=pnkfelix

Remove the `infer_static_outlives_requirements` feature

Closes rust-lang#54185
r? `@pnkfelix`
@bors bors closed this as completed in 89249b1 Jun 13, 2022
@apiraino apiraino removed the to-announce Announce this issue on triage meeting label Sep 8, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
B-unstable Blocker: Implemented in the nightly compiler and unstable. C-tracking-issue Category: An issue tracking the progress of sth. like the implementation of an RFC disposition-close This PR / issue is in PFCP or FCP with a disposition to close it. E-help-wanted Call for participation: Help is requested to fix this issue. E-mentor Call for participation: This issue has a mentor. Use #t-compiler/help on Zulip for discussion. finished-final-comment-period The final comment period is finished for this PR / Issue. S-tracking-design-concerns Status: There are blocking design concerns. T-lang Relevant to the language team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging a pull request may close this issue.