-
Notifications
You must be signed in to change notification settings - Fork 2
/
parser.py
65 lines (57 loc) · 1.25 KB
/
parser.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
57
58
59
60
61
62
63
64
65
from itertools import islice
import networkx as nx
tag = "ANDROID_NODE"
def check_item(item):
if "Landroid/" in item or "Lcom/android" in item:
return True
else:
return False
def prova(l):
global g, tag
chiamante = None
#top stacktrace
print 'aggiungo solo ' + l[0]
chiamante = l[0]
if check_item(chiamante):
g.add_node(tag)
else:
g.add_node(chiamante)
_ = l.pop(0)
for item in l:
print 'aggiungo nodo' + chiamante + ' chiamato da: ' + item
if check_item(chiamante):
if check_item(item):
#android call android
continue
else:
g.add_edge(item,tag)
else:
if check_item(item):
g.add_edge(tag,chiamante)
else:
g.add_edge(item,chiamante)
#g.add_edge(item,chiamante)
chiamante = item
#add(item,n)
def strace_reader():
global g
g = nx.DiGraph()
#prima riga e il numero di chiamate = n
#le successive n righe sono le chiamate, poi si ripete
with open("/tmp/stacktraces.log") as myfile:
while True:
#leggo la len
try:
num = next(myfile)
except:
print 'fine'
break
print num
#salvo le successive l righe in un array di l elementi
lista = list(islice(myfile, int(num)))
#aggiungo i nodi
print lista
prova(lista)
strace_reader()
print(g.nodes())
nx.write_gexf(g,"trace.gexf")