aboutsummaryrefslogtreecommitdiff
path: root/thirdparty/fmt/support/check-commits
blob: 11472d41f49901b749740617e34c7fd24b9727e6 (plain) (blame)
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
#!/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()