2015-10-14 09:27:42 -05:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
2024-04-08 22:33:50 -05:00
|
|
|
from __future__ import annotations
|
2015-10-14 09:27:42 -05:00
|
|
|
import fileinput
|
|
|
|
import json
|
2024-04-11 20:57:51 -05:00
|
|
|
from pathlib import Path
|
2015-10-14 09:27:42 -05:00
|
|
|
|
2024-04-08 22:33:50 -05:00
|
|
|
class SimHelper:
|
|
|
|
name: str = ""
|
2024-04-10 18:15:24 -05:00
|
|
|
title: str = ""
|
2024-04-08 22:33:50 -05:00
|
|
|
ports: str = ""
|
2024-04-11 20:57:51 -05:00
|
|
|
source: str = ""
|
2024-04-08 22:33:50 -05:00
|
|
|
desc: list[str]
|
|
|
|
code: list[str]
|
|
|
|
ver: str = "1"
|
2015-10-14 09:27:42 -05:00
|
|
|
|
2024-04-08 22:33:50 -05:00
|
|
|
def __init__(self) -> None:
|
|
|
|
self.desc = []
|
|
|
|
|
|
|
|
def __str__(self) -> str:
|
2024-04-11 20:57:51 -05:00
|
|
|
printed_fields = [
|
|
|
|
"name", "title", "ports", "source", "desc", "code", "ver",
|
|
|
|
]
|
|
|
|
# generate C++ struct
|
2024-04-08 22:33:50 -05:00
|
|
|
val = "tempCell = {\n"
|
2024-04-11 20:57:51 -05:00
|
|
|
for field in printed_fields:
|
|
|
|
field_val = getattr(self, field)
|
|
|
|
if isinstance(field_val, list):
|
|
|
|
field_val = "\n".join(field_val)
|
|
|
|
val += f' {json.dumps(field_val)},\n'
|
2024-04-08 22:33:50 -05:00
|
|
|
val += "};\n"
|
2024-04-11 20:57:51 -05:00
|
|
|
|
|
|
|
# map name to struct
|
2024-04-08 22:33:50 -05:00
|
|
|
val += f'cell_help[{json.dumps(self.name)}] = tempCell;'
|
|
|
|
val += "\n"
|
|
|
|
val += f'cell_code[{json.dumps(self.name + "+")}] = tempCell;'
|
|
|
|
return val
|
|
|
|
|
2024-04-11 22:48:47 -05:00
|
|
|
def simcells_reparse(cell: SimHelper):
|
|
|
|
# cut manual signature
|
|
|
|
cell.desc = cell.desc[3:]
|
|
|
|
|
|
|
|
# code-block truth table
|
|
|
|
new_desc = []
|
|
|
|
indent = ""
|
|
|
|
for line in cell.desc:
|
|
|
|
if line.startswith("Truth table:"):
|
|
|
|
indent = " "
|
|
|
|
new_desc.pop()
|
|
|
|
new_desc.extend(["::", ""])
|
|
|
|
new_desc.append(indent + line)
|
|
|
|
cell.desc = new_desc
|
|
|
|
|
|
|
|
# set version
|
|
|
|
cell.ver = "2a"
|
|
|
|
|
2024-04-08 22:33:50 -05:00
|
|
|
simHelper = SimHelper()
|
2015-10-14 09:27:42 -05:00
|
|
|
|
|
|
|
for line in fileinput.input():
|
2024-04-08 22:33:50 -05:00
|
|
|
line = line.rstrip()
|
|
|
|
# special comments
|
2015-10-14 09:27:42 -05:00
|
|
|
if line.startswith("//-"):
|
2024-04-08 22:33:50 -05:00
|
|
|
simHelper.desc.append(line[4:] if len(line) > 4 else "")
|
|
|
|
elif line.startswith("//* "):
|
|
|
|
_, key, val = line.split(maxsplit=2)
|
|
|
|
setattr(simHelper, key, val)
|
|
|
|
|
|
|
|
# code parsing
|
2015-10-14 09:27:42 -05:00
|
|
|
if line.startswith("module "):
|
2024-04-08 22:33:50 -05:00
|
|
|
clean_line = line[7:].replace("\\", "").replace(";", "")
|
|
|
|
simHelper.name, simHelper.ports = clean_line.split(maxsplit=1)
|
|
|
|
simHelper.code = []
|
2024-04-11 20:57:51 -05:00
|
|
|
short_filename = Path(fileinput.filename()).name
|
|
|
|
simHelper.source = f'{short_filename}:{fileinput.filelineno()}'
|
2015-10-16 19:22:42 -05:00
|
|
|
elif not line.startswith("endmodule"):
|
|
|
|
line = " " + line
|
2024-04-08 22:33:50 -05:00
|
|
|
try:
|
|
|
|
simHelper.code.append(line.replace("\t", " "))
|
|
|
|
except AttributeError:
|
|
|
|
# no module definition, ignore line
|
|
|
|
pass
|
2015-10-14 09:27:42 -05:00
|
|
|
if line.startswith("endmodule"):
|
2024-04-11 22:48:47 -05:00
|
|
|
short_filename = Path(fileinput.filename()).name
|
|
|
|
if simHelper.ver == "1" and short_filename == "simcells.v":
|
|
|
|
# default simcells parsing
|
|
|
|
simcells_reparse(simHelper)
|
2024-04-08 23:12:41 -05:00
|
|
|
if not simHelper.desc:
|
2024-04-11 22:48:47 -05:00
|
|
|
# no help
|
2024-04-08 23:12:41 -05:00
|
|
|
simHelper.desc.append("No help message for this cell type found.\n")
|
2024-04-08 22:33:50 -05:00
|
|
|
print(simHelper)
|
|
|
|
simHelper = SimHelper()
|
2015-10-14 09:27:42 -05:00
|
|
|
|