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

Remove async_trait dependency, MSRV CI #37

Merged
merged 2 commits into from
Apr 11, 2024
Merged

Conversation

nyurik
Copy link
Collaborator

@nyurik nyurik commented Apr 10, 2024

Requires Rust v1.75 - old enough to release now

Also fixes a few pedantic clippy things and CI improvements

Copy link

@ianthetechie ianthetechie left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good. Just two non-blocking discussions.

Comment on lines 47 to 54
- name: Read crate metadata
id: metadata
run: echo "rust-version=$(sed -ne 's/rust-version *= *\"\(.*\)\"/\1/p' Cargo.toml)" >> $GITHUB_OUTPUT
- name: Install Rust
uses: dtolnay/rust-toolchain@stable
with:
toolchain: ${{ steps.metadata.outputs.rust-version }}
components: clippy,rustfmt

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

More of a curiosity than anything, but why not use cargo hack? I found it to be a simpler way to enforce MSRV checks in Rust CI, but that's just a personal preference.
https://github.com/stadiamaps/ferrostar/blob/6ee817cd3dda844715d305897db1b9c04a7b5127/.github/workflows/rust.yml#L21

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, that could also work. The thing with hack is that its a fairly complex all-included utility, whereas what we need here is a really dumb way to extract an older version text, switch back to it, and just run regular tests. With hack, we don't know all the things it may do (or forget to do)... Not that important though, so up to you

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah I don't really care either way; just curious 😂 and eventually this will get built into cargo.

Feel free to merge when the latest CI run succeeds.

Comment on lines 217 to 227
pub trait AsyncBackend {
/// Reads exactly `length` bytes starting at `offset`
async fn read_exact(&self, offset: usize, length: usize) -> PmtResult<Bytes>;
fn read_exact(
&self,
offset: usize,
length: usize,
) -> impl Future<Output = PmtResult<Bytes>> + Send;

/// Reads up to `length` bytes starting at `offset`.
async fn read(&self, offset: usize, length: usize) -> PmtResult<Bytes>;
fn read(&self, offset: usize, length: usize) -> impl Future<Output = PmtResult<Bytes>> + Send;
}

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we want to go all the way with trait-variant now (simplifies syntax and creates a variant for single-threaded executors that doesn't require a Send bound)? Or just implement the path we care about? I'm completely fine with the code as-is, but just raising the question to document and make sure it's a conscious decision.

Background: https://blog.rust-lang.org/2023/12/21/async-fn-rpit-in-traits.html#async-fn-in-public-traits

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thx, good link. Technically, what I propose here is a direct replacement of the async_trait -- which in our case only implemented the Send version (it could have been both with #[async_trait(?Send)]). I would say YAGNI - unless someone asks for it?

@nyurik nyurik merged commit 64f39ec into stadiamaps:main Apr 11, 2024
2 checks passed
@nyurik nyurik deleted the rm-async branch April 11, 2024 06:04
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants