-
Notifications
You must be signed in to change notification settings - Fork 121
/
Copy pathapidocs.sh
executable file
·49 lines (41 loc) · 1.68 KB
/
apidocs.sh
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
#!/bin/bash
# This bash script builds the API documentation for ConfigArgParse.
# Resolve source directory path. From https://stackoverflow.com/questions/59895/how-to-get-the-source-directory-of-a-bash-script-from-within-the-script-itself/246128#246128
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )"
cd $SCRIPT_DIR
# Stop if errors
set -euo pipefail
IFS=$'\n\t,'
# Figure the project version
project_version="$(python3 setup.py -V)"
# Figure commit ref
git_sha="$(git rev-parse HEAD)"
if ! git describe --exact-match --tags > /dev/null 2>&1 ; then
is_tag=false
else
git_sha="$(git describe --exact-match --tags)"
is_tag=true
fi
# Init output folder
docs_folder="./apidocs/"
rm -rf "${docs_folder}"
mkdir -p "${docs_folder}"
# We generate the docs for the argparse module too, such that we can document
# the methods inherited from argparse.ArgumentParser, not only the methods that configargparse overrides.
# And it help to have a better vision of the whole thing also.
curl https://raw.githubusercontent.com/python/cpython/3.9/Lib/argparse.py > ./argparse.py
echo "__docformat__ = 'restructuredtext'" >> ./argparse.py
# Delete the file when the script exits
trap "rm -f ./argparse.py" EXIT
pydoctor \
--project-name="ConfigArgParse ${project_version}" \
--project-url="https://github.com/bw2/ConfigArgParse" \
--html-viewsource-base="https://github.com/bw2/ConfigArgParse/tree/${git_sha}" \
--intersphinx=https://docs.python.org/3/objects.inv \
--make-html \
--quiet \
--project-base-dir=.\
--docformat=google \
--html-output="${docs_folder}" \
./argparse.py ./configargparse.py || true
echo "API docs generated in ${docs_folder}"