blob: 1b833ff893248351621680cf23c61e91efcbaa0c [file] [log] [blame]
serge-sans-paille6c40e9c2020-07-15 09:31:13 +02001#!/usr/bin/env python
Patrick Meredithd629d5f2005-10-13 16:26:50 +00002
Tobias Hieta3c762872023-05-15 11:02:42 +02003# changelog:
4# 10/13/2005b: replaced the # in tmp(.#*)* with alphanumeric and _, this will then remove
5# nodes such as %tmp.1.i and %tmp._i.3
6# 10/13/2005: exntended to remove variables of the form %tmp(.#)* rather than just
Patrick Meredithd629d5f2005-10-13 16:26:50 +00007#%tmp.#, i.e. it now will remove %tmp.12.3.15 etc, additionally fixed a spelling error in
Tobias Hieta3c762872023-05-15 11:02:42 +02008# the comments
9# 10/12/2005: now it only removes nodes and edges for which the label is %tmp.# rather
10# than removing all lines for which the lable CONTAINS %tmp.#
Serge Gueltonbf2f82e2019-01-03 14:11:33 +000011
12from __future__ import print_function
13
Patrick Meredithd629d5f2005-10-13 16:26:50 +000014import re
15import sys
Tobias Hieta3c762872023-05-15 11:02:42 +020016
17if len(sys.argv) < 3:
18 print("usage is: ./DSAclean <dot_file_to_be_cleaned> <out_put_file>")
19 sys.exit(1)
20# get a file object
21input = open(sys.argv[1], "r")
22output = open(sys.argv[2], "w")
23# we'll get this one line at a time...while we could just put the whole thing in a string
24# it would kill old computers
Patrick Meredithd629d5f2005-10-13 16:26:50 +000025buffer = input.readline()
Tobias Hieta3c762872023-05-15 11:02:42 +020026while buffer != "":
27 if re.compile('label(\s*)=(\s*)"\s%tmp(.\w*)*(\s*)"').search(buffer):
28 # skip next line, write neither this line nor the next
29 buffer = input.readline()
30 else:
31 # this isn't a tmp Node, we can write it
32 output.write(buffer)
33 # prepare for the next iteration
34 buffer = input.readline()
Patrick Meredithd629d5f2005-10-13 16:26:50 +000035input.close()
36output.close()