From 39a49b55b95fae7205835ab42121c4cb9f2bfac2 Mon Sep 17 00:00:00 2001 From: Yuqi Feng Date: Tue, 14 May 2024 12:04:30 +0800 Subject: [PATCH 1/3] fix: broken link & tools for scripts --- website/docs/getting-started/quick-start.mdx | 13 ++++++++++--- website/docs/script/ScriptHeaders.tsx | 15 ++++++++++++--- website/docs/script/js-script.mdx | 20 ++++++++++++++------ 3 files changed, 36 insertions(+), 12 deletions(-) diff --git a/website/docs/getting-started/quick-start.mdx b/website/docs/getting-started/quick-start.mdx index ccaa94ede..86f9eb644 100644 --- a/website/docs/getting-started/quick-start.mdx +++ b/website/docs/getting-started/quick-start.mdx @@ -18,7 +18,7 @@ OffCKB provides a one-line command to start a local blockchain (CKB Devnet) with npm install -g @offckb/cli ``` -:::note +:::info Throughout this documentation, we use offckb/cli version **>=0.2.2**. You can always run the above command to update to the latest version. ::: @@ -164,15 +164,22 @@ Once the server is up and running, you can view the dApp by visiting [localhost: The boilerplate project for a full-stack CKB dApp comprises two main components: - The frontend, which utilizes the CKB JavaScript framework, [Lumos](https://github.com/ckb-js/lumos). -- The Scripts, which leverages the [ckb-script-templates](https://github.com/nervosnetwork/ckb-script-templates). +- The Scripts, which leverage the [ckb-script-templates](https://github.com/cryptape/ckb-script-templates). By default, the Next.js template comes with a simple Script `hello-world` under `contracts/hello-world/src/main.rs`. -:::note Tools You Need +:::info Tools You Need - [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. - [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` - [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) + + - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` + - Fedora 39+: `sudo dnf -y install clang` + - Archlinux: `sudo pacman --noconfirm -Syu clang` + - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` + - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` + - [Cargo-generate](https://github.com/cargo-generate/cargo-generate) Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). diff --git a/website/docs/script/ScriptHeaders.tsx b/website/docs/script/ScriptHeaders.tsx index a09a3fb21..8677127cf 100644 --- a/website/docs/script/ScriptHeaders.tsx +++ b/website/docs/script/ScriptHeaders.tsx @@ -37,6 +37,14 @@ export const ScriptHeaders: ScriptHeadersType = { make , + + sed + + , Clang 16+ - {" sample installtion steps for selected platforms are:"} + diff --git a/website/docs/script/js-script.mdx b/website/docs/script/js-script.mdx index cd61ccb17..3065fda51 100644 --- a/website/docs/script/js-script.mdx +++ b/website/docs/script/js-script.mdx @@ -110,12 +110,20 @@ understanding. The first step is to create a new Script project. We use [ckb-script-templates](https://github.com/cryptape/ckb-script-templates) for this purpose. You will need the following dependencies: -- `git`, `make`, `sed`, `bash`, `sha256sum` and others Unix utilities -- `Rust` with `riscv64` target installed: `rustup target add riscv64imac-unknown-none-elf` -- `Clang 16+` -- `cargo-generate`: You can install this via `cargo install cargo-generate` - -If you encounter any problems with these dependencies, refer to the [ReadMe](https://github.com/cryptape/ckb-script-templates?tab=readme-ov-file#dependencies) for installation details. +:::info Tools You Need + +- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. +- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` +- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) +- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) + - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` + - Fedora 39+: `sudo dnf -y install clang` + - Archlinux: `sudo pacman --noconfirm -Syu clang` + - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` + - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` + +Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). +::: ### Init a Script Project From 74717f1d287fa1c4665ca11a2b8c2648f24d2bcd Mon Sep 17 00:00:00 2001 From: Yuqi Feng Date: Tue, 14 May 2024 12:08:46 +0800 Subject: [PATCH 2/3] update tools in minimal-script --- website/docs/script/a-minimal-script.mdx | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/website/docs/script/a-minimal-script.mdx b/website/docs/script/a-minimal-script.mdx index 9c8216302..4d59f8cf4 100644 --- a/website/docs/script/a-minimal-script.mdx +++ b/website/docs/script/a-minimal-script.mdx @@ -44,12 +44,20 @@ Below is a step-by-step guide, and you can also clone the full code example from The first step is to create a new Script project. We use [ckb-script-templates](https://github.com/cryptape/ckb-script-templates) for this purpose. You will need the following dependencies: -- `git`, `make`, `sed`, `bash`, `sha256sum` and others Unix utilities -- `Rust` with `riscv64` target installed: `rustup target add riscv64imac-unknown-none-elf` -- `Clang 16+` -- `cargo-generate`: You can install this via `cargo install cargo-generate` - -If you got any problems for these dependencies, refer to [readme](https://github.com/cryptape/ckb-script-templates?tab=readme-ov-file#dependencies) for install details. +:::info Tools You Need + +- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. +- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` +- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) +- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) + - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` + - Fedora 39+: `sudo dnf -y install clang` + - Archlinux: `sudo pacman --noconfirm -Syu clang` + - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` + - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` + +Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). +::: ### Init a Script Project From b19aaec12961a4f4a5641fdd3a403815975563bd Mon Sep 17 00:00:00 2001 From: Yuqi Feng Date: Tue, 14 May 2024 12:45:26 +0800 Subject: [PATCH 3/3] move tools you need to a separate mdx file --- website/docs/getting-started/quick-start.mdx | 18 ++---------------- website/docs/script/_ScriptTools.mdx | 16 ++++++++++++++++ website/docs/script/a-minimal-script.mdx | 16 ++-------------- website/docs/script/js-script.mdx | 16 ++-------------- 4 files changed, 22 insertions(+), 44 deletions(-) create mode 100644 website/docs/script/_ScriptTools.mdx diff --git a/website/docs/getting-started/quick-start.mdx b/website/docs/getting-started/quick-start.mdx index 86f9eb644..41bd90cbd 100644 --- a/website/docs/getting-started/quick-start.mdx +++ b/website/docs/getting-started/quick-start.mdx @@ -5,6 +5,7 @@ title: Quick Start (5min) import Tabs from "@theme/Tabs"; import TabItem from "@theme/TabItem"; +import ScriptTools from "../script/_ScriptTools.mdx"; # Quick Start (5min) @@ -168,22 +169,7 @@ The boilerplate project for a full-stack CKB dApp comprises two main components: By default, the Next.js template comes with a simple Script `hello-world` under `contracts/hello-world/src/main.rs`. -:::info Tools You Need - -- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. -- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` -- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) - - - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` - - Fedora 39+: `sudo dnf -y install clang` - - Archlinux: `sudo pacman --noconfirm -Syu clang` - - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` - - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` - -- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) - -Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). -::: + ### Script-Related Commands diff --git a/website/docs/script/_ScriptTools.mdx b/website/docs/script/_ScriptTools.mdx new file mode 100644 index 000000000..ed8871ac3 --- /dev/null +++ b/website/docs/script/_ScriptTools.mdx @@ -0,0 +1,16 @@ +:::info Tools You Need + +- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. +- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` +- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) + + - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` + - Fedora 39+: `sudo dnf -y install clang` + - Archlinux: `sudo pacman --noconfirm -Syu clang` + - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` + - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` + +- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) + +Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). +::: diff --git a/website/docs/script/a-minimal-script.mdx b/website/docs/script/a-minimal-script.mdx index 4d59f8cf4..03a411f29 100644 --- a/website/docs/script/a-minimal-script.mdx +++ b/website/docs/script/a-minimal-script.mdx @@ -7,6 +7,7 @@ import Tabs from "@theme/Tabs"; import TabItem from "@theme/TabItem"; import ScriptHeaders from "./ScriptHeaders.tsx"; import TutorialHeader from "@components/TutorialHeader"; +import ScriptTools from "./_ScriptTools.mdx"; # Tutorial: A Minimal Script @@ -44,20 +45,7 @@ Below is a step-by-step guide, and you can also clone the full code example from The first step is to create a new Script project. We use [ckb-script-templates](https://github.com/cryptape/ckb-script-templates) for this purpose. You will need the following dependencies: -:::info Tools You Need - -- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. -- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` -- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) -- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) - - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` - - Fedora 39+: `sudo dnf -y install clang` - - Archlinux: `sudo pacman --noconfirm -Syu clang` - - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` - - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` - -Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). -::: + ### Init a Script Project diff --git a/website/docs/script/js-script.mdx b/website/docs/script/js-script.mdx index 3065fda51..b06df8d87 100644 --- a/website/docs/script/js-script.mdx +++ b/website/docs/script/js-script.mdx @@ -7,6 +7,7 @@ import Tabs from "@theme/Tabs"; import TabItem from "@theme/TabItem"; import ScriptHeaders from "./ScriptHeaders.tsx"; import TutorialHeader from "@components/TutorialHeader"; +import ScriptTools from "./_ScriptTools.mdx"; # Tutorial: Run JavaScript Code on CKB @@ -110,20 +111,7 @@ understanding. The first step is to create a new Script project. We use [ckb-script-templates](https://github.com/cryptape/ckb-script-templates) for this purpose. You will need the following dependencies: -:::info Tools You Need - -- [git](https://git-scm.com/), [make](https://www.tutorialspoint.com/unix_commands/make.htm), [sed](https://www.gnu.org/software/sed/), [bash](https://www.gnu.org/software/bash/), [sha256sum](https://linux.die.net/man/1/sha256sum) and others Unix utilities. -- [Rust](https://www.rust-lang.org/) with `riscv64 target`: `rustup target add riscv64imac-unknown-none-elf` -- [Clang 16+](https://releases.llvm.org/16.0.0/tools/clang/docs/ReleaseNotes.html) -- [Cargo-generate](https://github.com/cargo-generate/cargo-generate) - - Debian / Ubuntu: ` wget https://apt.llvm.org/llvm.sh && chmod +x llvm.sh && sudo./llvm.sh 16 && rm llvm.sh` - - Fedora 39+: `sudo dnf -y install clang` - - Archlinux: `sudo pacman --noconfirm -Syu clang` - - MacOS (with [Homebrew](https://brew.sh/)): `brew install llvm@16` - - Windows (with [Scoop](https://scoop.sh/)): `scoop install llvm yasm` - -Check out the `ckb-script-templates` for more [details](https://github.com/cryptape/ckb-script-templates/blob/main/README.md#dependencies). -::: + ### Init a Script Project