back.pysim: optionally allow introspecting generated code.
This commit is contained in:
parent
5ae87916ec
commit
377f2d987d
|
@ -1,5 +1,7 @@
|
|||
import inspect
|
||||
import os
|
||||
import tempfile
|
||||
import warnings
|
||||
import inspect
|
||||
from contextlib import contextmanager
|
||||
import itertools
|
||||
from vcd import VCDWriter
|
||||
|
@ -761,8 +763,19 @@ class _FragmentCompiler:
|
|||
signal_index = domain_process.context.get_signal(signal)
|
||||
emitter.append(f"slots[{signal_index}].set(next_{signal_index})")
|
||||
|
||||
# There shouldn't be any exceptions raised by the generated code, but if there are
|
||||
# (almost certainly due to a bug in the code generator), use this environment variable
|
||||
# to make backtraces useful.
|
||||
code = emitter.flush()
|
||||
if os.getenv("NMIGEN_pysim_dump"):
|
||||
file = tempfile.NamedTemporaryFile("w", prefix="nmigen_pysim_", delete=False)
|
||||
file.write(code)
|
||||
filename = file.name
|
||||
else:
|
||||
filename = "<string>"
|
||||
|
||||
exec_locals = {"slots": domain_process.context.slots, **_ValueCompiler.helpers}
|
||||
exec(emitter.flush(), exec_locals)
|
||||
exec(compile(code, filename, "exec"), exec_locals)
|
||||
domain_process.run = exec_locals["run"]
|
||||
|
||||
processes.add(domain_process)
|
||||
|
|
Loading…
Reference in a new issue