Skip to content

Commit

Permalink
Use docc for documentation generation
Browse files Browse the repository at this point in the history
  • Loading branch information
ffried committed May 7, 2022
1 parent 60390c8 commit 109eba4
Show file tree
Hide file tree
Showing 5 changed files with 238 additions and 84 deletions.
232 changes: 232 additions & 0 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,232 @@
name: Publish Documentation

on:
release:
types:
- published
- edited
push:
branches: [ master ]

jobs:
release-context:
runs-on: ubuntu-latest
outputs:
version-name: ${{github.ref_name}}
is-latest: ${{steps.compare-tags.output.is-latest}}
steps:
- uses: joutvhu/[email protected]
id: latest-release
with:
latest: true
throwing: false
env:
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
- name: Compare tags
id: compare-tags
run: |
if [ '${{github.ref_type}}' == 'tag' ] && [ '${{steps.latest-release.outputs.tag_name}}' == '${{github.ref_name}}' ]; then
echo "::set-output name=is-latest::true"
else
echo "::set-output name=is-latest::false"
fi
spm-context:
runs-on: ubuntu-latest
outputs:
package-dump: ${{steps.dump-package.outputs.package-dump}}
steps:
- uses: swift-actions/[email protected]
id: swift-setup
with:
swift-version: '5.6'
- name: Read OS Version
uses: sersoft-gmbh/[email protected]
id: os-version
- uses: actions/[email protected]
# We don't use a cache here, because SPM doesn't resolve dependencies when dumping packages.
- name: Dump package
id: dump-package
# We need to escape newlines: https://github.community/t/set-output-truncates-multiline-strings/16852/5
run: |
package_dump="$(swift package dump-package)"
package_dump="${package_dump//'%'/'%25'}"
package_dump="${package_dump//$'\n'/'%0A'}"
package_dump="${package_dump//$'\r'/'%0D'}"
echo "::set-output name=package-dump::${package_dump}"
generate-docs:
needs:
- release-context
- spm-context
runs-on: ubuntu-latest
strategy:
matrix:
target: ${{fromJson(needs.spm-context.outputs.package-dump).products.*.targets.*}}
steps:
- uses: swift-actions/[email protected]
id: swift-setup
with:
swift-version: '5.6'
- name: Read OS Version
uses: sersoft-gmbh/[email protected]
id: os-version
- uses: actions/[email protected]
- uses: actions/[email protected]
with:
path: .build
key: ${{runner.os}}-${{steps.os-version.outputs.version}}-${{github.repository}}-spm-${{steps.swift-setup.outputs.version}}-${{hashFiles('**/Package.resolved')}}
restore-keys: |
${{runner.os}}-${{steps.os-version.outputs.version}}-${{github.repository}}-spm-${{steps.swift-setup.outputs.version}}-
- uses: sersoft-gmbh/[email protected]
env:
ENABLE_DOCC_SUPPORT: '1'
DOCC_JSON_PRETTYPRINT: 'YES'
with:
package-version: ${{needs.release-context.outputs.version-name}}
targets: ${{matrix.target}}
enable-inherited-docs: true
enable-index-building: false
transform-for-static-hosting: true
hosting-base-path: ${{github.event.repository.name}}/${{needs.release-context.outputs.version-name}}
output: ${{matrix.target}}-docs
- name: Package docs
run: tar -cvf '${{matrix.target}}-docs.tar' '${{matrix.target}}-docs'
- uses: actions/upload-artifact@v3
with:
name: ${{matrix.target}}-docs
path: ${{matrix.target}}-docs.tar

