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 rust usage example #2447

Merged
merged 6 commits into from
Jun 12, 2023
Merged
Show file tree
Hide file tree
Changes from 3 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
45 changes: 45 additions & 0 deletions examples/rust/rust-day01-introduction/introduction.md
Young-Flash marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
# Introduction

Rust is a systems programming language that is known for its performance, memory safety, and concurrency features. OpenDAL(**Open D**ata **A**ccess **L**ayer) is a Rust project to access data freely, painlessly and efficiently.

This examples documentation is organized in a progressive manner, with each section building upon the previous one. Each section is located in a different folder and contains both documentation and a stand-alone project that can be run independently.

The following will briefly introduce dev environment set up, the Rust project structure, some important files, and how to quickly create a project. This is prepared for those who are not familiar with Rust. If you are familiar with Rust, you can skip this section.


# Environment set up

There need rust toolchain in your local environment, if you haven't set it up, you can refer [here](https://github.com/apache/incubator-opendal/blob/main/CONTRIBUTING.md#bring-your-own-toolbox) to figure it out.


# Rust Project Structure

A typical Rust project follows a specific directory structure. Here's an overview of the main directories and files you'll encounter in a Rust project:

- src/: This directory contains the source code for your Rust project. It typically includes a main.rs file, which is the entry point for your application.

- Cargo.toml: This file contains metadata about your project, such as its name, version, and dependencies. It also specifies the build configuration for your project.

## Cargo.toml

Cargo is Rust's package manager and build tool. It uses the Cargo.toml file to manage dependencies and build configurations for your project.

Here's an example Cargo.toml file for a Rust project:

```toml
[package]
name = "my_project"
version = "0.1.0"
authors = ["Your Name <[email protected]>"]
edition = "2018"

[dependencies]
serde = { version = "1.0", features = ["derive"] }
```
## main.rs
The main.rs file is the entry point for your Rust application. It typically contains the `main()` function, which is the starting point for your program.


# Create project
Young-Flash marked this conversation as resolved.
Show resolved Hide resolved

Once you have configured the Rust environment, you can use `cargo new peoject-day01 --bin` to create a example project quickly.
25 changes: 25 additions & 0 deletions examples/rust/rust-day01-introduction/project-day01/Cargo.toml
Young-Flash marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.

[package]
name = "day01"
version = "0.1.0"
edition = "2023"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
20 changes: 20 additions & 0 deletions examples/rust/rust-day01-introduction/project-day01/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

fn main() {
println!("Hello, world!");
}
28 changes: 28 additions & 0 deletions examples/rust/rust-day02-usage/project-day02/Cargo.toml
Young-Flash marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.

[package]
name = "peoject-day02"
version = "0.1.0"
edition = "2023"

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

[dependencies]
opendal = { version = "0.34.0", features = ["services-webdav", "services-gdrive"] }
tokio = { version = "1.27", features = ["full"] }
anyhow = { version = "1.0.30", features = ["std"] }
56 changes: 56 additions & 0 deletions examples/rust/rust-day02-usage/project-day02/src/main.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

use opendal::Operator;
use opendal::Result;
use opendal::services::Fs;

#[tokio::main]
async fn main() -> Result<()> {

// Create fs backend builder.
let mut builder = Fs::default();

// set the root for fs, all operations will happen under this root.
// note that the root must be absolute path.
builder.root("/home/flash/projects/opendal-example");

// create an `Operator` from `builder`, all file operations are initiated from it.
let op: Operator = Operator::new(builder)?.finish();

// if the 'root' path haven't been set, then the `file_path` below should be `/home/flash/projects/opendal-example/1.txt`.
let file_path = "1.txt";

// read the file and print its content.
let read_file = op.read(file_path).await?;
let content = String::from_utf8(read_file).unwrap();
println!("{}", content);

// write the file.
op.write(file_path, "who are you").await?;

// verify the file content after the write operator.
let read_file = op.read(file_path).await?;
let content = String::from_utf8(read_file).unwrap();
println!("{}", content);

// copy the file to `2.txt` and delete the old file.
op.copy(file_path, "2.txt").await?;
op.delete(file_path).await?;

Ok(())
}
7 changes: 7 additions & 0 deletions examples/rust/rust-day02-usage/usage-example.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# Basic Usage

In this section, we chose `Fs` service as example because it is simple and don't need extra work to set up, all service available can be found [here](https://docs.rs/opendal/latest/opendal/services/index.html).

There is a independent project name `project-day02`, the `src/main.rs` provide a example usage about `Fs`. It `read` a file and print its content to console, overwrite some new content to it and read & print content again to verify the `write` operator has been taken effect, copy a new file and then delete the old one.

Just take a try.