-
Notifications
You must be signed in to change notification settings - Fork 13k
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
Update hashbrown to version 0.15, with changes that were blocked by that release #131178
Conversation
Some changes occurred in cfg and check-cfg configuration cc @Urgau These commits modify the If this was unintentional then you should revert the changes before this PR is merged. |
d058e12
to
347dd7c
Compare
@@ -413,7 +413,7 @@ impl CheckCfg { | |||
] = self | |||
.expecteds | |||
.get_many_mut(VALUES) | |||
.expect("unable to get all the check-cfg values buckets"); | |||
.map(|x| x.expect("unable to get all the check-cfg values buckets")); |
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.
I tried updating this code in a few different ways but ultimately, this felt like the least-invasive way to make the change. I don't fully understand what this code is doing (and didn't really bother to figure out), so, someone else can change this code later if they find a better way of doing it.
Plus, a panic is an ICE anyway, so, if this causes any noticeable difference in behaviour it was a bug anyway.
Just kidding, I had searched for an existing PR and hadn't found one. Will close this and just reopen my other PR. >< |
The job Click to see the possible cause of the failure (guessed by this bot)
|
Going over the changes:
The obvious
hashbrown
has been set to version 0.15 inlibrary/std/Cargo.toml
, and acargo update
for thestd
crate has been performed. This also bumps the version of thecc
crate inCargo.lock
, but I didn't think it was worth removing this change by hand, since it's just a bugfix release.map_entry_replace
There was an FCP that decided to remove these unstable methods, but no PR was actually submitted to do so: #44286 (comment)
Since
hashbrown
has removed these methods, they are removed with the update as well.map_many_mut
The unstable APIs for
HashMap::get_many_mut
andHashMap::get_many_unchecked_mut
have been transposed from returningOption<[&mut V; N]>
to returning[Option<&mut V>; N]
.This was based upon a libs-api decision here: #97601 (comment)
hash_set_entry
The unstable
HashSet::get_or_insert_owned
API was removed in favour of the also-unstableHashSet::get_or_insert_with
. There wasn't much discussion here that I could find, but essentially, both of these methods have the same problem of having to verify that the keys are equivalent after the fact, and theowned
variant was removed fromhashbrown
, which seems to indicate some kind of consensus.Since this API is unstable, it doesn't need an FCP, but since I don't think there was any official consensus on it, someone from libs-api should probably sign this off. If you'd prefer to retain the
owned
variant of the method, it can easily be reimplemented on top of the hashbrown API which only offers awith
variant.default_iters_hash
These are instantly-stable, but already passed FCP here: #128711 (comment)
They were blocked by a hashbrown release containing the necessary impls, so, that's why they're included in this PR.
r? libs-api