| 12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- #!/usr/bin/env python3
- """Compile source on a range of commits
- Usage:
- check-commits <start> <source>
- """
- import docopt, os, sys, tempfile
- from subprocess import check_call, check_output, run
- args = docopt.docopt(__doc__)
- start = args.get('<start>')
- source = args.get('<source>')
- cwd = os.getcwd()
- with tempfile.TemporaryDirectory() as work_dir:
- check_call(['git', 'clone', 'https://github.com/fmtlib/fmt.git'],
- cwd=work_dir)
- repo_dir = os.path.join(work_dir, 'fmt')
- commits = check_output(
- ['git', 'rev-list', f'{start}..HEAD', '--abbrev-commit',
- '--', 'include', 'src'],
- text=True, cwd=repo_dir).rstrip().split('\n')
- commits.reverse()
- print('Time\tCommit')
- for commit in commits:
- check_call(['git', '-c', 'advice.detachedHead=false', 'checkout', commit],
- cwd=repo_dir)
- returncode = run(
- ['c++', '-std=c++11', '-O3', '-DNDEBUG', '-I', 'include',
- 'src/format.cc', os.path.join(cwd, source)], cwd=repo_dir).returncode
- if returncode != 0:
- continue
- times = []
- for i in range(5):
- output = check_output([os.path.join(repo_dir, 'a.out')], text=True)
- times.append(float(output))
- message = check_output(['git', 'log', '-1', '--pretty=format:%s', commit],
- cwd=repo_dir, text=True)
- print(f'{min(times)}\t{commit} {message[:40]}')
- sys.stdout.flush()
|