-
Notifications
You must be signed in to change notification settings - Fork 2
/
build.py
executable file
·133 lines (99 loc) · 3.5 KB
/
build.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
#!/usr/bin/env python3
"""
Builds the notebook and checks out the relevant files into gh-pages
"""
import logging
import os
import shutil
import subprocess
import click
try:
import ruamel.yaml as yaml
except ImportError:
import yaml
def load_config(config):
with open(config, 'r') as yf:
conf_dict = yaml.safe_load(yf)
return conf_dict
def get_current_git_ref():
# Gets the current branch_name for HEAD (or HEAD)
branch_name = subprocess.check_output(
['git', 'rev-parse', '--symbolic-full-name', '--verify',
'--abbrev-ref', 'HEAD'])
branch_name = branch_name.decode().strip()
if branch_name == 'HEAD':
# Instead use the current commit if we're in detached head mode
branch_name = subprocess.check_output(
['git', 'rev-parse', '--verify', 'HEAD']
).decode.strip()
return branch_name
def make_slides(config, serve=False):
reveal_prefix = config.get('reveal_prefix', 'reveal.js')
convert_cmd = [
'jupyter', 'nbconvert',
'--to=slides',
'--reveal-prefix={}'.format(reveal_prefix)
]
template_path = config.get('template', None)
if template_path is not None:
convert_cmd.append('--template={}'.format(template_path))
if serve:
convert_cmd.extend(['--post', 'serve'])
convert_cmd.append(config.get('notebook', 'notebook.ipynb'))
return subprocess.check_call(convert_cmd)
@click.group()
def cli():
pass
@cli.command()
@click.option('-c', '--config', type=click.Path(exists=True),
default='build_config.yml')
@click.option('--serve', is_flag=True, default=False,
help='Whether or not to serve the notebook after the build.')
def make(config, serve):
"""
Used to build the notebook in the local folder (on the local branch).
"""
conf = load_config(config)
make_slides(conf, serve=serve)
@cli.command()
@click.option('-c', '--config', type=click.Path(exists=True),
default='build_config.yml')
def pages(config):
"""
Used to generate the slides and copy the current branch's version of the
slides to the gh-pages branch.
"""
logging.getLogger().setLevel(logging.INFO)
conf = load_config(config)
try:
slides_loc = conf['slides']
except KeyError:
raise KeyError('Must specify slides output location in config')
# Build the slides
make_slides(conf)
if not os.path.exists(slides_loc):
raise ValueError('Could not find {}'.format(slides_loc))
cur_git_ref = get_current_git_ref() # So we can check stuff out from here
logging.info('Checking out gh-pages, leaving {}'.format(cur_git_ref))
# Check out the gh-pages branch
subprocess.check_call(['git', 'checkout', 'gh-pages'])
# Move the slides to index.html to update them
logging.info('Moving slides from {} to index.html'.format(slides_loc))
shutil.move('index.html', 'index.html.bak')
try:
shutil.move(slides_loc, 'index.html')
# Update the remaining files
logging.info('Checking out specified data from {}'.format(cur_git_ref))
subprocess.check_call(
['git', 'checkout', cur_git_ref] +
conf.get('files', []) + # Standalone files
conf.get('dirs', []) # Directories
)
except:
shutil.move('index.html.bak', 'index.html')
raise
finally:
if os.path.exists('index.html.bak'):
os.remove('index.html.bak')
if __name__ == "__main__":
cli()