-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparse.py
54 lines (45 loc) · 1.83 KB
/
parse.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
import os
import csv
import fnmatch
import shutil
from comment_parser import comment_parser
import git
from git import Repo
git_repository_url = "https://github.com/r0ket/r0ket.git" # URL of git repository
MIME = "text/x-c" # MIME type
# extensions of the files to be considered during parsing
extensions = [".c", ".h"]
L = list()
C = list()
i = 0
print "Cloning repository..."
Repo.clone_from(git_repository_url, "repository_root")
print "Repository cloning ended"
print "Comment parsing started..."
# recursively find files starting from root folder
for root, dirs, files in os.walk("repository_root"):
for filename in files:
if filename.lower().endswith(tuple(extensions)): # filter for given file extention
L.append(os.path.join(root, filename))
# parse comments according to hardcoded MIME
c = (comment_parser.extract_comments(L[i], MIME))
# store comment in list
C.append(c)
i += 1
print "Comment parsing ended"
with open("patterns.txt") as f: # patterns to be matched
keywords = [line.strip() for line in f]
print "Pattern matching started..."
with open('output_parsing.tsv', 'w') as csvfile:
writer = csv.writer(csvfile, delimiter='\t')
writer.writerow(["File name", "Keyword", "Comment"]) # write header
for x in range(len(L)): # for each file
for y in range(len(C[x])): # for each comment
for z in range(len(keywords)):
s = str(C[x][y])
# match lower case for case insensivity
if keywords[z].lower() in s.lower():
# store file name, keyword and comment
writer.writerow([L[x], keywords[z], str(C[x][y])])
print "Pattern matching ended"
shutil.rmtree("repository_root") # remove local copy of cloned repository