forked from mixxxdj/manual
-
Notifications
You must be signed in to change notification settings - Fork 0
/
fabfile.py
85 lines (71 loc) · 2.35 KB
/
fabfile.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
from fabric.api import *
import fabric.contrib.project as project
import os
from source import conf
PROD = 'direct.mixxx.org:2022'
# Format the path using the version in the Sphinx config.
DEST_PATH = '/home/mixxx/public_html/manual/%s' % conf.version
ROOT_PATH = os.path.abspath(os.path.dirname(__file__))
env.user = 'mixxx'
HTML_DEPLOY_PATH = os.path.join(ROOT_PATH, 'build/html')
PDF_DEPLOY_PATH = os.path.join(ROOT_PATH, 'build/latex/Mixxx-Manual.pdf')
env.sphinx_tags = []
def make_command(language):
tags = ' '.join('-t %s' % tag for tag in env.sphinx_tags)
return 'make -e SPHINXOPTS="-D language=\'%s\' %s"' % (language, tags)
@task
def release():
env.sphinx_tags.append('release')
@task
def clean():
local('make clean')
@task
def i18n_update_source_translations():
# Builds .pot files containing translation text from all manual pages.
local('make gettext')
# Updates Transifex configuration to include new chapters / source files.
local('sphinx-intl update-txconfig-resources --pot-dir source/locale/pot '
'--transifex-project-name mixxxdj-manual --locale-dir source/locale')
@task
def tx_push():
# Pushes latest .pot files to Transifex.
local('tx push -s')
@task
def tx_pull():
# Pulls latest .po translation files for all languages from Transifex.
local('tx pull -a -f')
@task
def i18n_build():
# Re-build .mo files.
local('sphinx-intl build')
@task
def regen():
clean()
html()
@task
def html(language='en'):
local('%s html' % make_command(language))
@task
def pdf(language='en'):
local('%s latex' % make_command(language))
# The manual PDF build typically throws tons of errors. We should fix them
# but for now we ignore so the build server job isn't always marked as
# failed when a mostly-working PDF is generated.
with settings(warn_only=True):
with lcd('build/latex'):
# You need to run pdflatex twice to get the TOC and references
# right.
local('pdflatex -interaction=nonstopmode Mixxx-Manual.tex')
local('pdflatex -interaction=nonstopmode Mixxx-Manual.tex')
@task
@hosts(PROD)
def publish():
regen()
pdf()
put(local_path=PDF_DEPLOY_PATH,
remote_path=DEST_PATH)
project.rsync_project(
remote_dir=DEST_PATH,
local_dir=HTML_DEPLOY_PATH.rstrip('/') + '/',
delete=True
)