forked from PyGithub/PyGithub
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmanage.sh
executable file
·99 lines (81 loc) · 2.52 KB
/
manage.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
#!/bin/bash
# -*- coding: utf-8 -*-
function publish {
bump
readme
#doc
push
}
function check {
pep8 --ignore=E501 github scripts doc *.py || exit
}
function fix_headers {
python scripts/fix_headers.py
}
function test {
test2
test3
}
function test2 {
coverage run --branch --include=github/*.py --omit=github/tests/*.py setup.py test --quiet || exit
coverage report --show-missing || exit
}
function test3 {
python3 setup.py test --quiet || exit
}
function bump {
previousVersion=$( grep '^version =' setup.py | sed 's/version = \"\(.*\)\"/\1/' )
echo "Next version number? (previous: '$previousVersion')"
read version
sed -i -b "s/version = .*/version = \"$version\"/" setup.py
}
function readme {
# creates a changelog based on the commits from the previous version until now
changelog=$(tail -n +6 doc/changes.rst)
gitlog=$(git log v$previousVersion.. --oneline --pretty=format:'* %s (%h)' | grep -v "Merge")
today=$(date "+(%B %m, %Y)")
echo "Change log\n==========\n\nStable versions\n~~~~~~~~~~~~~~~\n\nVersion $version $today\n-----------------------------------\n\n$gitlog\n$changelog" > doc/changes.rst
}
function doc {
rm -rf gh-pages
git clone . gh-pages -b gh-pages || exit
sphinx-build -b html -d doc/doctrees doc gh-pages/v1 || exit
cd gh-pages
git add . --all || exit
git commit --message "Generate doc of v1" || exit
git push origin gh-pages || exit
cd ..
}
function push {
echo "Break (Ctrl+c) here if something is wrong. Else, press enter"
read foobar
git commit -am "Publish version $version"
git tag -m "Version $version" v$version
git push origin master
git push --tags
}
function unmerged {
BRANCHES_NOT_TO_BE_MERGED="-e gh-pages -e topic/DependencyGraph"
COMMITS_NOT_TO_BE_MERGED="-e 1bea00a -e 11aeaa7 -e dd1e255 -e 670c6fb -e ed87a91 -e 072fbcb -e 421a743 -e 0c45af7 -e 92e4df4 -e 79ebd4b -e 0965ffd -e e1990c5 -e 55f3250"
for b in `git branch -a --no-merged | grep -v $BRANCHES_NOT_TO_BE_MERGED`
do
if git --no-pager log ..$b --oneline | grep -v $COMMITS_NOT_TO_BE_MERGED > /dev/null
then
echo $b
git --no-pager log ..$b --oneline
echo
fi
done
}
function compare_to_api_ref_doc {
if [ -e developer.github.com ]
then
cd developer.github.com
git pull
cd ..
else
git clone https://github.com/github/developer.github.com.git
fi
python scripts/compare_to_api_ref_doc.py
}
$1