File: check-commits

package info (click to toggle)
fmtlib 11.1.1%2Bds1-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 1,772 kB
  • sloc: cpp: 22,591; ansic: 758; python: 504; sh: 53; makefile: 16; javascript: 4
file content (43 lines) | stat: -rwxr-xr-x 1,389 bytes parent folder | download | duplicates (9)
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()