mirror of
https://github.com/bertptrs/adventofcode.git
synced 2025-12-25 21:00:31 +01:00
68 lines
1.4 KiB
Python
Executable File
68 lines
1.4 KiB
Python
Executable File
#!/usr/bin/env python3
|
|
'''
|
|
Plotter for the length of my solutions, by day.
|
|
|
|
This excludes common code.
|
|
'''
|
|
import argparse
|
|
import csv
|
|
import io
|
|
import re
|
|
import subprocess
|
|
import matplotlib.pyplot as plt
|
|
|
|
|
|
def get_args():
|
|
parser = argparse.ArgumentParser()
|
|
parser.add_argument('source', help='Source directory', nargs='?',
|
|
default='src')
|
|
parser.add_argument('-o', '--output', help='Output for the plot')
|
|
|
|
return parser.parse_args()
|
|
|
|
|
|
def cloc_usage(src_dir):
|
|
result = subprocess.run(['cloc', '--by-file', '--csv', '--quiet', src_dir],
|
|
check=True, capture_output=True)
|
|
|
|
output = result.stdout.decode('utf-8')
|
|
data = io.StringIO(output, newline='')
|
|
|
|
reader = csv.reader(data, dialect='unix')
|
|
values = []
|
|
|
|
for line in reader:
|
|
if not line:
|
|
continue
|
|
|
|
match = re.search(r"\d+", line[1])
|
|
if match:
|
|
day = int(match.group(0))
|
|
values.append([day] + [int(x) for x in line[2:]])
|
|
|
|
values.sort()
|
|
values = tuple(zip(*values))
|
|
|
|
return values[0], values[1:]
|
|
|
|
|
|
def main():
|
|
args = get_args()
|
|
days, values = cloc_usage(args.source)
|
|
|
|
for sequence in values:
|
|
plt.plot(days, sequence)
|
|
|
|
plt.xlabel('Day')
|
|
plt.ylabel('Lines of code')
|
|
plt.legend(['Blank', 'Comment', 'Code'])
|
|
|
|
if args.output:
|
|
plt.savefig(args.output)
|
|
else:
|
|
plt.show()
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|