2019-10-15 13:27:41 +00:00
|
|
|
<h1 align="center">async-std</h1>
|
|
|
|
<div align="center">
|
|
|
|
<strong>
|
|
|
|
Async version of the Rust standard library
|
|
|
|
</strong>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<br />
|
|
|
|
|
|
|
|
<div align="center">
|
|
|
|
<!-- Crates version -->
|
|
|
|
<a href="https://crates.io/crates/async-std">
|
|
|
|
<img src="https://img.shields.io/crates/v/async-std.svg?style=flat-square"
|
|
|
|
alt="Crates.io version" />
|
|
|
|
</a>
|
|
|
|
<!-- Downloads -->
|
|
|
|
<a href="https://crates.io/crates/async-std">
|
|
|
|
<img src="https://img.shields.io/crates/d/async-std.svg?style=flat-square"
|
|
|
|
alt="Download" />
|
|
|
|
</a>
|
|
|
|
<!-- docs.rs docs -->
|
|
|
|
<a href="https://docs.rs/async-std">
|
|
|
|
<img src="https://img.shields.io/badge/docs-latest-blue.svg?style=flat-square"
|
|
|
|
alt="docs.rs docs" />
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<a href="https://discord.gg/JvZeVNe">
|
|
|
|
<img src="https://img.shields.io/discord/598880689856970762.svg?logo=discord&style=flat-square"
|
|
|
|
alt="chat" />
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div align="center">
|
|
|
|
<h3>
|
|
|
|
<a href="https://docs.rs/async-std">
|
|
|
|
API Docs
|
|
|
|
</a>
|
|
|
|
<span> | </span>
|
|
|
|
<a href="https://book.async.rs">
|
|
|
|
Book
|
|
|
|
</a>
|
|
|
|
<span> | </span>
|
|
|
|
<a href="https://github.com/async-rs/async-std/releases">
|
|
|
|
Releases
|
|
|
|
</a>
|
|
|
|
<span> | </span>
|
|
|
|
<a href="https://async.rs/contribute">
|
|
|
|
Contributing
|
|
|
|
</a>
|
|
|
|
</h3>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<br/>
|
|
|
|
|
|
|
|
This crate provides an async version of [`std`]. It provides all the interfaces
|
|
|
|
you are used to, but in an async version and ready for Rust's `async`/`await`
|
|
|
|
syntax.
|
2019-08-08 12:44:48 +00:00
|
|
|
|
|
|
|
[`std`]: https://doc.rust-lang.org/std/index.html
|
2019-08-15 13:27:25 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
## Features
|
2019-08-15 13:27:25 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
- __Modern:__ Built from the ground up for `std::future` and `async/await` with
|
2019-10-30 19:06:42 +00:00
|
|
|
blazing fast compilation time.
|
2019-10-15 13:27:41 +00:00
|
|
|
- __Fast:__ Our robust allocator and threadpool designs provide ultra-high
|
|
|
|
throughput with predictably low latency.
|
|
|
|
- __Intuitive:__ Complete parity with the stdlib means you only need to learn
|
|
|
|
APIs once.
|
|
|
|
- __Clear:__ [Detailed documentation][docs] and [accessible guides][book] mean
|
|
|
|
using async Rust was never easier.
|
2019-08-15 13:27:25 +00:00
|
|
|
|
2019-08-12 12:15:59 +00:00
|
|
|
[docs]: https://docs.rs/async-std
|
|
|
|
[book]: https://book.async.rs
|
2019-08-08 12:44:48 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
## Examples
|
2019-08-08 12:44:48 +00:00
|
|
|
|
|
|
|
```rust
|
2019-12-08 06:15:29 +00:00
|
|
|
use async_std::task;
|
|
|
|
|
2019-11-12 22:25:52 +00:00
|
|
|
async fn say_hello() {
|
|
|
|
println!("Hello, world!");
|
|
|
|
}
|
2019-08-08 12:44:48 +00:00
|
|
|
|
2019-12-08 06:15:29 +00:00
|
|
|
fn main() {
|
|
|
|
task::block_on(say_hello())
|
2019-08-08 12:44:48 +00:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
More examples, including networking and file access, can be found in our
|
2019-11-12 22:25:52 +00:00
|
|
|
[`examples`] directory and in our [documentation].
|
2019-09-16 12:54:19 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
[`examples`]: https://github.com/async-rs/async-std/tree/master/examples
|
2019-11-12 22:25:52 +00:00
|
|
|
[documentation]: https://docs.rs/async-std#examples
|
2019-12-06 06:06:44 +00:00
|
|
|
[`task::block_on`]: https://docs.rs/async-std/*/async_std/task/fn.block_on.html
|
2019-11-21 20:21:19 +00:00
|
|
|
[`"attributes"` feature]: https://docs.rs/async-std/#features
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
## Philosophy
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
We believe Async Rust should be as easy to pick up as Sync Rust. We also believe
|
|
|
|
that the best API is the one you already know. And finally, we believe that
|
|
|
|
providing an asynchronous counterpart to the standard library is the best way
|
|
|
|
stdlib provides a reliable basis for both performance and productivity.
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
Async-std is the embodiment of that vision. It combines single-allocation task
|
|
|
|
creation, with an adaptive lock-free executor, threadpool and network driver to
|
|
|
|
create a smooth system that processes work at a high pace with low latency,
|
|
|
|
using Rust's familiar stdlib API.
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
## Installation
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
With [cargo add][cargo-add] installed run:
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
```sh
|
|
|
|
$ cargo add async-std
|
2019-08-12 12:15:59 +00:00
|
|
|
```
|
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
We also provide a set of "unstable" features with async-std. See the [features
|
|
|
|
documentation] on how to enable them.
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
[cargo-add]: https://github.com/killercup/cargo-edit
|
|
|
|
[features documentation]: https://docs.rs/async-std/#features
|
2019-08-12 12:15:59 +00:00
|
|
|
|
2019-08-08 12:44:48 +00:00
|
|
|
## License
|
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
<sup>
|
|
|
|
Licensed under either of <a href="LICENSE-APACHE">Apache License, Version
|
|
|
|
2.0</a> or <a href="LICENSE-MIT">MIT license</a> at your option.
|
|
|
|
</sup>
|
2019-08-08 12:44:48 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
<br/>
|
2019-08-08 12:44:48 +00:00
|
|
|
|
2019-10-15 13:27:41 +00:00
|
|
|
<sub>
|
2019-08-08 12:44:48 +00:00
|
|
|
Unless you explicitly state otherwise, any contribution intentionally submitted
|
2019-10-15 13:27:41 +00:00
|
|
|
for inclusion in this crate by you, as defined in the Apache-2.0 license, shall
|
|
|
|
be dual licensed as above, without any additional terms or conditions.
|
|
|
|
</sub>
|