| tag | da40d8599b83ee3f2dfa45385c51e669ef92ede9 | |
|---|---|---|
| tagger | Xuanwo <github@xuanwo.io> | Sat Apr 02 22:28:56 2022 +0800 |
| object | e8ac38c495f39afe3bd0e56a9d9baea26bc7465f |
Release v0.4.1
| commit | e8ac38c495f39afe3bd0e56a9d9baea26bc7465f | [log] [tgz] |
|---|---|---|
| author | Xuanwo <github@xuanwo.io> | Sat Apr 02 22:28:36 2022 +0800 |
| committer | GitHub <noreply@github.com> | Sat Apr 02 22:28:36 2022 +0800 |
| tree | 082f52c559bb98173900139934c73c2c31fd9317 | |
| parent | 446dcfb3b7dcf4d7f553b6970134fa531bba644c [diff] |
Bump to version 0.4.1 (#213) Signed-off-by: Xuanwo <github@xuanwo.io>
Open Data Access Layer that connect the whole world together.
You may be looking for:
OpenDAL is in alpha stage and has been early adopted by databend. Welcome any feedback at Discussions!
use anyhow::Result; use futures::AsyncReadExt; use futures::StreamExt; use opendal::services::fs; use opendal::ObjectMode; use opendal::Operator; #[tokio::main] async fn main() -> Result<()> { let op = Operator::new(fs::Backend::build().root("/tmp").finish().await?); let o = op.object("test_file"); // Write data info file; let _ = o.write("Hello, World!").await?; // Read data from file; let bs = o.read().await?; // Read range from file; let bs = o.range_read(1..=11).await?; // Get file's Metadata let meta = o.metadata().await?; // List dir. let mut obs = op.objects("").await?.map(|o| o.expect("list object")); while let Some(o) = obs.next().await { let meta = o.metadata().await?; let path = meta.path(); let mode = meta.mode(); let length = meta.content_length(); } // Delete file. o.delete().await?; Ok(()) }
More examples could be found at examples.
Check out the CONTRIBUTING.md guide for more details on getting started with contributing to this project.
Submit issues for bug report or asking questions in discussion.