forked from diem/website
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild_docs.sh
executable file
·93 lines (80 loc) · 3.09 KB
/
build_docs.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
#!/bin/bash
# Copyright (c) Calibra. All Rights Reserved
# run this script from the project root using `./scripts/build_docs.sh`
usage() {
echo "Usage: $0 [-b]"
echo ""
echo "Build Libra documentation."
echo ""
echo " -b Build static version of documentation (otherwise start server)"
echo ""
exit 1
}
BUILD_STATIC=false
BUILD_RUSTDOCS=false
while getopts 'hbr' flag; do
case "${flag}" in
h)
usage
;;
b)
BUILD_STATIC=true
;;
r)
BUILD_RUSTDOCS=true
;;
*)
usage
;;
esac
done
git submodule update --init
# manually copy crate README files from fixed directory
###
echo "-----------------------------------"
echo "Manually Copying READMEs to docs/crates"
echo "-----------------------------------"
sed -i.old '/^# /d' libra/admission_control/README.md; cp libra/admission_control/README.md docs/crates/admission-control.md
sed -i.old '/^# /d' libra/language/bytecode-verifier/README.md; cp libra/language/bytecode-verifier/README.md docs/crates/bytecode-verifier.md
sed -i.old '/^# /d' libra/consensus/README.md; cp libra/consensus/README.md docs/crates/consensus.md
sed -i.old '/^# /d' libra/crypto/crypto/README.md; cp libra/crypto/crypto/README.md docs/crates/crypto.md
sed -i.old '/^# /d' libra/executor/README.md; cp libra/executor/README.md docs/crates/executor.md
sed -i.old '/^# /d' libra/language/README.md; cp libra/language/README.md docs/crates/move-language.md
sed -i.old '/^# /d' libra/language/compiler/README.md; cp libra/language/compiler/README.md docs/crates/ir-to-bytecode.md
sed -i.old '/^# /d' libra/mempool/README.md; cp libra/mempool/README.md docs/crates/mempool.md
sed -i.old '/^# /d' libra/network/README.md; cp libra/network/README.md docs/crates/network.md
sed -i.old '/^# /d' libra/storage/README.md; cp libra/storage/README.md docs/crates/storage.md
sed -i.old '/^# /d' libra/language/vm/README.md; cp libra/language/vm/README.md docs/crates/vm.md
echo "-----------------------------------"
echo "Manually Copy Coding Guidelines"
echo "-----------------------------------"
sed -i.old '/^# Libra Core coding guidelines/d' libra/documentation/coding_guidelines.md
cp libra/documentation/coding_guidelines.md docs/community/coding-guidelines.md
if [[ $BUILD_RUSTDOCS == true ]]; then
echo "-----------------------------------"
echo "Generating API reference via Rustdoc"
echo "-----------------------------------"
cd libra
cargo doc --no-deps --workspace --lib || exit 1
RUSTDOC_DIR='libra/target/doc/'
DOCUSAURUS_RUSTDOC_DIR='website/static/docs/rustdocs/'
cd .. || exit
mkdir -p $DOCUSAURUS_RUSTDOC_DIR
cp -r $RUSTDOC_DIR $DOCUSAURUS_RUSTDOC_DIR
fi
echo "-----------------------------------"
echo "Building Docusaurus 🦖"
echo "-----------------------------------"
cd website || exit
npm install
if [[ $BUILD_STATIC == true ]]; then
echo "-----------------------------------"
echo "Building static site"
echo "-----------------------------------"
npm run build
else
echo "-----------------------------------"
echo "Starting local server"
echo "-----------------------------------"
npm run start
fi