-
-
Notifications
You must be signed in to change notification settings - Fork 74
/
Copy pathdocupages.py
executable file
·127 lines (106 loc) · 3.8 KB
/
docupages.py
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
116
117
118
119
120
121
122
123
124
125
126
127
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import pathlib
import tempfile
import shutil
import subprocess
import argparse
from typing import Union
def copy_docs_output_dir(
docs_dir: Union[str, pathlib.Path], out: Union[str, pathlib.Path]
) -> None:
shutil.copytree(pathlib.Path(docs_dir).resolve(), out, dirs_exist_ok=True)
def github_pages_nojekyll(out: Union[str, pathlib.Path]) -> None:
with pathlib.Path(out, ".nojekyll").open("w+"):
pass
def git_init(repo: str, branch: str, working_dir: Union[str, pathlib.Path]) -> None:
try:
subprocess.run(
["git", "clone", "-b", branch, repo, "."], cwd=working_dir, check=True
)
except subprocess.CalledProcessError:
subprocess.run(["git", "clone", repo, "."], cwd=working_dir, check=True)
subprocess.run(
["git", "switch", "--orphan", branch], cwd=working_dir, check=True
)
subprocess.run(
["git", "config", "user.name", "GitHub Actions"], cwd=working_dir, check=True
)
subprocess.run(
["git", "config", "user.email", "[email protected]"],
cwd=working_dir,
check=True,
)
subprocess.run(["git", "rm", "-rf", "*"], cwd=working_dir, check=True)
def git_add_documentation_files(working_dir: Union[str, pathlib.Path]) -> None:
subprocess.run(
["git", "add", "."], cwd=working_dir, stdout=subprocess.DEVNULL, check=True
)
def git_commit(message: str, working_dir: Union[str, pathlib.Path]) -> None:
subprocess.run(["git", "commit", "-m", message], cwd=working_dir, check=True)
def git_push(
repository: str, branch: str, token: str, working_dir: Union[str, pathlib.Path]
) -> None:
repo = repository.replace(r"//", rf"//{token}@")
subprocess.run(
["git", "push", repo, branch, "--quiet"], cwd=working_dir, check=True
)
def generate_documentation(
docs_dir: pathlib.Path, working_dir: Union[str, pathlib.Path]
) -> None:
doxygen_dir = docs_dir.joinpath("doxygen")
subprocess.run(["doxygen"], cwd=doxygen_dir)
mkdocs_dir = docs_dir.joinpath("mkdocs")
copy_docs_output_dir(
doxygen_dir.joinpath("html"), mkdocs_dir.joinpath("docs", "doxygen")
)
subprocess.run(["poetry", "install", "--no-root"], cwd=mkdocs_dir)
subprocess.run(
["poetry", "run", "mkdocs", "build"],
cwd=mkdocs_dir,
check=True,
)
shutil.copytree(mkdocs_dir.joinpath("site"), working_dir, dirs_exist_ok=True)
def main() -> None:
parser = argparse.ArgumentParser(
description="Upload generated documentation to GitHub Pages"
)
parser.add_argument("-n", action="store_true", help="Dry run enable")
parser.add_argument(
"-r",
"--repo",
type=str,
required=True,
help="Link to repository where documentation should be built",
)
parser.add_argument(
"-b",
"--branch",
type=str,
required=True,
help="Branch to put documentation to (e.g. 'gh-pages' for GitHub)",
)
parser.add_argument(
"-t",
"--token",
type=str,
required=True,
help="Token that allows push to the specified branch",
)
parser.add_argument(
"--commit",
type=str,
required=True,
help="Commit ID to use for documentation generation",
)
options = parser.parse_args()
with tempfile.TemporaryDirectory() as docudir:
git_init(options.repo, options.branch, docudir)
github_pages_nojekyll(docudir)
generate_documentation(pathlib.Path("docs").resolve(), docudir)
git_add_documentation_files(docudir)
if not options.n:
git_commit(f"Update {options.commit} documentation", docudir)
git_push(options.repo, options.branch, options.token, docudir)
if __name__ == "__main__":
main()