-
Notifications
You must be signed in to change notification settings - Fork 48
Expand file tree
/
Copy pathcheck-docs.sh
More file actions
executable file
·115 lines (102 loc) · 3.73 KB
/
Copy pathcheck-docs.sh
File metadata and controls
executable file
·115 lines (102 loc) · 3.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#!/bin/bash
##===----------------------------------------------------------------------===##
##
## This source file is part of the Swift.org open source project
##
## Copyright (c) 2025 Apple Inc. and the Swift project authors
## Licensed under Apache License v2.0 with Runtime Library Exception
##
## See https://swift.org/LICENSE.txt for license information
## See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
##
##===----------------------------------------------------------------------===##
set -euo pipefail
log() { printf -- "** %s\n" "$*" >&2; }
error() { printf -- "** ERROR: %s\n" "$*" >&2; }
fatal() { error "$@"; exit 1; }
usage() {
cat <<EOF
Usage: $(basename "$0") [options]
Options:
--no-analyze Do not pass --analyze to 'swift package plugin generate-documentation'.
--additional-docc-arguments <args...> Extra arguments forwarded to 'swift package plugin generate-documentation'.
Consumes all remaining tokens until the next known option
(--no-analyze, -h, --help) or end of arguments.
-h, --help Show this help message.
EOF
}
is_known_option() {
case "$1" in
--no-analyze|--additional-docc-arguments|-h|--help)
return 0
;;
*)
return 1
;;
esac
}
analyze_flag="--analyze"
additional_docc_arguments=""
while [[ $# -gt 0 ]]; do
case "$1" in
--no-analyze)
analyze_flag=""
shift
;;
--additional-docc-arguments)
shift
collected=()
while [[ $# -gt 0 ]] && ! is_known_option "$1"; do
collected+=("$1")
shift
done
additional_docc_arguments="${collected[*]}"
;;
-h|--help)
usage
exit 0
;;
*)
error "Unknown argument: $1"
usage >&2
exit 2
;;
esac
done
if [ ! -f .spi.yml ]; then
fatal "No '.spi.yml' found. Failing as there is no documentation targets to check. Learn more at https://github.com/swiftlang/github-workflows/blob/main/docs/soundness-docs-check.md"
fi
if ! command -v yq &> /dev/null; then
case "$(uname -s)" in
Darwin*) brew install yq;;
Linux*) apt -q update && apt -yq install yq;;
esac
fi
package_files=$(find . -maxdepth 1 -name 'Package*.swift')
if [ -z "$package_files" ]; then
fatal "Package.swift not found. Please ensure you are running this script from the root of a Swift package."
fi
# yq 3.1.0-3 doesn't have filter, otherwise we could replace the grep call with "filter(.identity == "swift-docc-plugin") | keys | .[]"
hasDoccPlugin=$(swift package dump-package | yq -r '.dependencies[].sourceControl' | grep -e "\"identity\": \"swift-docc-plugin\"" || true)
if [[ -n $hasDoccPlugin ]]
then
log "swift-docc-plugin already exists"
else
log "Appending swift-docc-plugin"
for package_file in $package_files; do
log "Editing $package_file..."
cat <<EOF >> "$package_file"
package.dependencies.append(
.package(url: "https://github.com/swiftlang/swift-docc-plugin", from: "1.0.0")
)
EOF
done
fi
log "Checking documentation targets..."
for target in $(yq -r '.builder.configs[].documentation_targets[]' .spi.yml); do
log "Checking target $target..."
target_docc_arguments=$(yq ".builder.configs[] | select(.documentation_targets[] == \"${target}\") | .custom_documentation_parameters[]" .spi.yml)
# shellcheck disable=SC2086 # We explicitly want to explode "$analyze_flag", "$additional_docc_arguments" and "$target_docc_arguments" into multiple arguments.
swift package plugin generate-documentation --target "$target" --warnings-as-errors $analyze_flag $additional_docc_arguments $target_docc_arguments
done
log "✅ Found no documentation issues."