Merge branch 'different-optimizations-for-master-and-branches' into 'master'
CI: Use full optimizations for master and faster config else See merge request famedly/conduit!155next
commit
cefca2d0d1
241
.gitlab-ci.yml
241
.gitlab-ci.yml
|
@ -9,85 +9,6 @@ variables:
|
||||||
FF_USE_FASTZIP: 1
|
FF_USE_FASTZIP: 1
|
||||||
CACHE_COMPRESSION_LEVEL: fastest
|
CACHE_COMPRESSION_LEVEL: fastest
|
||||||
|
|
||||||
test:cargo:
|
|
||||||
stage: "test"
|
|
||||||
needs: []
|
|
||||||
image: "rust:latest"
|
|
||||||
tags: ["docker"]
|
|
||||||
variables:
|
|
||||||
CARGO_HOME: "cargohome"
|
|
||||||
cache:
|
|
||||||
paths:
|
|
||||||
- target
|
|
||||||
- cargohome
|
|
||||||
key: test_cache
|
|
||||||
interruptible: true
|
|
||||||
before_script:
|
|
||||||
- mkdir -p $CARGO_HOME && echo "using $CARGO_HOME to cache cargo deps"
|
|
||||||
- apt-get update -yqq
|
|
||||||
- apt-get install -yqq --no-install-recommends build-essential libssl-dev pkg-config
|
|
||||||
- rustup component add clippy rustfmt
|
|
||||||
script:
|
|
||||||
- rustc --version && cargo --version # Print version info for debugging
|
|
||||||
- cargo fmt --all -- --check
|
|
||||||
- cargo test --workspace --verbose --locked
|
|
||||||
- cargo clippy
|
|
||||||
|
|
||||||
test:sytest:
|
|
||||||
stage: "test"
|
|
||||||
allow_failure: true
|
|
||||||
needs:
|
|
||||||
- "build:cargo:x86_64-unknown-linux-musl"
|
|
||||||
image:
|
|
||||||
name: "valkum/sytest-conduit:latest"
|
|
||||||
entrypoint: [""]
|
|
||||||
tags: ["docker"]
|
|
||||||
variables:
|
|
||||||
PLUGINS: "https://github.com/valkum/sytest_conduit/archive/master.tar.gz"
|
|
||||||
before_script:
|
|
||||||
- "mkdir -p /app"
|
|
||||||
- "cp ./conduit-x86_64-unknown-linux-musl /app/conduit"
|
|
||||||
- "chmod +x /app/conduit"
|
|
||||||
- "rm -rf /src && ln -s $CI_PROJECT_DIR/ /src"
|
|
||||||
- "mkdir -p /work/server-0/database/ && mkdir -p /work/server-1/database/ && mkdir -p /work/server-2/database/"
|
|
||||||
- "cd /"
|
|
||||||
script:
|
|
||||||
- "SYTEST_EXIT_CODE=0"
|
|
||||||
- "/bootstrap.sh conduit || SYTEST_EXIT_CODE=1"
|
|
||||||
- "perl /sytest/tap-to-junit-xml.pl --puretap --input /logs/results.tap --output $CI_PROJECT_DIR/sytest.xml \"Sytest\" && cp /logs/results.tap $CI_PROJECT_DIR/results.tap"
|
|
||||||
- "exit $SYTEST_EXIT_CODE"
|
|
||||||
artifacts:
|
|
||||||
when: always
|
|
||||||
paths:
|
|
||||||
- "$CI_PROJECT_DIR/sytest.xml"
|
|
||||||
- "$CI_PROJECT_DIR/results.tap"
|
|
||||||
reports:
|
|
||||||
junit: "$CI_PROJECT_DIR/sytest.xml"
|
|
||||||
|
|
||||||
|
|
||||||
test:register:element-web-stable:
|
|
||||||
stage: "test"
|
|
||||||
needs:
|
|
||||||
- "build:cargo:x86_64-unknown-linux-gnu"
|
|
||||||
image: "buildkite/puppeteer:latest"
|
|
||||||
tags: ["docker"]
|
|
||||||
interruptible: true
|
|
||||||
script:
|
|
||||||
- "CONDUIT_CONFIG=tests/test-config.toml ./conduit-x86_64-unknown-linux-gnu > conduit.log &"
|
|
||||||
- "cd tests/client-element-web/"
|
|
||||||
- "npm install puppeteer"
|
|
||||||
- "node test-element-web-registration.js \"https://app.element.io/\" \"http://localhost:6167\""
|
|
||||||
- "killall --regexp \"conduit\""
|
|
||||||
- "cd ../.."
|
|
||||||
- "cat conduit.log"
|
|
||||||
artifacts:
|
|
||||||
paths:
|
|
||||||
- "tests/client-element-web/*.png"
|
|
||||||
- "*.log"
|
|
||||||
expire_in: 1 week
|
|
||||||
when: always
|
|
||||||
retry: 1
|
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------- #
|
# --------------------------------------------------------------------- #
|
||||||
# Cargo: Compiling for different architectures #
|
# Cargo: Compiling for different architectures #
|
||||||
|
@ -105,7 +26,7 @@ test:register:element-web-stable:
|
||||||
paths:
|
paths:
|
||||||
- cargohome
|
- cargohome
|
||||||
- target/
|
- target/
|
||||||
key: "build_cache-$TARGET"
|
key: "build_cache-$TARGET-release"
|
||||||
before_script:
|
before_script:
|
||||||
- 'echo "Building for target $TARGET"'
|
- 'echo "Building for target $TARGET"'
|
||||||
- 'mkdir -p cargohome && CARGOHOME="cargohome"'
|
- 'mkdir -p cargohome && CARGOHOME="cargohome"'
|
||||||
|
@ -115,26 +36,21 @@ test:register:element-web-stable:
|
||||||
- "apt-get install -yqq --no-install-recommends $NEEDED_PACKAGES"
|
- "apt-get install -yqq --no-install-recommends $NEEDED_PACKAGES"
|
||||||
- "rustup target add $TARGET"
|
- "rustup target add $TARGET"
|
||||||
script:
|
script:
|
||||||
# Set some cargo tuning here, because targets overwrite the 'variables'
|
|
||||||
- "export CARGO_INCREMENTAL=true"
|
|
||||||
- "export CARGO_PROFILE_RELEASE_CODEGEN_UNITS=16"
|
|
||||||
- "export CARGO_PROFILE_RELEASE_LTO=thin"
|
|
||||||
- time cargo build --target $TARGET --release
|
- time cargo build --target $TARGET --release
|
||||||
- 'mv "target/$TARGET/release/conduit" "conduit-$TARGET"'
|
- 'mv "target/$TARGET/release/conduit" "conduit-$TARGET"'
|
||||||
|
|
||||||
build:cargo:x86_64-unknown-linux-gnu:
|
|
||||||
|
build:release:cargo:x86_64-unknown-linux-gnu:
|
||||||
extends: .build-cargo-shared-settings
|
extends: .build-cargo-shared-settings
|
||||||
variables:
|
variables:
|
||||||
TARGET: "x86_64-unknown-linux-gnu"
|
TARGET: "x86_64-unknown-linux-gnu"
|
||||||
rules:
|
|
||||||
- if: "$CI_COMMIT_BRANCH"
|
|
||||||
artifacts:
|
artifacts:
|
||||||
name: "conduit-x86_64-unknown-linux-gnu"
|
name: "conduit-x86_64-unknown-linux-gnu"
|
||||||
paths:
|
paths:
|
||||||
- "conduit-x86_64-unknown-linux-gnu"
|
- "conduit-x86_64-unknown-linux-gnu"
|
||||||
expose_as: "Release binary x86_64-unknown-linux-gnu"
|
expose_as: "Conduit for x86_64-unknown-linux-gnu"
|
||||||
|
|
||||||
build:cargo:armv7-unknown-linux-gnueabihf:
|
build:release:cargo:armv7-unknown-linux-gnueabihf:
|
||||||
extends: .build-cargo-shared-settings
|
extends: .build-cargo-shared-settings
|
||||||
variables:
|
variables:
|
||||||
TARGET: "armv7-unknown-linux-gnueabihf"
|
TARGET: "armv7-unknown-linux-gnueabihf"
|
||||||
|
@ -146,9 +62,9 @@ build:cargo:armv7-unknown-linux-gnueabihf:
|
||||||
name: "conduit-armv7-unknown-linux-gnueabihf"
|
name: "conduit-armv7-unknown-linux-gnueabihf"
|
||||||
paths:
|
paths:
|
||||||
- "conduit-armv7-unknown-linux-gnueabihf"
|
- "conduit-armv7-unknown-linux-gnueabihf"
|
||||||
expose_as: "Release binary armv7-unknown-linux-gnueabihf"
|
expose_as: "Conduit for armv7-unknown-linux-gnueabihf"
|
||||||
|
|
||||||
build:cargo:aarch64-unknown-linux-gnu:
|
build:release:cargo:aarch64-unknown-linux-gnu:
|
||||||
extends: .build-cargo-shared-settings
|
extends: .build-cargo-shared-settings
|
||||||
variables:
|
variables:
|
||||||
TARGET: "aarch64-unknown-linux-gnu"
|
TARGET: "aarch64-unknown-linux-gnu"
|
||||||
|
@ -162,13 +78,11 @@ build:cargo:aarch64-unknown-linux-gnu:
|
||||||
name: "conduit-aarch64-unknown-linux-gnu"
|
name: "conduit-aarch64-unknown-linux-gnu"
|
||||||
paths:
|
paths:
|
||||||
- "conduit-aarch64-unknown-linux-gnu"
|
- "conduit-aarch64-unknown-linux-gnu"
|
||||||
expose_as: "Release binary aarch64-unknown-linux-gnu"
|
expose_as: "Conduit for aarch64-unknown-linux-gnu"
|
||||||
|
|
||||||
build:cargo:x86_64-unknown-linux-musl:
|
build:release:cargo:x86_64-unknown-linux-musl:
|
||||||
extends: .build-cargo-shared-settings
|
extends: .build-cargo-shared-settings
|
||||||
image: "rust:alpine"
|
image: "rust:alpine"
|
||||||
rules:
|
|
||||||
- if: '$CI_COMMIT_BRANCH' # Always run
|
|
||||||
variables:
|
variables:
|
||||||
TARGET: "x86_64-unknown-linux-musl"
|
TARGET: "x86_64-unknown-linux-musl"
|
||||||
before_script:
|
before_script:
|
||||||
|
@ -181,7 +95,47 @@ build:cargo:x86_64-unknown-linux-musl:
|
||||||
name: "conduit-x86_64-unknown-linux-musl"
|
name: "conduit-x86_64-unknown-linux-musl"
|
||||||
paths:
|
paths:
|
||||||
- "conduit-x86_64-unknown-linux-musl"
|
- "conduit-x86_64-unknown-linux-musl"
|
||||||
expose_as: "Release binary x86_64-unknown-linux-musl"
|
expose_as: "Conduit for x86_64-unknown-linux-musl"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
.cargo-debug-shared-settings:
|
||||||
|
extends: ".build-cargo-shared-settings"
|
||||||
|
rules:
|
||||||
|
- if: '$CI_COMMIT_BRANCH'
|
||||||
|
cache:
|
||||||
|
key: "build_cache-$TARGET-debug"
|
||||||
|
script:
|
||||||
|
- "time cargo build --target $TARGET"
|
||||||
|
- 'mv "target/$TARGET/debug/conduit" "conduit-debug-$TARGET"'
|
||||||
|
|
||||||
|
build:debug:cargo:x86_64-unknown-linux-gnu:
|
||||||
|
extends: ".cargo-debug-shared-settings"
|
||||||
|
variables:
|
||||||
|
TARGET: "x86_64-unknown-linux-gnu"
|
||||||
|
artifacts:
|
||||||
|
name: "conduit-debug-x86_64-unknown-linux-gnu"
|
||||||
|
paths:
|
||||||
|
- "conduit-debug-x86_64-unknown-linux-gnu"
|
||||||
|
expose_as: "Conduit DEBUG for x86_64-unknown-linux-gnu"
|
||||||
|
|
||||||
|
build:debug:cargo:x86_64-unknown-linux-musl:
|
||||||
|
extends: ".cargo-debug-shared-settings"
|
||||||
|
image: "rust:alpine"
|
||||||
|
variables:
|
||||||
|
TARGET: "x86_64-unknown-linux-musl"
|
||||||
|
before_script:
|
||||||
|
- 'echo "Building for target $TARGET"'
|
||||||
|
- 'mkdir -p cargohome && CARGOHOME="cargohome"'
|
||||||
|
- "cat /etc/*-release && rustc --version && cargo --version" # Print version info for debugging
|
||||||
|
- "rustup target add $TARGET"
|
||||||
|
- "apk add libc-dev"
|
||||||
|
artifacts:
|
||||||
|
name: "conduit-debug-x86_64-unknown-linux-musl"
|
||||||
|
paths:
|
||||||
|
- "conduit-debug-x86_64-unknown-linux-musl"
|
||||||
|
expose_as: "Conduit DEBUG for x86_64-unknown-linux-musl"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------- #
|
# --------------------------------------------------------------------- #
|
||||||
|
@ -252,7 +206,7 @@ build:cargo-deb:x86_64-unknown-linux-gnu:
|
||||||
build:docker:main:
|
build:docker:main:
|
||||||
extends: .docker-shared-settings
|
extends: .docker-shared-settings
|
||||||
needs:
|
needs:
|
||||||
- "build:cargo:x86_64-unknown-linux-musl"
|
- "build:release:cargo:x86_64-unknown-linux-musl"
|
||||||
script:
|
script:
|
||||||
- >
|
- >
|
||||||
/kaniko/executor
|
/kaniko/executor
|
||||||
|
@ -272,6 +226,91 @@ build:docker:main:
|
||||||
- if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
|
- if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------- #
|
||||||
|
# Run tests #
|
||||||
|
# --------------------------------------------------------------------- #
|
||||||
|
|
||||||
|
test:cargo:
|
||||||
|
stage: "test"
|
||||||
|
needs: [ ]
|
||||||
|
image: "rust:latest"
|
||||||
|
tags: [ "docker" ]
|
||||||
|
variables:
|
||||||
|
CARGO_HOME: "cargohome"
|
||||||
|
cache:
|
||||||
|
paths:
|
||||||
|
- target
|
||||||
|
- cargohome
|
||||||
|
key: test_cache
|
||||||
|
interruptible: true
|
||||||
|
before_script:
|
||||||
|
- mkdir -p $CARGO_HOME && echo "using $CARGO_HOME to cache cargo deps"
|
||||||
|
- apt-get update -yqq
|
||||||
|
- apt-get install -yqq --no-install-recommends build-essential libssl-dev pkg-config
|
||||||
|
- rustup component add clippy rustfmt
|
||||||
|
script:
|
||||||
|
- rustc --version && cargo --version # Print version info for debugging
|
||||||
|
- cargo fmt --all -- --check
|
||||||
|
- cargo test --workspace --verbose --locked
|
||||||
|
- cargo clippy
|
||||||
|
|
||||||
|
test:sytest:
|
||||||
|
stage: "test"
|
||||||
|
allow_failure: true
|
||||||
|
needs:
|
||||||
|
- "build:debug:cargo:x86_64-unknown-linux-musl"
|
||||||
|
image:
|
||||||
|
name: "valkum/sytest-conduit:latest"
|
||||||
|
entrypoint: [ "" ]
|
||||||
|
tags: [ "docker" ]
|
||||||
|
variables:
|
||||||
|
PLUGINS: "https://github.com/valkum/sytest_conduit/archive/master.tar.gz"
|
||||||
|
before_script:
|
||||||
|
- "mkdir -p /app"
|
||||||
|
- "cp ./conduit-debug-x86_64-unknown-linux-musl /app/conduit"
|
||||||
|
- "chmod +x /app/conduit"
|
||||||
|
- "rm -rf /src && ln -s $CI_PROJECT_DIR/ /src"
|
||||||
|
- "mkdir -p /work/server-0/database/ && mkdir -p /work/server-1/database/ && mkdir -p /work/server-2/database/"
|
||||||
|
- "cd /"
|
||||||
|
script:
|
||||||
|
- "SYTEST_EXIT_CODE=0"
|
||||||
|
- "/bootstrap.sh conduit || SYTEST_EXIT_CODE=1"
|
||||||
|
- "perl /sytest/tap-to-junit-xml.pl --puretap --input /logs/results.tap --output $CI_PROJECT_DIR/sytest.xml \"Sytest\" && cp /logs/results.tap $CI_PROJECT_DIR/results.tap"
|
||||||
|
- "exit $SYTEST_EXIT_CODE"
|
||||||
|
artifacts:
|
||||||
|
when: always
|
||||||
|
paths:
|
||||||
|
- "$CI_PROJECT_DIR/sytest.xml"
|
||||||
|
- "$CI_PROJECT_DIR/results.tap"
|
||||||
|
reports:
|
||||||
|
junit: "$CI_PROJECT_DIR/sytest.xml"
|
||||||
|
|
||||||
|
|
||||||
|
test:register:element-web-stable:
|
||||||
|
stage: "test"
|
||||||
|
needs:
|
||||||
|
- "build:debug:cargo:x86_64-unknown-linux-gnu"
|
||||||
|
image: "buildkite/puppeteer:latest"
|
||||||
|
tags: [ "docker" ]
|
||||||
|
interruptible: true
|
||||||
|
script:
|
||||||
|
- "CONDUIT_CONFIG=tests/test-config.toml ./conduit-debug-x86_64-unknown-linux-gnu > conduit.log &"
|
||||||
|
- "cd tests/client-element-web/"
|
||||||
|
- "npm install puppeteer"
|
||||||
|
- "node test-element-web-registration.js \"https://app.element.io/\" \"http://localhost:6167\""
|
||||||
|
- "killall --regexp \"conduit\""
|
||||||
|
- "cd ../.."
|
||||||
|
- "cat conduit.log"
|
||||||
|
artifacts:
|
||||||
|
paths:
|
||||||
|
- "tests/client-element-web/*.png"
|
||||||
|
- "*.log"
|
||||||
|
expire_in: 1 week
|
||||||
|
when: always
|
||||||
|
retry: 1
|
||||||
|
|
||||||
|
|
||||||
# --------------------------------------------------------------------- #
|
# --------------------------------------------------------------------- #
|
||||||
# Store binaries as package so they have download urls #
|
# Store binaries as package so they have download urls #
|
||||||
# --------------------------------------------------------------------- #
|
# --------------------------------------------------------------------- #
|
||||||
|
@ -279,10 +318,10 @@ build:docker:main:
|
||||||
publish:package:
|
publish:package:
|
||||||
stage: "upload artifacts"
|
stage: "upload artifacts"
|
||||||
needs:
|
needs:
|
||||||
- "build:cargo:x86_64-unknown-linux-gnu"
|
- "build:release:cargo:x86_64-unknown-linux-gnu"
|
||||||
- "build:cargo:armv7-unknown-linux-gnueabihf"
|
- "build:release:cargo:armv7-unknown-linux-gnueabihf"
|
||||||
- "build:cargo:aarch64-unknown-linux-gnu"
|
- "build:release:cargo:aarch64-unknown-linux-gnu"
|
||||||
- "build:cargo:x86_64-unknown-linux-musl"
|
- "build:release:cargo:x86_64-unknown-linux-musl"
|
||||||
- "build:cargo-deb:x86_64-unknown-linux-gnu"
|
- "build:cargo-deb:x86_64-unknown-linux-gnu"
|
||||||
rules:
|
rules:
|
||||||
- if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
|
- if: '$CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH'
|
||||||
|
|
19
Cargo.toml
19
Cargo.toml
|
@ -119,6 +119,21 @@ conf-files = [
|
||||||
maintainer-scripts = "debian/"
|
maintainer-scripts = "debian/"
|
||||||
systemd-units = { unit-name = "matrix-conduit" }
|
systemd-units = { unit-name = "matrix-conduit" }
|
||||||
|
|
||||||
# For flamegraphs:
|
[profile.dev]
|
||||||
#[profile.release]
|
lto = 'thin'
|
||||||
|
incremental = true
|
||||||
|
|
||||||
|
[profile.release]
|
||||||
|
lto = true
|
||||||
|
incremental = true
|
||||||
|
codegen-units = 1
|
||||||
|
# If you want to make flamegraphs, enable debug info:
|
||||||
# debug = true
|
# debug = true
|
||||||
|
|
||||||
|
# For releases also try to max optimizations for dependencies:
|
||||||
|
[profile.release.build-override]
|
||||||
|
opt-level = 3
|
||||||
|
codegen-units = 1
|
||||||
|
[profile.release.package."*"]
|
||||||
|
opt-level = 3
|
||||||
|
codegen-units = 1
|
||||||
|
|
15
DEPLOY.md
15
DEPLOY.md
|
@ -6,8 +6,7 @@ If you run into any problems while setting up Conduit, write an email to `timo@k
|
||||||
|
|
||||||
## Installing Conduit
|
## Installing Conduit
|
||||||
|
|
||||||
You may simply download the binary that fits your machine. Run `uname -m` to see
|
You may simply download the binary that fits your machine. Run `uname -m` to see what you need. Now copy the right url:
|
||||||
what you need. Now copy the right url:
|
|
||||||
|
|
||||||
| CPU Architecture | GNU (Ubuntu, Debian, ArchLinux, ...) | MUSL (Alpine, ... ) |
|
| CPU Architecture | GNU (Ubuntu, Debian, ArchLinux, ...) | MUSL (Alpine, ... ) |
|
||||||
| -------------------- | ------------------------------------- | ----------------------- |
|
| -------------------- | ------------------------------------- | ----------------------- |
|
||||||
|
@ -15,10 +14,13 @@ what you need. Now copy the right url:
|
||||||
| armv7 (Raspberry Pi) | [Download][armv7-gnu] | - |
|
| armv7 (Raspberry Pi) | [Download][armv7-gnu] | - |
|
||||||
| armv8 / aarch64 | [Download][armv8-gnu] | - |
|
| armv8 / aarch64 | [Download][armv8-gnu] | - |
|
||||||
|
|
||||||
[x84_64-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-x86_64-unknown-linux-gnu?job=build:cargo:x86_64-unknown-linux-gnu
|
[x84_64-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-x86_64-unknown-linux-gnu?job=build:release:cargo:x86_64-unknown-linux-gnu
|
||||||
[x84_64-musl]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-x86_64-unknown-linux-musl?job=build:cargo:x86_64-unknown-linux-musl
|
|
||||||
[armv7-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-armv7-unknown-linux-gnueabihf?job=build:cargo:armv7-unknown-linux-gnueabihf
|
[x84_64-musl]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-x86_64-unknown-linux-musl?job=build:release:cargo:x86_64-unknown-linux-musl
|
||||||
[armv8-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-aarch64-unknown-linux-gnu?job=build:cargo:aarch64-unknown-linux-gnu
|
|
||||||
|
[armv7-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-armv7-unknown-linux-gnueabihf?job=build:release:cargo:armv7-unknown-linux-gnueabihf
|
||||||
|
|
||||||
|
[armv8-gnu]: https://gitlab.com/famedly/conduit/-/jobs/artifacts/master/raw/conduit-aarch64-unknown-linux-gnu?job=build:release:cargo:aarch64-unknown-linux-gnu
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ sudo wget -O /usr/local/bin/matrix-conduit <url>
|
$ sudo wget -O /usr/local/bin/matrix-conduit <url>
|
||||||
|
@ -26,6 +28,7 @@ $ sudo chmod +x /usr/local/bin/matrix-conduit
|
||||||
```
|
```
|
||||||
|
|
||||||
Alternatively, you may compile the binary yourself using
|
Alternatively, you may compile the binary yourself using
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ cargo build --release
|
$ cargo build --release
|
||||||
```
|
```
|
||||||
|
|
Loading…
Reference in New Issue