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

docs: Add docs of options for xxx_with APIs #4099

Merged
merged 2 commits into from
Jan 30, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions bin/ofs/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -30,20 +30,20 @@ repository.workspace = true
rust-version.workspace = true

[dependencies]
anyhow = "1"
async-trait = "0.1.75"
clap = { version = "4.4.18", features = ["derive", "env"] }
env_logger = "0.10"
fuse3 = { "version" = "0.6.1", "features" = ["tokio-runtime", "unprivileged"] }
futures-util = "0.3.30"
libc = "0.2.151"
log = "0.4.20"
anyhow = "1"
nix = { version = "0.27.1", features = ["user"] }
opendal.workspace = true
tokio = { version = "1.34", features = [
"fs",
"macros",
"rt-multi-thread",
"io-std",
] }
nix = { version = "0.27.1", features = ["user"] }
env_logger = "0.10"
clap = { version = "4.4.18", features = ["derive", "env"] }
url = "2.5.0"
opendal.workspace = true
1 change: 0 additions & 1 deletion bindings/c/include/opendal.h
Original file line number Diff line number Diff line change
Expand Up @@ -120,7 +120,6 @@ typedef struct BlockingLister BlockingLister;
*
* Some services like s3, gcs doesn't have native blocking supports, we can use [`layers::BlockingLayer`]
* to wrap the async operator to make it blocking.
*
* # use anyhow::Result;
* use opendal::layers::BlockingLayer;
* use opendal::services::S3;
Expand Down
2 changes: 1 addition & 1 deletion bindings/java/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -98,8 +98,8 @@ services-all = [
# Default services provided by opendal.
services-azblob = ["opendal/services-azblob"]
services-azdls = ["opendal/services-azdls"]
services-cos = ["opendal/services-cos"]
services-chainsafe = ["opendal/services-chainsafe"]
services-cos = ["opendal/services-cos"]
services-fs = ["opendal/services-fs"]
services-gcs = ["opendal/services-gcs"]
services-ghac = ["opendal/services-ghac"]
Expand Down
2 changes: 1 addition & 1 deletion bindings/nodejs/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -93,8 +93,8 @@ services-all = [
# Default services provided by opendal.
services-azblob = ["opendal/services-azblob"]
services-azdls = ["opendal/services-azdls"]
services-cos = ["opendal/services-cos"]
services-chainsafe = ["opendal/services-chainsafe"]
services-cos = ["opendal/services-cos"]
services-fs = ["opendal/services-fs"]
services-gcs = ["opendal/services-gcs"]
services-ghac = ["opendal/services-ghac"]
Expand Down
2 changes: 1 addition & 1 deletion bindings/php/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@

[package]
name = "opendal-php"
version = "0.1.0"
publish = false
version = "0.1.0"

authors = ["Apache OpenDAL <[email protected]>"]
edition = "2021"
Expand Down
2 changes: 1 addition & 1 deletion bindings/python/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -95,8 +95,8 @@ services-all = [
# Default services provided by opendal.
services-azblob = ["opendal/services-azblob"]
services-azdls = ["opendal/services-azdls"]
services-cos = ["opendal/services-cos"]
services-chainsafe = ["opendal/services-chainsafe"]
services-cos = ["opendal/services-cos"]
services-fs = ["opendal/services-fs"]
services-gcs = ["opendal/services-gcs"]
services-ghac = ["opendal/services-ghac"]
Expand Down
2 changes: 1 addition & 1 deletion bindings/ruby/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@

[package]
name = "opendal-ruby"
version = "0.1.0"
publish = false
version = "0.1.0"

authors = ["Apache OpenDAL <[email protected]>"]
edition = "2021"
Expand Down
8 changes: 4 additions & 4 deletions core/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,8 @@ layers-await-tree = ["dep:await-tree"]
# Enable layers async-backtrace support.
layers-async-backtrace = ["dep:async-backtrace"]
# Enable dtrace support.
layers-dtrace=["dep:probe"]
layers-blocking = ["internal-tokio-rt"]
layers-dtrace = ["dep:probe"]

services-alluxio = []
services-atomicserver = ["dep:atomic_lib"]
Expand Down Expand Up @@ -156,9 +156,9 @@ services-gridfs = ["dep:mongodb"]
services-hdfs = ["dep:hdrs"]
services-http = []
services-huggingface = []
services-icloud = ["internal-path-cache"]
services-ipfs = ["dep:prost"]
services-ipmfs = []
services-icloud = ["internal-path-cache"]
services-koofr = []
services-libsql = ["dep:hrana-client-proto"]
services-memcached = ["dep:bb8"]
Expand Down Expand Up @@ -202,11 +202,11 @@ services-vercel-artifacts = []
# Deprecated
# wasabi services support has been removed.
# We will remove this feature in the next version.
services-hdfs-native = ["hdfs-native"]
services-wasabi = []
services-webdav = []
services-webhdfs = []
services-yandex-disk = []
services-hdfs-native = ["hdfs-native"]

internal-tokio-rt = ["tokio/rt-multi-thread"]

Expand Down Expand Up @@ -341,7 +341,7 @@ suppaftp = { version = "5.3.1", default-features = false, features = [
# for services-tikv
tikv-client = { version = "0.3.0", optional = true, default-features = false }
# for services-hdfs-native
hdfs-native = { version = "0.6.0", optional = true}
hdfs-native = { version = "0.6.0", optional = true }

# Layers
# for layers-async-backtrace
Expand Down
27 changes: 15 additions & 12 deletions core/src/layers/dtrace.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,19 +15,21 @@
// specific language governing permissions and limitations
// under the License.

use crate::raw::Accessor;
use crate::raw::*;
use crate::*;
use async_trait::async_trait;
use bytes::Bytes;
use probe::probe_lazy;
use std::ffi::CString;
use std::fmt::Debug;
use std::fmt::Formatter;
use std::io;
use std::task::Context;
use std::task::Poll;

use async_trait::async_trait;
use bytes::Bytes;
use probe::probe_lazy;

use crate::raw::Accessor;
use crate::raw::*;
use crate::*;

/// Support User Statically-Defined Tracing(aka USDT) on Linux
///
/// This layer is an experimental feature, it will be enabled by `features = ["layers-dtrace"]` in Cargo.toml.
Expand Down Expand Up @@ -113,11 +115,10 @@ use std::task::Poll;
///
/// Example:
/// ```
///
/// use anyhow::Result;
/// use opendal::layers::DTraceLayer;
/// use opendal::services::Fs;
/// use opendal::Operator;
/// use opendal::layers::DTraceLayer;
///
/// #[tokio::main]
/// async fn main() -> Result<()> {
Expand All @@ -126,10 +127,12 @@ use std::task::Poll;
/// builder.root("/tmp");
///
/// // `Accessor` provides the low level APIs, we will use `Operator` normally.
/// let op: Operator = Operator::new(builder)?.layer(DtraceLayer::default()).finish();
///
/// let path="/tmp/test.txt";
/// for _ in 1..100000{
/// let op: Operator = Operator::new(builder)?
/// .layer(DtraceLayer::default())
/// .finish();
///
/// let path = "/tmp/test.txt";
/// for _ in 1..100000 {
/// let bs = vec![0; 64 * 1024 * 1024];
/// op.write(path, bs).await?;
/// op.read(path).await?;
Expand Down
35 changes: 22 additions & 13 deletions core/src/layers/timeout.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,9 @@
use std::future::Future;
use std::io::SeekFrom;
use std::pin::Pin;
use std::task::ready;
use std::task::Context;
use std::task::Poll;
use std::task::{ready, Context};
use std::time::Duration;

use async_trait::async_trait;
Expand Down Expand Up @@ -57,18 +58,21 @@ use crate::*;
/// operations, 3 seconds timeout for all io operations.
///
/// ```
/// use std::time::Duration;
///
/// use anyhow::Result;
/// use opendal::layers::TimeoutLayer;
/// use opendal::services;
/// use opendal::Operator;
/// use opendal::Scheme;
/// use std::time::Duration;
///
/// let _ = Operator::new(services::Memory::default())
/// .expect("must init")
/// .layer(TimeoutLayer::default()
/// .with_timeout(Duration::from_secs(10))
/// .with_io_timeout(Duration::from_secs(3)))
/// .layer(
/// TimeoutLayer::default()
/// .with_timeout(Duration::from_secs(10))
/// .with_io_timeout(Duration::from_secs(3)),
/// )
/// .finish();
/// ```
///
Expand Down Expand Up @@ -368,17 +372,22 @@ impl<R: oio::List> oio::List for TimeoutWrapper<R> {

#[cfg(test)]
mod tests {
use crate::layers::{TimeoutLayer, TypeEraseLayer};
use crate::raw::oio::ReadExt;
use crate::raw::*;
use crate::*;
use async_trait::async_trait;
use bytes::Bytes;
use std::io::SeekFrom;
use std::sync::Arc;
use std::task::{Context, Poll};
use std::task::Context;
use std::task::Poll;
use std::time::Duration;
use tokio::time::{sleep, timeout};

use async_trait::async_trait;
use bytes::Bytes;
use tokio::time::sleep;
use tokio::time::timeout;

use crate::layers::TimeoutLayer;
use crate::layers::TypeEraseLayer;
use crate::raw::oio::ReadExt;
use crate::raw::*;
use crate::*;

#[derive(Debug, Clone, Default)]
struct MockService;
Expand Down
16 changes: 11 additions & 5 deletions core/src/raw/oio/write/block_write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -326,14 +326,20 @@ where

#[cfg(test)]
mod tests {
use super::*;
use crate::raw::oio::{StreamExt, WriteBuf, WriteExt};
use bytes::Bytes;
use pretty_assertions::assert_eq;
use rand::{thread_rng, Rng, RngCore};
use std::collections::HashMap;
use std::sync::Mutex;

use bytes::Bytes;
use pretty_assertions::assert_eq;
use rand::thread_rng;
use rand::Rng;
use rand::RngCore;

use super::*;
use crate::raw::oio::StreamExt;
use crate::raw::oio::WriteBuf;
use crate::raw::oio::WriteExt;

struct TestWrite {
length: u64,
bytes: HashMap<Uuid, Bytes>,
Expand Down
10 changes: 7 additions & 3 deletions core/src/raw/oio/write/multipart_write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -404,11 +404,15 @@ where

#[cfg(test)]
mod tests {
use std::sync::Mutex;

use pretty_assertions::assert_eq;
use rand::thread_rng;
use rand::Rng;
use rand::RngCore;

use super::*;
use crate::raw::oio::WriteExt;
use pretty_assertions::assert_eq;
use rand::{thread_rng, Rng, RngCore};
use std::sync::Mutex;

struct TestWrite {
upload_id: String,
Expand Down
12 changes: 8 additions & 4 deletions core/src/raw/oio/write/range_write.rs
Original file line number Diff line number Diff line change
Expand Up @@ -354,13 +354,17 @@ impl<W: RangeWrite> oio::Write for RangeWriter<W> {

#[cfg(test)]
mod tests {
use super::*;
use crate::raw::oio::WriteExt;
use pretty_assertions::assert_eq;
use rand::{thread_rng, Rng, RngCore};
use std::collections::HashSet;
use std::sync::Mutex;

use pretty_assertions::assert_eq;
use rand::thread_rng;
use rand::Rng;
use rand::RngCore;

use super::*;
use crate::raw::oio::WriteExt;

struct TestWrite {
length: u64,
bytes: HashSet<u64>,
Expand Down
17 changes: 11 additions & 6 deletions core/src/raw/path_cache.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,12 +15,15 @@
// specific language governing permissions and limitations
// under the License.

use crate::raw::*;
use crate::*;
use std::collections::VecDeque;

use async_trait::async_trait;
use moka::sync::Cache;
use std::collections::VecDeque;
use tokio::sync::{Mutex, MutexGuard};
use tokio::sync::Mutex;
use tokio::sync::MutexGuard;

use crate::raw::*;
use crate::*;

/// The trait required for path cacher.
#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
Expand Down Expand Up @@ -191,10 +194,12 @@ impl<Q: PathQuery> PathCacher<Q> {

#[cfg(test)]
mod tests {
use crate::raw::{PathCacher, PathQuery};
use crate::*;
use async_trait::async_trait;

use crate::raw::PathCacher;
use crate::raw::PathQuery;
use crate::*;

struct TestQuery {}

#[async_trait]
Expand Down
3 changes: 2 additions & 1 deletion core/src/raw/tokio_util.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@
// specific language governing permissions and limitations
// under the License.

use crate::{Error, ErrorKind};
use crate::Error;
use crate::ErrorKind;

/// Parse tokio error into opendal::Error.
pub fn new_task_join_error(e: tokio::task::JoinError) -> Error {
Expand Down
2 changes: 1 addition & 1 deletion core/src/services/dropbox/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,14 +15,14 @@
// specific language governing permissions and limitations
// under the License.

use serde::Deserialize;
use std::collections::HashMap;
use std::fmt::Debug;
use std::fmt::Formatter;
use std::sync::Arc;

use chrono::DateTime;
use chrono::Utc;
use serde::Deserialize;
use tokio::sync::Mutex;

use super::backend::DropboxBackend;
Expand Down
9 changes: 6 additions & 3 deletions core/src/services/gdrive/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,13 @@ use serde::Deserialize;
use tokio::sync::Mutex;

use super::backend::GdriveBackend;
use crate::raw::{normalize_root, PathCacher};
use crate::raw::{ConfigDeserializer, HttpClient};
use crate::raw::normalize_root;
use crate::raw::ConfigDeserializer;
use crate::raw::HttpClient;
use crate::raw::PathCacher;
use crate::services::gdrive::core::GdriveCore;
use crate::services::gdrive::core::GdrivePathQuery;
use crate::services::gdrive::core::GdriveSigner;
use crate::services::gdrive::core::{GdriveCore, GdrivePathQuery};
use crate::Scheme;
use crate::*;

Expand Down
Loading
Loading