-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdrawing.py
56 lines (43 loc) · 2.13 KB
/
drawing.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
56
"""
This script contains all methods that do the drawing part
"""
import os
import re
def writeOnCluster(rovFile, objects, line):
"This function write objects to their cluster on ROV.dot file"
rovFile.write(line)
for object in objects[:-1]:
rovFile.write(object+",")
rovFile.write(objects[-1]+";"+"\n")
def draw_relation(rovFile, object, to, noDuplicate):
"This function draw an arrow between two objects"
if not (to in noDuplicate[object]) and (to != object) :
rovFile.write(object+" -> "+to+";\n")
noDuplicate[object].append(to)
def draw_inheritance_relation(rovFile, object, to):
rovFile.write(object+" -> "+to+";\n")
def draw_wrong_relation(rovFile, object, to, noDuplicate, num, message):
"This function draw the wrong relation between two objects"
print "\n WARNING:"
print "\n",object, "is a Controller object, and in line", num, "it called", to, message
if not (to in noDuplicate[object]):
# draw the wrong relation with a dot line.
rovFile.write(object+" -> "+to+"[style=dotted];\n")
noDuplicate[object].append(to)
def check_relations(filename, extLen, noDuplicate, rovFile, objects, current_list, path):
"This function check relations between clusters"
noDuplicate[filename[:-extLen]] = []
with open(os.path.join(path, filename),'r') as f:
scan(rovFile, f, filename[:-extLen], objects, current_list, noDuplicate)
def scan(rovFile, file, filename, objects, cluster_objects, noDuplicate):
# This pattern check inheritance relations between objects in the same cluster
inheritance_pattern = re.compile(filename+": \\b(?=(" + "|".join(map(re.escape, cluster_objects)) + ")\\b {)")
for num, line in enumerate(file, 1):
for object in objects:
# No warning message
if objects[object] == "" :
for match in re.finditer(object, line):
draw_relation(rovFile, filename, match.group(1), noDuplicate)
else:
for match in re.finditer(object, line):
draw_wrong_relation(rovFile, filename, match.group(1), noDuplicate, num, objects[object])