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

Address concerns of weak-into-raw #71107

Merged
merged 2 commits into from
Apr 19, 2020
Merged

Conversation

vorner
Copy link
Contributor

@vorner vorner commented Apr 13, 2020

This should address the standing concerns in #60728 (comment).

I've still left the ability to create a new dangling pointer from null, as I feel like this is the natural behaviour to expect, but I'm fine removing that too. I've modified the documentation to allow the as_ptr or into_ptr to return whatever garbage in case of a dangling pointer. I've also removed the guarantee to be able to do from_raw(as_ptr) from the documentation (but it would still work right now).

I've renamed the method and added implementations for Rc/Arc.

I've also tried if I can just „enable“ unsized types. I believe the current interface is compatible with them. But the inner implementation will be a bit challenging ‒ I can't use the data_offset as is used by Rc or Arc because it AFAIK „touches“ (creates a reference to) the live value of T ‒ and in case of Weak, it might be completely bogus or already dead ‒ so that would be UB.

./x.py test tidy is completely mad on my own system all over the code base :-(. I'll just hope it goes through CI, or will fix as necessary.

Is it OK if I ask @Amanieu for review, as the concerns are from you?

~r @Amanieu

* Rename Weak::as_raw to Weak::as_ptr for consistency with some other
  types.
* The as_ptr for a dangling Weak pointer might return whatever garbage
  (and takes that advantage to avoid a conditional).
* Don't guarantee to be able to do `Weak::from_raw(weak.as_ptr())` (even
  though it'll still work fine).
@rust-highfive
Copy link
Collaborator

r? @LukasKalbertodt

(rust_highfive has picked a reviewer for you, use r? to override)

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Apr 13, 2020
@vorner
Copy link
Contributor Author

vorner commented Apr 13, 2020

r? @Amanieu

@Centril
Copy link
Contributor

Centril commented Apr 13, 2020

cc @RalfJung

src/liballoc/rc.rs Outdated Show resolved Hide resolved
src/liballoc/sync.rs Outdated Show resolved Hide resolved
@Amanieu
Copy link
Member

Amanieu commented Apr 18, 2020

r=me once the issues with the doc comments are fixed.

For consistency with Weak
@vorner vorner force-pushed the weak-into-raw-dangling branch from eb84a49 to f4ded11 Compare April 19, 2020 07:38
@vorner
Copy link
Contributor Author

vorner commented Apr 19, 2020

Thanks. I've forced-pushed it directly, but the only change is the rewording of the comment.

@vorner vorner requested a review from Amanieu April 19, 2020 07:42
@Amanieu
Copy link
Member

Amanieu commented Apr 19, 2020

@bors r+ rollup

@bors
Copy link
Contributor

bors commented Apr 19, 2020

📌 Commit f4ded11 has been approved by Amanieu

@bors bors added S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Apr 19, 2020
Dylan-DPC-zz pushed a commit to Dylan-DPC-zz/rust that referenced this pull request Apr 19, 2020
…anieu

Address concerns of weak-into-raw

This should address the standing concerns in rust-lang#60728 (comment).

I've still left the ability to create a new dangling pointer from `null`, as I feel like this is the natural behaviour to expect, but I'm fine removing that too. I've modified the documentation to allow the `as_ptr` or `into_ptr` to return whatever garbage in case of a dangling pointer. I've also removed the guarantee to be able to do `from_raw(as_ptr)` from the documentation (but it would still work right now).

I've renamed the method and added implementations for `Rc`/`Arc`.

I've also tried if I can just „enable“ unsized types. I believe the current interface is compatible with them. But the inner implementation will be a bit challenging ‒ I can't use the `data_offset` as is used by `Rc` or `Arc` because it AFAIK „touches“ (creates a reference to) the live value of `T` ‒ and in case of `Weak`, it might be completely bogus or already dead ‒ so that would be UB.

`./x.py test tidy` is completely mad on my own system all over the code base :-(. I'll just hope it goes through CI, or will fix as necessary.

Is it OK if I ask @Amanieu for review, as the concerns are from you?

~r @Amanieu
This was referenced Apr 19, 2020
bors added a commit to rust-lang-ci/rust that referenced this pull request Apr 19, 2020
Rollup of 5 pull requests

Successful merges:

 - rust-lang#71107 (Address concerns of weak-into-raw)
 - rust-lang#71188 (Fixed missing trait method suggests incorrect code (self parameter not named "self"). )
 - rust-lang#71300 (Clarify when to use the tracking issue template)
 - rust-lang#71315 (Add example in the alternative in std::mem::transmute docs)
 - rust-lang#71319 (Clean up E0522 explanation)

Failed merges:

r? @ghost
@bors bors merged commit 4d11c3f into rust-lang:master Apr 19, 2020
@vorner vorner deleted the weak-into-raw-dangling branch April 19, 2020 19:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-waiting-on-bors Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants