forked from ASPP/pelita
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcommit-doc-tree.sh
executable file
·67 lines (50 loc) · 1.77 KB
/
commit-doc-tree.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
#!/bin/sh
# Script to automatically generate documentation and commit this to the gh-pages
# branch. See http://ASPP.github.com/pelita/development.rst for more
# information.
# check, if index is empty
if ! git diff-index --cached --quiet --ignore-submodules HEAD ; then
echo "Fatal: cannot work with indexed files!"
exit 1
fi
if ! git rev-parse gh-pages &> /dev/null ; then
echo "Fatal: no local branch 'gh-pages exists!'"
exit 2
fi
if [ -z $(git config branch.gh-pages.remote) ] ; then
echo "Fatal: 'gh-pages' does not have a remote branch!'"
exit 3
fi
if [ $(git rev-parse gh-pages) != $(git rev-parse $(git config branch.gh-pages.remote)/gh-pages) ] ; then
echo "Fatal: local branch 'gh-pages' and "\
"remote branch '$(git config branch.gh-pages.remote)' are out of sync!"
exit 4
fi
# get the 'git describe' output
git_describe=$(git describe)
# make the documentation, hope it doesn't fail
echo "Generating doc from $git_describe"
(cd doc; make clean)
if ! (cd doc; make html) ; then
echo "Fatal: 'make'ing the docs failed cannot commit!"
exit 5
fi
docdirectory=doc/build/html/
# Add a .nojekyll file
# This prevents the GitHub jekyll website generator from running
touch $docdirectory".nojekyll"
# Adding the doc files to the index
git add -f $docdirectory
# writing a tree using the current index
tree=$(git write-tree --prefix=$docdirectory)
# we’ll have a commit
commit=$(echo "DOC: Sphinx generated doc from $git_describe" | git commit-tree $tree -p gh-pages)
# move the branch to the commit we made, i.e. one up
git update-ref refs/heads/gh-pages $commit
# clean index
git reset HEAD
# try to checkout what we’ve done – does not matter much, if it fails
# it is purely informative
git checkout gh-pages
# print the commit message
git log -1 --oneline