From f15c30935d35ef204157ddc80c39e271d7815f22 Mon Sep 17 00:00:00 2001 From: Costa Shulyupin Date: Thu, 26 Jul 2018 08:34:40 +0300 Subject: [PATCH] +most_used, + starts, *digraph_print --- srcxray.py | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/srcxray.py b/srcxray.py index 4d0d1df..8d08337 100755 --- a/srcxray.py +++ b/srcxray.py @@ -362,9 +362,22 @@ def syscalls(): # srcxray.py 'write_dot(syscalls(), "syscalls.dot")' -def digraph_print(dg): + +def most_used(dg, ins=10, outs=10): + # return {a: b for a, b in sorted(dg.in_degree, key=lambda k: k[1]) if b > 1 and} + return [(x, dg.in_degree(x), dg.out_degree(x)) for x in dg.nodes() + if dg.in_degree(x) > ins and dg.out_degree(x) > outs] + + +def starts(dg): # roots + return {n: dg.out_degree(n) for (n, d) in dg.in_degree if not d} + + +def digraph_print(dg, starts=None, sort=False): def digraph_print_sub(node=None, printed=None, level=0): - outs = [_ for _ in dg.successors(node)] + outs = {_: dg.out_degree(_) for _ in dg.successors(node)} + if sort: + outs = {a: b for a, b in sorted(outs.items(), key=lambda k: k[1], reverse=True)} if node in printed: print_limited(level*'\t' + str(node) + ' ^') return