Update documentation to reflect the discontinuation. #5790
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
env: | |
# We aim to always test with the latest stable Rust toolchain, however we pin to a specific | |
# version like 1.70. Note that we only specify MAJOR.MINOR and not PATCH so that bugfixes still | |
# come automatically. If the version specified here is no longer the latest stable version, | |
# then please feel free to submit a PR that adjusts it along with the potential clippy fixes. | |
RUST_STABLE_VER: "1.82" # In quotes because otherwise 1.70 would be interpreted as 1.7 | |
name: CI | |
on: | |
pull_request: | |
merge_group: | |
jobs: | |
rustfmt: | |
runs-on: ubuntu-latest | |
name: cargo fmt | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: rustfmt | |
- name: cargo fmt | |
run: cargo fmt --all --check | |
- name: install ripgrep | |
run: | | |
sudo apt update | |
sudo apt install ripgrep | |
- name: check copyright headers | |
run: bash .github/copyright.sh | |
test-stable: | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [windows-latest, macos-latest, ubuntu-latest] | |
name: cargo clippy+test | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install additional linux dependencies | |
run: | | |
sudo apt update | |
sudo apt install libpango1.0-dev libxkbcommon-dev libxkbcommon-x11-dev | |
if: contains(matrix.os, 'ubuntu') | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
# Clippy packages in deeper-to-higher dependency order | |
- name: cargo clippy druid-shell | |
run: cargo clippy --manifest-path=druid-shell/Cargo.toml --all-targets --no-default-features --features=x11,image,raw-win-handle -- -D warnings | |
- name: cargo clippy druid | |
run: cargo clippy --manifest-path=druid/Cargo.toml --all-targets --no-default-features --features=svg,image,im,x11,raw-win-handle -- -D warnings | |
- name: cargo clippy druid-derive | |
run: cargo clippy --manifest-path=druid-derive/Cargo.toml --all-targets -- -D warnings | |
# there's no platform specific code here so we only run once | |
if: contains(matrix.os, 'mac') | |
- name: cargo clippy book examples | |
run: cargo clippy --manifest-path=docs/book_examples/Cargo.toml --all-targets -- -D warnings | |
if: contains(matrix.os, 'mac') | |
# Test packages in deeper-to-higher dependency order | |
- name: cargo test druid-shell | |
run: cargo test --manifest-path=druid-shell/Cargo.toml --no-default-features --features=x11,image,raw-win-handle | |
# We use --all-targets to skip doc tests; we run them in a parallel task | |
# there are no gtk-specific doctests in the main druid crate anyway | |
- name: cargo test druid | |
run: cargo test --manifest-path=druid/Cargo.toml --all-targets --no-default-features --features=svg,image,im,x11 | |
- name: cargo test druid-derive | |
run: cargo test --manifest-path=druid-derive/Cargo.toml | |
if: contains(matrix.os, 'mac') | |
- name: cargo test book examples | |
run: cargo test --manifest-path=docs/book_examples/Cargo.toml | |
if: contains(matrix.os, 'mac') | |
# we test the wayland backend as a separate job | |
test-stable-wayland: | |
runs-on: ubuntu-latest | |
name: cargo clippy+test (wayland) | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install additional wayland dependencies | |
run: | | |
sudo apt update | |
sudo apt install libwayland-dev libpango1.0-dev libxkbcommon-dev | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
- name: cargo clippy druid-shell | |
run: cargo clippy --manifest-path=druid-shell/Cargo.toml --all-targets --no-default-features --features=wayland,image,raw-win-handle -- -D warnings | |
- name: cargo test druid-shell | |
run: cargo test --manifest-path=druid-shell/Cargo.toml --no-default-features --features=wayland,image,raw-win-handle | |
# We use --all-targets to skip doc tests; there are no wayland-specific | |
# doctests in the main druid crate anyway | |
- name: cargo test druid | |
run: cargo test --manifest-path=druid/Cargo.toml --all-targets --no-default-features --features=wayland,svg,image,im,raw-win-handle | |
# we test the gtk backend as a separate job because gtk install takes | |
# a long time. | |
test-stable-gtk: | |
runs-on: ubuntu-latest | |
name: cargo clippy+test (gtk) | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install additional gtk dependencies | |
run: | | |
sudo apt update | |
sudo apt install libgtk-3-dev | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
- name: cargo clippy druid-shell | |
run: cargo clippy --manifest-path=druid-shell/Cargo.toml --all-targets --features=image,raw-win-handle -- -D warnings | |
- name: cargo test druid-shell | |
run: cargo test --manifest-path=druid-shell/Cargo.toml --features=image,raw-win-handle | |
# We use --all-targets to skip doc tests; there are no gtk-specific | |
# doctests in the main druid crate anyway | |
- name: cargo test druid | |
run: cargo test --manifest-path=druid/Cargo.toml --all-targets --features=svg,image,im,raw-win-handle | |
test-stable-wasm: | |
runs-on: macOS-latest | |
name: cargo test (wasm32) | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install wasm-pack | |
uses: jetli/[email protected] | |
with: | |
version: latest | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
targets: wasm32-unknown-unknown | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
- name: cargo clippy druid-shell (wasm) | |
run: cargo clippy --manifest-path=druid-shell/Cargo.toml --all-targets --target wasm32-unknown-unknown -- -D warnings | |
# Test wasm32 relevant packages in deeper-to-higher dependency order | |
# TODO: Find a way to make tests work. Until then the tests are merely compiled. | |
- name: cargo test compile druid-shell | |
run: cargo test --manifest-path=druid-shell/Cargo.toml --features=image --no-run --target wasm32-unknown-unknown | |
# We use --all-targets to skip doc tests; there are no wasm-specific | |
# doctests in the main druid crate anyway | |
- name: cargo test compile druid | |
# TODO: Add svg feature when it's no longer broken with wasm | |
run: cargo test --manifest-path=druid/Cargo.toml --all-targets --features=image,im --no-run --target wasm32-unknown-unknown | |
- name: cargo test compile book examples | |
run: cargo test --manifest-path=docs/book_examples/Cargo.toml --no-run --target wasm32-unknown-unknown | |
## build the special druid-web-examples package. | |
- name: wasm-pack build examples | |
run: wasm-pack build --dev --target web druid/examples/web | |
## build the hello_web example | |
- name: wasm-pack build hello_web example | |
run: wasm-pack build --dev --target web druid/examples/hello_web | |
doctest-stable: | |
runs-on: macOS-latest | |
name: druid doctests | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
- name: cargo test druid --doc | |
run: cargo test --manifest-path=druid/Cargo.toml --doc --no-default-features --features=svg,image,im,raw-win-handle | |
check-docs: | |
name: Docs | |
runs-on: ${{ matrix.os }} | |
strategy: | |
matrix: | |
os: [windows-latest, macos-latest, ubuntu-latest] | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install additional linux dependencies | |
run: | | |
sudo apt update | |
sudo apt install libgtk-3-dev libwayland-dev libpango1.0-dev libxkbcommon-dev libxkbcommon-x11-dev | |
if: contains(matrix.os, 'ubuntu') | |
- name: install nightly toolchain | |
uses: dtolnay/rust-toolchain@nightly | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
# Doc packages in deeper-to-higher dependency order | |
- name: cargo doc druid-shell | |
run: cargo doc --manifest-path=druid-shell/Cargo.toml --features=image,raw-win-handle --no-deps --document-private-items -Zunstable-options -Zrustdoc-scrape-examples | |
- name: cargo doc druid | |
run: cargo doc --manifest-path=druid/Cargo.toml --features=svg,image,im,raw-win-handle --no-deps --document-private-items -Zunstable-options -Zrustdoc-scrape-examples | |
- name: cargo doc druid-derive | |
run: cargo doc --manifest-path=druid-derive/Cargo.toml --no-deps --document-private-items | |
- name: cargo doc book examples | |
run: cargo doc --manifest-path=docs/book_examples/Cargo.toml --no-deps --document-private-items | |
# On Linux also attempt docs for X11. | |
- name: cargo doc druid-shell (X11) | |
run: cargo doc --manifest-path=druid-shell/Cargo.toml --no-default-features --features=x11,image,raw-win-handle --no-deps --document-private-items -Zunstable-options -Zrustdoc-scrape-examples | |
if: contains(matrix.os, 'ubuntu') | |
# On Linux also attempt docs for Wayland. | |
- name: cargo doc druid-shell (Wayland) | |
run: cargo doc --manifest-path=druid-shell/Cargo.toml --no-default-features --features=wayland,image,raw-win-handle --no-deps --document-private-items -Zunstable-options -Zrustdoc-scrape-examples | |
if: contains(matrix.os, 'ubuntu') | |
mdbook-build: | |
runs-on: ubuntu-latest | |
name: mdbook build | |
steps: | |
- uses: actions/checkout@v4 | |
- name: install stable toolchain | |
uses: dtolnay/rust-toolchain@master | |
with: | |
toolchain: ${{ env.RUST_STABLE_VER }} | |
components: clippy | |
- name: restore cache | |
uses: Swatinem/rust-cache@v2 | |
- name: install mdbook | |
run: cargo install --vers "^0.4" mdbook | |
- name: mdbook build | |
run: mdbook build | |
working-directory: ./docs |