publish-docs:
needs:
- release-context
- spm-context
- generate-docs
runs-on: ubuntu-latest
steps:
- uses: actions/[email protected]
with:
ref: gh-pages
path: repository
- uses: actions/download-artifact@v3
with:
path: artifacts
- name: Extract tars
run: find artifacts -name '*.tar' -execdir tar -xvf '{}' --strip-components 1 \; -delete
- name: Merge documentations
env:
TARGETS: ${{join(fromJson(needs.spm-context.outputs.package-dump).products.*.targets.*, ' ')}}
DOCS_BASE_DIR: repository/${{needs.release-context.outputs.version-name}}
run: |
rm -rf "${DOCS_BASE_DIR}"
is_first=1
for target in $TARGETS; do
if [ $is_first -eq 1 ]; then
echo "Copying initial documentation for ${target}"
cp -R "artifacts/${target}-docs" "${DOCS_BASE_DIR}"
is_first=0
else
echo "Merging documentation for ${target}"
cp -R "artifacts/${target}-docs/data/documentation/"* "${DOCS_BASE_DIR}/data/documentation/"
cp -R "artifacts/${target}-docs/documentation/"* "${DOCS_BASE_DIR}/documentation/"
fi
done
echo "Deleting non-mergable metadata.json"
rm -f "${DOCS_BASE_DIR}/metadata.json"
- name: Create version index
working-directory: repository
env:
TARGET_DOCS_DIR: ${{needs.release-context.outputs.version-name}}/documentation
INDEX_FILE: ${{needs.release-context.outputs.version-name}}/index.html
BASE_URL: 'https://${{github.repository_owner}}.github.io/${{github.event.repository.name}}/${{needs.release-context.outputs.version-name}}/documentation'
run: |
target_count=0
target_list=""
single_target_name=""
for target in $(ls "${TARGET_DOCS_DIR}"); do
if [ -d "${TARGET_DOCS_DIR}/${target}" ]; then
single_target_name="${target}"
target_count=$((target_count+1))
target_list="${target_list}<li><a href=\"${BASE_URL}/${target}\"><code>${target}</code> Documentation</a></li>"
fi
done
if [ ${target_count} -gt 1 ]; then
echo "Found ${target_count} targets. Generating list..."
cat > "${INDEX_FILE}" <<EOF
<!DOCTYPE html>
<html>
<head>
<title>${{github.event.repository.name}} Documentation</title>
</head>
<body>
<ul>
${target_list}
</ul>
</body>
</html>
EOF
else
echo "Found one target. Generating redirect file to target ${single_target_name}"
cat > "${INDEX_FILE}" <<EOF
<!DOCTYPE html>
<html>
<head>
<title>${{github.event.repository.name}} Documentation</title>
<meta http-equiv="refresh" content="0; url=${BASE_URL}/${single_target_name}" />
</head>
<body>
<p>Redirecting...</p>
</body>
</html>
EOF
fi
- name: Create root index
working-directory: repository
env:
REDIRECT_URL: 'https://${{github.repository_owner}}.github.io/${{github.event.repository.name}}/latest'
run: |
cat > 'index.html' <<EOF
<!DOCTYPE html>
<html>
<head>
<title>${{github.event.repository.name}} Documentation</title>
<meta http-equiv="refresh" content="0; url=${REDIRECT_URL}" />
</head>
<body>
<p>Redirecting...</p>
</body>
</html>
EOF
- name: Create latest symlink
if: ${{needs.release-context.outputs.is-latest}}
working-directory: repository
run: |
rm -f 'latest'
ln -s '${{needs.release-context.outputs.version-name}}' 'latest'
- name: Determine changes
id: check-changes
working-directory: repository
run: |
if [ -n "$(git status --porcelain)" ]; then
echo "::set-output name=has-changes::true"
else
echo "::set-output name=has-changes::false"
fi
- uses: crazy-max/[email protected]
if: ${{steps.check-changes.outputs.has-changes}}
with:
keep_history: true
build_dir: repository
commit_message: Deploy documentation for '${{needs.release-context.outputs.version-name}}'
env:
GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}

cleanup:
needs:
- generate-docs
- publish-docs
if: always()
runs-on: ubuntu-latest
steps:
- name: Cleanup Artifacts
uses: joutvhu/delete-artifact@v1
69 changes: 0 additions & 69 deletions .github/workflows/release.yml

This file was deleted.

14 changes: 0 additions & 14 deletions .jazzy.yaml

This file was deleted.

5 changes: 5 additions & 0 deletions Package.swift
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
// The swift-tools-version declares the minimum version of Swift required to build this package.

import PackageDescription
import Foundation

let package = Package(
name: "route-docs",
Expand Down Expand Up @@ -42,3 +43,7 @@ let package = Package(
dependencies: ["RouteDocs"]),
]
)

if ProcessInfo.processInfo.environment["ENABLE_DOCC_SUPPORT"] == "1" {
package.dependencies.append(.package(url: "https://github.com/apple/swift-docc-plugin", from: "1.0.0"))
}
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
![Tests](https://github.com/sersoft-gmbh/route-docs/workflows/Tests/badge.svg)
[![Codacy Badge](https://app.codacy.com/project/badge/Grade/79e8965866ad4ed9a2cf4389c0a3a1a1)](https://www.codacy.com/gh/sersoft-gmbh/route-docs/dashboard?utm_source=github.com&amp;utm_medium=referral&amp;utm_content=sersoft-gmbh/route-docs&amp;utm_campaign=Badge_Grade)
[![codecov](https://codecov.io/gh/sersoft-gmbh/route-docs/branch/master/graph/badge.svg?token=UUQetUQ4hG)](https://codecov.io/gh/sersoft-gmbh/route-docs)
[![jazzy](https://raw.githubusercontent.com/sersoft-gmbh/route-docs/gh-pages/badge.svg?sanitize=true)](https://sersoft-gmbh.github.io/route-docs)
[![Docs](https://img.shields.io/badge/-documentation-informational)](https://sersoft-gmbh.github.io/route-docs)

This adds some types and extensions to Vapor's `Route` type that allows documenting each route.
Also, a `ViewContext` object helps in bringing these documentations to a web page.
Expand Down

0 comments on commit 109eba4

Please sign in to comment.