diff --git a/.github/workflows/docs.yaml b/.github/workflows/docs.yaml new file mode 100644 index 0000000..868aa55 --- /dev/null +++ b/.github/workflows/docs.yaml @@ -0,0 +1,48 @@ +# Adjusted workflow from: https://github.com/mitmproxy/pdoc/blob/25f325d06aaacba9711f957f48e770029f608f6a/.github/workflows/docs.yml + +name: Generate documentation using pdoc and deploy as gh page. + +# build the documentation whenever there are new commits on main +on: + push: + branches: + - dev + # Alternative: only build for tags. + # tags: + # - '*' + +# security: restrict permissions for CI jobs. +permissions: + contents: read + +jobs: + # Build the documentation and upload the static HTML files as an artifact. + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v4 + - uses: actions/setup-python@v5 + with: + python-version: '3.11' + + # Install all dependencies (including pdoc) + - run: pip install -e .[docs] + - run: pdoc -d numpy -o docs tensorflow_time_series_dataset + - uses: actions/upload-pages-artifact@v3 + with: + path: docs/ + + # Deploy the artifact to GitHub pages. + # This is a separate job so that only actions/deploy-pages has the necessary permissions. + deploy: + needs: build + runs-on: ubuntu-latest + permissions: + pages: write + id-token: write + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + steps: + - id: deployment + uses: actions/deploy-pages@v4 diff --git a/pyproject.toml b/pyproject.toml index f632006..b104275 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -42,6 +42,10 @@ develop = [ 'python-lsp-server[all]', 'ruff' ] +docs = [ + 'python_project_skeleton[test]', + 'pdoc' +] test = [ 'pytest', 'pytest-xdist'