-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathbuild-helper.sh
executable file
·179 lines (160 loc) · 4.51 KB
/
build-helper.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
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
#!/bin/bash
# Copyright 2023 NeuroML contributors
# File : build-helper.sh
#
# Shell script to build and publish the book when needed
VENV_DIR="$(readlink -f .venv)"
VENV_ACTIVATE_SCRIPT="$VENV_DIR/bin/activate"
VENV_STATUS="inactive"
if [[ -z "${PYTHON}" ]]
then
PYTHON="python3"
fi
function enable_virtenv() {
if [[ -z "${VIRTUAL_ENV}" ]];
then
echo "No virtual environment active."
else
# Check if it is the correct virtual env
if [[ "$VIRTUAL_ENV" == "$VENV_DIR" ]];
then
echo "Virtual env in $VENV_DIR already active."
VENV_STATUS="active"
else
echo "Another virtual env is active:"
echo "Deactivating $VIRTUAL_ENV".
deactivate
fi
fi
if [[ "$VENV_STATUS" != "active" ]]
then
if [[ -e "$VENV_ACTIVATE_SCRIPT" ]];
then
echo "Activating virtual env in $VENV_DIR."
source "$VENV_ACTIVATE_SCRIPT"
VENV_STATUS="active"
else
echo "No virtual environment found in $VENV_DIR."
echo "Creating new."
create_virtenv
VENV_STATUS="active"
fi
fi
}
function create_virtenv() {
if [[ -e "$VENV_ACTIVATE_SCRIPT" ]];
then
echo "Virtual environment activation script already exists: $VENV_ACTIVATE_SCRIPT."
echo "Please delete it and re-run to create a new one."
else
echo "Setting up new virtual environment in $VENV_DIR."
$PYTHON -m venv "$VENV_DIR"
echo "Activating virtual environment."
source "$VENV_ACTIVATE_SCRIPT"
echo "Installing required dependencies in virtual environment."
pip install wheel
pip install -r requirements-book.txt
# pip install -r requirements.txt
echo
echo "Virtual environment created."
echo "Activate using:"
echo "source $VENV_ACTIVATE_SCRIPT"
fi
}
function build_book() {
enable_virtenv
echo "Building book."
jupyter-book build ./source
}
function publish_book() {
enable_virtenv
echo "Updating URLs for 404.html"
sed -i 's|src="\([[:alnum:]_]\)|src="/\1|g' ./source/_build/html/404.html
sed -i 's|href="\([[:alnum:]_]\)|href="/\1|g' ./source/_build/html/404.html
# if we also replaced "http.." with "/http..", undo that
sed -i 's|href="/http|href="http|g' ./source/_build/html/404.html
sed -i 's|src="/http|src="http|g' ./source/_build/html/404.html
echo "Publishing book."
ghp-import -c "docs.neuroml.org" -n -p -f ./source/_build/html
}
function clean_book() {
enable_virtenv
echo "Cleaning book."
jupyter-book clean ./source
}
function watch_and_build () {
if ! command -v inotifywait > /dev/null
then
echo "inotifywait command could not be found. Please install inotify-tools."
else
build_book
while true
do
echo "Watching source dir for changes and re-building as required. Use Ctrl C to stop."
inotifywait -q -e modify,create,delete,move -r source && echo "Change detected, rebuilding.." && build_book
done
fi
}
build_pdf () {
enable_virtenv
echo "Building book PDF using LaTeX."
rm -rf ./source/_build/latex/*
jupyter-book build ./source --builder pdflatex
echo "Installing book to _static directory"
mv source/_build/latex/neuroml-documentation.pdf source/_static/files/
}
function usage() {
echo "$0: helper script to work with docs locally"
echo "OPTIONS:"
echo
echo "-h: print help message"
echo "-c: create new virtual environment in $VENV and install packages."
echo "-b: build book"
echo "-f: build pdf (using LaTeX)"
echo "-w: watch source directory for changes and build as necessary, requires inotifywait"
echo "-p: publish book to GitHub pages (requires commit access to repo)"
echo "-X: clean book"
}
if [ $# -lt 1 ]
then
usage
exit 1
fi
# parse options
while getopts "bpchwfX" OPTION
do
case $OPTION in
b)
build_book
exit 0
;;
w)
watch_and_build
exit 0
;;
f)
build_pdf
exit 0
;;
p)
publish_book
exit 0
;;
c)
create_virtenv
exit 0
;;
X)
clean_book
exit 0
;;
h)
usage
exit 0
;;
?)
usage
exit 1
;;
esac
done