2022-04-12 00:55:51 +10:00
|
|
|
name: Docs
|
2022-04-12 00:55:10 +10:00
|
|
|
|
|
|
|
on:
|
|
|
|
push:
|
|
|
|
branches:
|
|
|
|
- master
|
|
|
|
|
|
|
|
defaults:
|
|
|
|
run:
|
|
|
|
# This otherwise gets run under dash which does not support brace expansion
|
|
|
|
shell: bash
|
|
|
|
|
|
|
|
jobs:
|
|
|
|
docs:
|
|
|
|
name: Build and test all components
|
|
|
|
runs-on: ubuntu-18.04
|
|
|
|
steps:
|
2023-01-26 03:29:50 +11:00
|
|
|
- uses: actions/checkout@v3
|
2022-04-12 00:55:10 +10:00
|
|
|
# Needed for git-describe to do anything useful
|
|
|
|
- name: Fetch all git history
|
|
|
|
run: git fetch --force --prune --tags --unshallow
|
|
|
|
|
|
|
|
- name: Install dependencies
|
|
|
|
run: |
|
|
|
|
sudo apt-get update
|
2022-08-20 01:33:25 +10:00
|
|
|
sudo apt-get install -y libasound2-dev libgl-dev libjack-dev libxcb1-dev libxcb-icccm4-dev libxcursor-dev libxkbcommon-dev libxcb-shape0-dev libxcb-xfixes0-dev
|
2022-04-12 00:55:10 +10:00
|
|
|
|
2023-01-26 03:29:50 +11:00
|
|
|
- uses: actions/cache@v3
|
2022-11-14 04:46:29 +11:00
|
|
|
# FIXME: Caching `target/` causes the Windows runner to blow up after some time
|
|
|
|
if: startsWith(matrix.os, 'windows')
|
2022-04-12 00:55:10 +10:00
|
|
|
with:
|
|
|
|
path: |
|
|
|
|
~/.cargo/registry/index/
|
|
|
|
~/.cargo/registry/cache/
|
|
|
|
~/.cargo/git/db/
|
2022-11-12 12:22:46 +11:00
|
|
|
key: ${{ matrix.name }}-${{ matrix.cross-target }}
|
2023-01-26 03:29:50 +11:00
|
|
|
- uses: actions/cache@v3
|
2022-11-14 04:46:29 +11:00
|
|
|
if: "!startsWith(matrix.os, 'windows')"
|
2022-11-10 05:54:05 +11:00
|
|
|
with:
|
|
|
|
path: |
|
|
|
|
~/.cargo/registry/index/
|
|
|
|
~/.cargo/registry/cache/
|
|
|
|
~/.cargo/git/db/
|
|
|
|
target/
|
2022-11-12 12:22:46 +11:00
|
|
|
key: ${{ matrix.name }}-${{ matrix.cross-target }}
|
2022-04-12 00:55:10 +10:00
|
|
|
|
|
|
|
- name: Set up Rust toolchain
|
2023-01-26 03:22:26 +11:00
|
|
|
# Nightly is needed to document the SIMD feature and for the
|
|
|
|
# `doc_auto_cfg` feature
|
|
|
|
uses: dtolnay/rust-toolchain@nightly
|
2023-01-26 03:35:31 +11:00
|
|
|
- name: Generate documentation for all targets
|
|
|
|
# Don't use --all-features here as that will enable a whole bunch of
|
|
|
|
# conflicting iced features. We also don't want to use `--workspace`
|
|
|
|
# here because that would also document our plugins and binary crates.
|
|
|
|
run: >-
|
|
|
|
cargo doc --features docs,simd,standalone,zstd --no-deps
|
2022-04-12 00:55:10 +10:00
|
|
|
-p nih_plug
|
|
|
|
-p nih_plug_derive
|
|
|
|
-p nih_plug_egui
|
|
|
|
-p nih_plug_iced
|
|
|
|
-p nih_plug_vizia
|
|
|
|
-p nih_plug_xtask
|
|
|
|
|
|
|
|
- name: Add a redirect index page
|
|
|
|
run: |
|
2022-04-12 00:59:07 +10:00
|
|
|
cat > target/doc/index.html <<EOF
|
2022-04-12 00:55:10 +10:00
|
|
|
<meta charset="utf-8">
|
2022-04-12 01:11:52 +10:00
|
|
|
<meta http-equiv="refresh" content="0; url=nih_plug">
|
2022-04-12 00:55:10 +10:00
|
|
|
EOF
|
|
|
|
- name: Deploy to GitHub Pages
|
|
|
|
uses: JamesIves/github-pages-deploy-action@v4.3.0
|
|
|
|
with:
|
|
|
|
branch: gh-pages
|
|
|
|
folder: target/doc
|
2022-04-27 04:20:14 +10:00
|
|
|
|
|
|
|
# Having the gh-pages branch on this repository adds a whole bunch of
|
|
|
|
# noise to the GitHub feed if you follow this repo
|
|
|
|
repository-name: robbert-vdh/nih-plug-docs
|
|
|
|
ssh-key: ${{ secrets.DOCS_DEPLOY_KEY }}
|