1234567891011121314151617181920212223242526272829303132333435363738394041 |
- #![deny(warnings)]
- // This is using the `tokio` runtime. You'll need the following dependency:
- //
- // `tokio = { version = "1", features = ["full"] }`
- #[cfg(not(target_arch = "wasm32"))]
- #[tokio::main]
- async fn main() -> Result<(), reqwest::Error> {
- // Some simple CLI args requirements...
- let url = match std::env::args().nth(1) {
- Some(url) => url,
- None => {
- println!("No CLI URL provided, using default.");
- "https://hyper.rs".into()
- }
- };
- eprintln!("Fetching {:?}...", url);
- // reqwest::get() is a convenience function.
- //
- // In most cases, you should create/build a reqwest::Client and reuse
- // it for all requests.
- let res = reqwest::get(url).await?;
- eprintln!("Response: {:?} {}", res.version(), res.status());
- eprintln!("Headers: {:#?}\n", res.headers());
- let body = res.text().await?;
- println!("{}", body);
- Ok(())
- }
- // The [cfg(not(target_arch = "wasm32"))] above prevent building the tokio::main function
- // for wasm32 target, because tokio isn't compatible with wasm32.
- // If you aren't building for wasm32, you don't need that line.
- // The two lines below avoid the "'main' function not found" error when building for wasm32 target.
- #[cfg(target_arch = "wasm32")]
- fn main() {}
|