-
Notifications
You must be signed in to change notification settings - Fork 305
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
Make HeaderName::from_static const #499
Conversation
787b82b
to
feab2c3
Compare
@carllerche you wrote the |
It's been a while. My recollection is this was to optimize header parsing. If there are benchmarks still checking parse speed and they aren't impacted, then it is probably fine. |
Using
and with this change,
|
.... and just to be complete, here are the two new benchmarks cut out and run on 0.2.6,
So, maybe only a 20% improvement instead of a 33% improvement, but still! |
…o constname_merge Merges hyperium#428 into hyperium#499
@jeddenlea @seanmonstar FYI - const_panic is now stable in |
src/header/name.rs
Outdated
panic!("invalid header name") | ||
} | ||
} | ||
#[allow(unconditional_panic)] // required for the panic circumventon |
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.
D'oh, I copied the same error fixed in #532
…o constname_merge Merges hyperium#428 into hyperium#499
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.
overall lgtm w/ the benches you posted.
src/header/name.rs
Outdated
/// | ^^^^^^^^^^^^^^^^^^ | ||
/// | | | ||
/// | index out of bounds: the length is 0 but the index is 0 | ||
/// | inside `fastly::http::HeaderName::from_static` at http/src/header/name.rs:1241:13 |
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.
did you mean to include fastly
here?
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.
/// | inside `fastly::http::HeaderName::from_static` at http/src/header/name.rs:1241:13 | |
/// | inside `http::HeaderName::from_static` at http/src/header/name.rs:1241:13 |
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.
Haha, no, I did not. I'm so used to seeing it I didn't even notice. I'm going to force push that change.
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.
With the one proposed change, we can merge this :)
... plus some clean-up. It was only after I came up with the scheme using `const fn from_bytes(&[u8]) -> Option<StandardHeader>` that I noticed the debug+wasm32-wasi version of `parse_hdr`, which had something very similar. While cleaning up that function, I realized it still would still panic if an attempted name was too long, which had been fixed for all other targets and profiles in hyperium#433. Then, I thought it would be worth seeing if the use of `eq!` in the primary version of `parse_hdr` still made any difference. And, it would not appear so. At least not on x86_64, nor wasm32-wasi run via wasmtime. I've run the benchmarks a number of times now, and it seems the only significant performance change anywhere is actually that of `HeaderName::from_static` itself, which now seems to run in about 2/3 the time on average. Unfortunately, `const fn` still cannot `panic!`, but I've followed the lead from `HeaderValue::from_static`. While that version required 1.46, this new function requires 1.49. That is almost 8 months old, so hopefully this isn't too controversial!
…o constname_merge Merges hyperium#428 into hyperium#499
@@ -21,7 +21,7 @@ jobs: | |||
- nightly | |||
# When updating this value, don't forget to also adjust the | |||
# `rust-version` field in the `Cargo.toml` file. | |||
- 1.46.0 | |||
- 1.49.0 |
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.
Seems kinda strange that the MSRV was bumped without any notice in the PR description or in the release notes, no? Makes it somewhat hard to handle updates in downstream projects.
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 project follows the msrv of tokio /~https://github.com/tokio-rs/tokio/#supported-rust-versions but we should add it to the changelog. Good catch.
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.
It doesn't seem like it? tokio supports previous versions with point releases, allowing users with an older rustc to keep using tokio with bugfixes provided even if they have to ignore new versions. It looks like this crate is updated in point releases to have a new MSRV. In this case I wasn't able to use a down-down-downstream crate because it no longer built using system rustc on popular distros.
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 think this is mainly due to a few reasons, tokio is already 1.0 and thus at the time of 1.0 we try to support everyone. While this crate is below 1.0 so the guarantees are different. I assume it should be possible to pin the version of http though for your crate?
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.
Sure, understood, and I can pin for now, I was just noting that you said "this project follow the msrv of tokio" which isn't really accurate, given tokio has great support for broadly-available/deployed versions of rustc but I don't believe such support exists here (ie you miss bugfixes if you don't use rustup).
... plus some clean-up.
It was only after I came up with the scheme using
const fn from_bytes(&[u8]) -> Option<StandardHeader>
that I noticed the debug+wasm32-wasi version of
parse_hdr
, which hadsomething very similar.
While cleaning up that function, I realized it still would still panic
if an attempted name was too long, which had been fixed for all other
targets and profiles in #433. Then, I thought it would be worth seeing
if the use of
eq!
in the primary version ofparse_hdr
still made anydifference.
And, it would not appear so. At least not on x86_64, nor wasm32-wasi run
via wasmtime. I've run the benchmarks a number of times now, and it
seems the only significant performance change anywhere is actually that
of
HeaderName::from_static
itself, which now seems to run in about 2/3the time on average.
Unfortunately,
const fn
still cannotpanic!
, but I've followed thelead from
HeaderValue::from_static
. While that version required 1.46,this new function requires 1.49. That is almost 8 months old, so
hopefully this isn't too controversial!