-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhotspot_compiler.py
55 lines (43 loc) · 1.85 KB
/
hotspot_compiler.py
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
44
45
46
47
48
49
50
51
52
53
54
55
from weights_normaliser import normalise_weights
def create_hotspots(commits, loc):
"""
Creates the hotspots.
:param commits: a dict of file names and the number of commits
:param lines_of_code: a dict of file names and the number of lines of code
:return: a sorted list of tuple (name, changes, lines)
"""
# Remove any files with no lines of code before normalisation
remove_files_with_no_code(commits, loc)
# Normalise the data into weights
weights = normalise_weights(commits)
# Compile hotspots
return merge_raw_data(weights, loc)
def remove_files_with_no_code(commits, lines_of_code):
"""
Removes files that either have no lines of code or no longer exist but are
historically present in the commits list.
:param commits: a dict of file names and the number of commits
:param lines_of_code: a dict of file names and the number of lines of code
"""
for k in list(commits.keys()):
if k not in lines_of_code or lines_of_code[k] == 0:
del commits[k]
def merge_raw_data(commits, lines_of_code):
"""
Creates a list of the files sorted primarily by the number of changes
and secondly by the number of lines of code.
:param commits: a dict of file names and the number of commits
:param lines_of_code: a dict of file names and the number of lines of code
:return: a sorted list of tuple (name, changes, lines)
"""
data = []
for k, v in commits.items():
# File may not exist anymore but is still in log
# Skip these files
if k in lines_of_code:
data.append((k, v, lines_of_code[k]))
# Sort on secondary key
data = sorted(data, key=lambda x: x[2], reverse=True)
# Sort on primary key as this gives sorted by first value then by
# second value
return sorted(data, key=lambda x: x[1], reverse=True)