mirror of
				https://github.com/fmtlib/fmt.git
				synced 2025-11-04 08:01:40 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
#!/usr/bin/env python
 | 
						|
# Build the documentation in CI.
 | 
						|
 | 
						|
from __future__ import print_function
 | 
						|
import errno, os, shutil, subprocess, sys, urllib
 | 
						|
from subprocess import call, check_call, Popen, PIPE, STDOUT
 | 
						|
 | 
						|
def rmtree_if_exists(dir):
 | 
						|
    try:
 | 
						|
        shutil.rmtree(dir)
 | 
						|
    except OSError as e:
 | 
						|
        if e.errno == errno.ENOENT:
 | 
						|
            pass
 | 
						|
 | 
						|
def install_dependencies():
 | 
						|
    branch = os.environ['GITHUB_REF']
 | 
						|
    if branch != 'refs/heads/master':
 | 
						|
        print('Branch: ' + branch)
 | 
						|
        exit(0) # Ignore non-master branches
 | 
						|
    check_call('curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key ' +
 | 
						|
               '| sudo apt-key add -', shell=True)
 | 
						|
    check_call('echo "deb https://deb.nodesource.com/node_0.10 precise main" ' +
 | 
						|
               '| sudo tee /etc/apt/sources.list.d/nodesource.list', shell=True)
 | 
						|
    check_call(['sudo', 'apt-get', 'update'])
 | 
						|
    check_call(['sudo', 'apt-get', 'install', 'python-virtualenv'])
 | 
						|
    deb_file = 'doxygen_1.8.6-2_amd64.deb'
 | 
						|
    urllib.urlretrieve('http://mirrors.kernel.org/ubuntu/pool/main/d/doxygen/' +
 | 
						|
                       deb_file, deb_file)
 | 
						|
    check_call(['sudo', 'dpkg', '-i', deb_file])
 | 
						|
 | 
						|
fmt_dir = os.path.dirname(os.path.dirname(os.path.realpath(__file__)))
 | 
						|
 | 
						|
is_ci = 'CI' in os.environ
 | 
						|
if is_ci:
 | 
						|
    install_dependencies()
 | 
						|
sys.path.insert(0, os.path.join(fmt_dir, 'doc'))
 | 
						|
import build
 | 
						|
build.create_build_env()
 | 
						|
html_dir = build.build_docs()
 | 
						|
repo = 'fmtlib.github.io'
 | 
						|
if is_ci and 'KEY' not in os.environ:
 | 
						|
    # Don't update the repo if building in CI from an account that doesn't have
 | 
						|
    # push access.
 | 
						|
    print('Skipping update of ' + repo)
 | 
						|
    exit(0)
 | 
						|
# Clone the fmtlib.github.io repo.
 | 
						|
rmtree_if_exists(repo)
 | 
						|
git_url = 'https://github.com/' if is_ci else 'git@github.com:'
 | 
						|
check_call(['git', 'clone', git_url + 'fmtlib/{}.git'.format(repo)])
 | 
						|
# Copy docs to the repo.
 | 
						|
target_dir = os.path.join(repo, 'dev')
 | 
						|
rmtree_if_exists(target_dir)
 | 
						|
shutil.copytree(html_dir, target_dir, ignore=shutil.ignore_patterns('.*'))
 | 
						|
if is_ci:
 | 
						|
    check_call(['git', 'config', '--global', 'user.name', 'fmtbot'])
 | 
						|
    check_call(['git', 'config', '--global', 'user.email', 'viz@fmt.dev'])
 | 
						|
# Push docs to GitHub pages.
 | 
						|
check_call(['git', 'add', '--all'], cwd=repo)
 | 
						|
if call(['git', 'diff-index', '--quiet', 'HEAD'], cwd=repo):
 | 
						|
    check_call(['git', 'commit', '-m', 'Update documentation'], cwd=repo)
 | 
						|
    cmd = 'git push'
 | 
						|
    if is_ci:
 | 
						|
        cmd += ' https://$KEY@github.com/fmtlib/fmtlib.github.io.git master'
 | 
						|
    p = Popen(cmd, shell=True, stdout=PIPE, stderr=STDOUT, cwd=repo)
 | 
						|
    # Print the output without the key.
 | 
						|
    print(p.communicate()[0].replace(os.environ['KEY'], '$KEY'))
 | 
						|
    if p.returncode != 0:
 | 
						|
        raise subprocess.CalledProcessError(p.returncode, cmd)
 |