mirror of
				https://github.com/async-rs/async-std.git
				synced 2025-10-25 05:46:43 +00:00 
			
		
		
		
	clean readme (#331)
* clean readme Signed-off-by: Yoshua Wuyts <yoshuawuyts@gmail.com> * add back features Signed-off-by: Yoshua Wuyts <yoshuawuyts@gmail.com> * Update README.md Co-Authored-By: Stjepan Glavina <stjepang@gmail.com>
This commit is contained in:
		
							parent
							
								
									aed9e2efdf
								
							
						
					
					
						commit
						35fc85a157
					
				
					 1 changed files with 95 additions and 106 deletions
				
			
		
							
								
								
									
										201
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										201
									
								
								README.md
									
									
									
									
									
								
							|  | @ -1,41 +1,78 @@ | ||||||
| # Async version of the Rust standard library | <h1 align="center">async-std</h1> | ||||||
|  | <div align="center"> | ||||||
|  |  <strong> | ||||||
|  |    Async version of the Rust standard library | ||||||
|  |  </strong> | ||||||
|  | </div> | ||||||
| 
 | 
 | ||||||
| [](https://travis-ci.com/async-rs/async-std) | <br /> | ||||||
| [](https://github.com/async-rs/async-std) |  | ||||||
| [](https://crates.io/crates/async-std) |  | ||||||
| [](https://docs.rs/async-std) |  | ||||||
| [](https://discord.gg/JvZeVNe) |  | ||||||
| 
 | 
 | ||||||
| This crate provides an async version of [`std`]. It provides all the interfaces you | <div align="center"> | ||||||
| are used to, but in an async version and ready for Rust's `async`/`await` syntax. |   <!-- 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. | ||||||
| 
 | 
 | ||||||
| [`std`]: https://doc.rust-lang.org/std/index.html | [`std`]: https://doc.rust-lang.org/std/index.html | ||||||
| 
 | 
 | ||||||
| ## Documentation | ## Features | ||||||
| 
 | 
 | ||||||
| `async-std` comes with [extensive API documentation][docs] and a [book][book]. | - __Modern:__ Built from the ground up for `std::future` and `async/await` with | ||||||
|  |     blazing fast compilation times. | ||||||
|  | - __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. | ||||||
| 
 | 
 | ||||||
| [docs]: https://docs.rs/async-std | [docs]: https://docs.rs/async-std | ||||||
| [book]: https://book.async.rs | [book]: https://book.async.rs | ||||||
| 
 | 
 | ||||||
| ## Quickstart | ## Examples | ||||||
| 
 |  | ||||||
| Add the following lines to your `Cargo.toml`: |  | ||||||
| 
 |  | ||||||
| ```toml |  | ||||||
| [dependencies] |  | ||||||
| async-std = "0.99" |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| Or use [cargo add][cargo-add] if you have it installed: |  | ||||||
| 
 |  | ||||||
| ```sh |  | ||||||
| $ cargo add async-std |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| [cargo-add]: https://github.com/killercup/cargo-edit |  | ||||||
| 
 |  | ||||||
| ## Hello world |  | ||||||
| 
 | 
 | ||||||
| ```rust | ```rust | ||||||
| use async_std::task; | use async_std::task; | ||||||
|  | @ -47,96 +84,48 @@ fn main() { | ||||||
| } | } | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## Low-Friction Sockets with Built-In Timeouts | More examples, including networking and file access, can be found in our | ||||||
|  | [`examples`] directory. | ||||||
| 
 | 
 | ||||||
| ```rust | [`examples`]: https://github.com/async-rs/async-std/tree/master/examples | ||||||
| use std::time::Duration; |  | ||||||
| 
 | 
 | ||||||
| use async_std::{ | ## Philosophy | ||||||
|     prelude::*, |  | ||||||
|     task, |  | ||||||
|     io, |  | ||||||
|     net::TcpStream, |  | ||||||
| }; |  | ||||||
| 
 | 
 | ||||||
| async fn get() -> io::Result<Vec<u8>> { | We believe Async Rust should be as easy to pick up as Sync Rust. We also believe | ||||||
|     let mut stream = TcpStream::connect("example.com:80").await?; | that the best API is the one you already know. And finally, we believe that | ||||||
|     stream.write_all(b"GET /index.html HTTP/1.0\r\n\r\n").await?; | providing an asynchronous counterpart to the standard library is the best way | ||||||
|  | stdlib provides a reliable basis for both performance and productivity. | ||||||
| 
 | 
 | ||||||
|     let mut buf = vec![]; | 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. | ||||||
| 
 | 
 | ||||||
|     io::timeout(Duration::from_secs(5), async { | ## Installation | ||||||
|         stream.read_to_end(&mut buf).await?; |  | ||||||
|         Ok(buf) |  | ||||||
|     }).await |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| fn main() { | With [cargo add][cargo-add] installed run: | ||||||
|     task::block_on(async { | 
 | ||||||
|         let raw_response = get().await.expect("request"); | ```sh | ||||||
|         let response = String::from_utf8(raw_response) | $ cargo add async-std | ||||||
|             .expect("utf8 conversion"); |  | ||||||
|         println!("received: {}", response); |  | ||||||
|     }); |  | ||||||
| } |  | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| ## Features | We also provide a set of "unstable" features with async-std. See the [features | ||||||
|  | documentation] on how to enable them. | ||||||
| 
 | 
 | ||||||
| `async-std` is strongly commited to following semver. This means your code won't | [cargo-add]: https://github.com/killercup/cargo-edit | ||||||
| break unless _you_ decide to upgrade. | [features documentation]: https://docs.rs/async-std/#features | ||||||
| 
 |  | ||||||
| However every now and then we come up with something that we think will work |  | ||||||
| _great_ for `async-std`, and we want to provide a sneak-peek so you can try it |  | ||||||
| out. This is what we call _"unstable"_ features. You can try out the unstable |  | ||||||
| features by enabling the `unstable` feature in your `Cargo.toml` file: |  | ||||||
| 
 |  | ||||||
| ```toml |  | ||||||
| [dependencies.async-std] |  | ||||||
| version = "0.99" |  | ||||||
| features = ["unstable"] |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| Just be careful when using these features, as they may change between |  | ||||||
| versions. |  | ||||||
| 
 |  | ||||||
| ## Take a look around |  | ||||||
| 
 |  | ||||||
| Clone the repo: |  | ||||||
| 
 |  | ||||||
| ``` |  | ||||||
| git clone git@github.com:async-rs/async-std.git && cd async-std |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| Generate docs: |  | ||||||
| 
 |  | ||||||
| ``` |  | ||||||
| cargo +nightly doc --features docs --open |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| Check out the [examples](examples). To run an example: |  | ||||||
| 
 |  | ||||||
| ``` |  | ||||||
| cargo +nightly run --example hello-world |  | ||||||
| ``` |  | ||||||
| 
 |  | ||||||
| ## Contributing |  | ||||||
| 
 |  | ||||||
| See [our contribution document][contribution]. |  | ||||||
| 
 |  | ||||||
| [contribution]: https://async.rs/contribute |  | ||||||
| 
 | 
 | ||||||
| ## License | ## License | ||||||
| 
 | 
 | ||||||
| Licensed under either of | <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> | ||||||
| 
 | 
 | ||||||
|  * Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) | <br/> | ||||||
|  * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) |  | ||||||
| 
 |  | ||||||
| at your option. |  | ||||||
| 
 |  | ||||||
| #### Contribution |  | ||||||
| 
 | 
 | ||||||
|  | <sub> | ||||||
| Unless you explicitly state otherwise, any contribution intentionally submitted | Unless you explicitly state otherwise, any contribution intentionally submitted | ||||||
| for inclusion in the work by you, as defined in the Apache-2.0 license, shall be | for inclusion in this crate by you, as defined in the Apache-2.0 license, shall | ||||||
| dual licensed as above, without any additional terms or conditions. | be dual licensed as above, without any additional terms or conditions. | ||||||
|  | </sub> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue