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

Reduce dependency tree #3515

Open
6 of 9 tasks
thomaseizinger opened this issue Feb 27, 2023 · 7 comments
Open
6 of 9 tasks

Reduce dependency tree #3515

thomaseizinger opened this issue Feb 27, 2023 · 7 comments
Labels
tracking-issue Issues which are the entry point to bigger projects.

Comments

@thomaseizinger
Copy link
Contributor

thomaseizinger commented Feb 27, 2023

I'll record various efforts in here to reduce the size of our dependency tree where possible.

Tasks

Preview Give feedback
  1. send-it
  2. difficulty:hard help wanted priority:nicetohave
  3. difficulty:easy help wanted priority:nicetohave

More suggestions welcome, a good place to start is a timings report by cargo of the entire workspace (minus dev-dependencies): cargo build --workspace --all-features --timings. Once you have identified a (ideally heavy) dependency that we might not need, investigate with cargo tree -i -p <dependency> where it comes from.

@tbu-
Copy link

tbu- commented Mar 11, 2023

Might it be possible to get rid of the async-std (optional) dependency? I'd guess the ecosystem has moved on to tokio these days, with the last commit in async-std being 9 months ago: async-rs/async-std@bf316b0.

I think this could help cutting down some more dependencies as well.

@thomaseizinger
Copy link
Contributor Author

I am not following the async-std development but I'd consider that one too established to remove.

Plus, it is optional as you said. I think it would be more fruitful to investigate for dependencies in our protocol crates like yamux, gossipsub or kademlia.

@thomaseizinger
Copy link
Contributor Author

Might it be possible to get rid of the async-std (optional) dependency? I'd guess the ecosystem has moved on to tokio these days, with the last commit in async-std being 9 months ago: async-rs/async-std@bf316b0.

I think this could help cutting down some more dependencies as well.

We can cut down some dependencies by moving all our tests and examples to tokio. async-std is heavily feature-flagged, meaning we can reduce our dependencies by only activating the bare minimum features needed in the various transports and libp2p-swarm.

@thomaseizinger thomaseizinger changed the title Tracking issue: Reduce dependency tree Reduce dependency tree Sep 19, 2023
@thomaseizinger thomaseizinger added difficulty:moderate help wanted tracking-issue Issues which are the entry point to bigger projects. and removed help wanted difficulty:moderate labels Sep 19, 2023
@tbu-
Copy link

tbu- commented Oct 29, 2024

We can cut down some dependencies by moving all our tests and examples to tokio. async-std is heavily feature-flagged, meaning we can reduce our dependencies by only activating the bare minimum features needed in the various transports and libp2p-swarm.

Would you reconsider removing async-std entirely today? async-std development seems to be entirely dead. In the last 1.5 years since your comment, there has been +128 -79 lines of change in async-std, mostly compilation fixes, doc changes and dependency updates.

async-rs/async-std@e1d66f5...fa29b50

@jxs
Copy link
Member

jxs commented Oct 30, 2024

Hi! Yeah there's an open issue for that: #4449

@tbu-
Copy link

tbu- commented Oct 30, 2024

That issue is not about removing async-std support.

For now, we want to keep supporting async-std

I'd advocate for removing async-std support since supporting multiple runtimes makes the code more complex — and async-std seems to be dead, with around 200 lines changed in 1.5 years.

@jxs
Copy link
Member

jxs commented Nov 5, 2024

That issue is not about removing async-std support.

Yeah you are right sorry, cannot find the phase out discussion post, probably was discussed on a call.
Basically the plan is to first prefer tokio everywhere first, and then removing async-std

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
tracking-issue Issues which are the entry point to bigger projects.
Projects
None yet
Development

No branches or pull requests

3 participants