2020-12-19 17:48:22 +00:00
|
|
|
#!/usr/bin/env python3
|
2022-12-12 02:58:02 +00:00
|
|
|
# pylint: disable=C0103,C0114,C0115,C0116,C0209,C0301
|
2007-03-05 13:52:21 +00:00
|
|
|
######################################################################
|
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
import argparse
|
|
|
|
import re
|
2007-03-05 13:52:21 +00:00
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
######################################################################
|
2007-03-05 13:52:21 +00:00
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
Header = []
|
|
|
|
Vertexes = []
|
|
|
|
Edges = []
|
2007-03-05 13:52:21 +00:00
|
|
|
|
|
|
|
#######################################################################
|
|
|
|
|
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
def dotread(filename):
|
2022-12-12 02:58:02 +00:00
|
|
|
with open(filename, "r", encoding="utf8") as fh:
|
2020-12-19 17:48:22 +00:00
|
|
|
header = True
|
|
|
|
vnum = 0
|
|
|
|
|
|
|
|
vertex_re = re.compile(r'^\t([a-zA-Z0-9_]+)\t(.*)$')
|
2024-08-27 01:43:34 +00:00
|
|
|
edge_re = re.compile(r'^\t([a-zA-Z0-9_]+)\s+->\s+([a-zA-Z0-9_]+)\s*(.*)$')
|
2020-12-19 17:48:22 +00:00
|
|
|
|
|
|
|
for line in fh:
|
|
|
|
vertex_match = re.search(vertex_re, line)
|
|
|
|
edge_match = re.search(edge_re, line)
|
|
|
|
if vertex_match:
|
|
|
|
if vertex_match.group(1) != 'nTITLE':
|
|
|
|
header = False
|
2024-08-27 01:43:34 +00:00
|
|
|
Vertexes.append({'num': vnum, 'line': line, 'name': vertex_match.group(1)})
|
2020-12-19 17:48:22 +00:00
|
|
|
vnum += 1
|
|
|
|
elif edge_match:
|
|
|
|
fromv = edge_match.group(1)
|
|
|
|
tov = edge_match.group(2)
|
|
|
|
w = re.match(r'weight=(\d+)', line)
|
|
|
|
weight = w.group(1) if w else 1
|
|
|
|
w = re.match(r'style=(\S+)', line)
|
|
|
|
cutable = w.group(1) if w else None
|
|
|
|
edge = {
|
|
|
|
'num': vnum,
|
|
|
|
'line': line,
|
|
|
|
'weight': weight,
|
|
|
|
'cutable': cutable,
|
|
|
|
'from': fromv,
|
|
|
|
'to': tov
|
|
|
|
}
|
|
|
|
vnum += 1
|
|
|
|
Edges.append(edge)
|
|
|
|
elif header:
|
|
|
|
Header.append(line)
|
|
|
|
print("IGNORE: " + line)
|
2007-03-05 13:52:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
#######################################################################
|
|
|
|
|
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
def cwrite(filename):
|
2022-12-12 02:58:02 +00:00
|
|
|
with open(filename, "w", encoding="utf8") as fh:
|
2020-12-19 17:48:22 +00:00
|
|
|
fh.write("void V3GraphTestImport::dotImport() {\n")
|
|
|
|
fh.write(" auto* gp = &m_graph;\n")
|
|
|
|
for ver in sorted(Vertexes, key=lambda ver: ver['num']):
|
2024-08-27 01:43:34 +00:00
|
|
|
fh.write(" auto* %s = new V3GraphTestVertex{gp, \"%s\"}; if (%s) {}\n" %
|
|
|
|
(ver['name'], ver['name'], ver['name']))
|
2020-12-19 17:48:22 +00:00
|
|
|
fh.write("\n")
|
|
|
|
for edge in Edges:
|
2024-08-27 01:43:34 +00:00
|
|
|
fh.write(
|
|
|
|
" new V3GraphEdge{gp, %s, %s, %s, %s};\n" %
|
|
|
|
(edge['from'], edge['to'], edge['weight'], "true" if edge['cutable'] else "false"))
|
2020-12-19 17:48:22 +00:00
|
|
|
fh.write("}\n")
|
2007-03-05 13:52:21 +00:00
|
|
|
|
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
######################################################################
|
|
|
|
# main
|
2007-03-05 13:52:21 +00:00
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
parser = argparse.ArgumentParser(
|
|
|
|
allow_abbrev=False,
|
|
|
|
formatter_class=argparse.RawDescriptionHelpFormatter,
|
2024-08-27 01:43:34 +00:00
|
|
|
description="""dot_importer takes a graphvis .dot file and converts into .cpp file.
|
2020-12-19 17:48:22 +00:00
|
|
|
This x.cpp file is then manually included in V3GraphTest.cpp to verify
|
|
|
|
various xsub-algorithms.""",
|
2024-08-27 01:43:34 +00:00
|
|
|
epilog="""Copyright 2005-2024 by Wilson Snyder. This program is free software; you
|
2020-03-21 15:24:24 +00:00
|
|
|
can redistribute it and/or modify it under the terms of either the GNU
|
|
|
|
Lesser General Public License Version 3 or the Perl Artistic License
|
|
|
|
Version 2.0.
|
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0""")
|
2007-03-05 13:52:21 +00:00
|
|
|
|
2024-08-27 01:43:34 +00:00
|
|
|
parser.add_argument('--debug', action='store_const', const=9, help='enable debug')
|
2020-12-19 17:48:22 +00:00
|
|
|
parser.add_argument('filename', help='input .dot filename to process')
|
2007-03-05 13:52:21 +00:00
|
|
|
|
2020-12-19 17:48:22 +00:00
|
|
|
Args = parser.parse_args()
|
|
|
|
dotread(Args.filename)
|
|
|
|
cwrite("graph_export.cpp")
|
2007-03-05 13:52:21 +00:00
|
|
|
|
|
|
|
######################################################################
|
2021-03-06 02:59:00 +00:00
|
|
|
# Local Variables:
|
|
|
|
# compile-command: "./dot_importer ../test_regress/obj_vlt/t_EXAMPLE/*orderg_o*.dot && cat graph_export.cpp"
|
|
|
|
# End:
|