-
Notifications
You must be signed in to change notification settings - Fork 11
/
ets_docs.py
158 lines (126 loc) · 5.99 KB
/
ets_docs.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
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
#! /usr/bin/env python
"""A thin replacement for SetupDocs (which is no longer part of ETS).
Performs documentation building, check in, updating, etc of all actively
maintained ETS packages.
"""
import sys
import os
import subprocess
from distutils.dir_util import copy_tree
usage = """\
Usage: ets_docs -h | --help | update [PROJ] | COMMAND [args] | ALIAS [args]
-h, --help Print this message.
update This command performs a 'remote update', ie it updates the
live website from the repository. If your remote username
is different than your local username, you may specify the
remote one here.
COMMAND Run this shell command, with any following arguments, inside
each package's documentation sub-directory. If any command
arguments must be quoted, you may need to use nested quotes,
depending on the quote handling in your shell. For example:
ets_docs svn ci "'check-in comment for all packages'"
ALIAS Each alias is shorthand for a shell command with arguments.
The available aliases are pre-defined by this script, not by
the user. Any alias may be followed by optional additional
arguments.
The available aliases and their equivalent commands are:%s
Example:
Fresh install and basic workflow:
ets_docs html # Generate new HTML docs
ets_docs update traits # Updates the gh-pages branch.
The ETS packages referenced, in order of processing, are:\n%s
"""
aliases = """\n
html make html
latex make latex
"""
ets_package_names = """\
traits pyface traitsui
codetools etsdevtools scimath
enable apptools envisage
chaco mayavi blockcanvas
"""
alias_dict = {}
for line in aliases.split('\n'):
tokens = line.split()
if tokens:
alias_dict[tokens[0]] = tokens[1:]
def main():
if len(sys.argv) < 2 or sys.argv[1].startswith('-'):
print usage % (aliases, ets_package_names)
return
arg1 = sys.argv[1]
# Update the gh-pages branch
if arg1 == 'update':
if 2 < len(sys.argv):
ets_packages = sys.argv[2:]
else:
ets_packages = ets_package_names.split()
for ets_pkg_name in ets_packages:
print "Updating documentation branch for {0}...".format(ets_pkg_name)
# Find the current branch, so that we may return to it
branches = subprocess.check_output(['git', 'branch'], cwd=ets_pkg_name)
current_branch = [line.split()[1] for line in branches.splitlines() if line.startswith('*')]
current_branch = current_branch[0]
# Checkout the gh-pages branch
try:
subprocess.check_call(['git', 'checkout', 'gh-pages'], cwd=ets_pkg_name)
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
continue
# Copy the files over
print "Copying files for {0}".format(ets_pkg_name)
if ets_pkg_name == 'mayavi':
copy_tree(ets_pkg_name + '/docs/build/tvtk/html/', ets_pkg_name + '/tvtk/')
copy_tree(ets_pkg_name + '/docs/build/mayavi/html/', ets_pkg_name + '/mayavi/')
else:
copy_tree(ets_pkg_name + '/docs/build/html/', ets_pkg_name)
# Add everything to the repository
try:
subprocess.check_call(['git', 'add', '.'], cwd=ets_pkg_name)
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
continue
# Commit to the repo.
try:
subprocess.check_call(['git', 'commit', '-a', '-m', '"Updated docs."'], cwd=ets_pkg_name)
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
continue
# Push these changes.
try:
subprocess.check_call(['git', 'push'], cwd=ets_pkg_name)
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
continue
# Return to the current branch
try:
subprocess.check_call(['git', 'checkout', current_branch], cwd=ets_pkg_name)
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
continue
print
return
# Determine command from either alias or command line
if arg1 in alias_dict:
cmd = alias_dict[arg1] + sys.argv[2:]
if cmd[0] == 'python':
cmd[0] = sys.executable
else:
cmd = sys.argv[1:]
# Run the command in each project directory
for ets_pkg_name in ets_package_names.split():
print "Running command %r in package %s" % (' '.join(cmd), ets_pkg_name)
try:
subprocess.check_call(cmd, cwd=ets_pkg_name + '/docs/')
print
except (OSError, subprocess.CalledProcessError), detail:
print " Error running command in package %s:\n %s" % (ets_pkg_name, detail)
raw_input(" Press enter to process remaining packages.")
if __name__ == "__main__":
main()