1
0
mirror of https://github.com/myhdl/myhdl.git synced 2024-12-14 07:44:38 +08:00

toVerilog is now a callable instance

This commit is contained in:
jand 2005-09-09 09:15:07 +00:00
parent 60d6cc0142
commit fba110a473
2 changed files with 65 additions and 49 deletions

View File

@ -138,9 +138,11 @@ def _analyzeGens(top, genNames):
else:
f = g.gi_frame
s = inspect.getsource(f)
#print s
s = s.lstrip()
#print s
ast = compiler.parse(s)
# print ast
#print ast
ast.sourcefile = inspect.getsourcefile(f)
ast.lineoffset = inspect.getsourcelines(f)[1]-1
ast.symdict = f.f_globals.copy()

View File

@ -38,7 +38,7 @@ import warnings
import myhdl
from myhdl import *
from myhdl import ToVerilogError, ToVerilogWarning
from myhdl._extractHierarchy import _HierExtr, _findInstanceName, _isMem, _getMemInfo
from myhdl._extractHierarchy import _HierExtr, _isMem, _getMemInfo
from myhdl._util import _flatten
from myhdl._always_comb import _AlwaysComb
from myhdl._toVerilog import _error, _access, _kind,_context, \
@ -54,7 +54,15 @@ def _checkArgs(arglist):
if not type(arg) in (GeneratorType, _AlwaysComb):
raise ToVerilogError(_error.ArgType, arg)
def toVerilog(func, *args, **kwargs):
class _ToVerilogConvertor(object):
__slots__ = ("name")
def __init__(self):
self.name = None
def __call__(self, func, *args, **kwargs):
global _converting
if _converting:
return func(*args, **kwargs) # skip
@ -68,12 +76,15 @@ def toVerilog(func, *args, **kwargs):
raise ToVerilogError(_error.FirstArgType, "got %s" % type(func))
_converting = 1
if self.name is None:
name = func.func_name
else:
name = str(self.name)
try:
# outer = inspect.getouterframes(inspect.currentframe())[1]
# name = _findInstanceName(outer)
name = func.func_name
if name is None:
raise ToVerilogError(_error.TopLevelName)
## if name is None:
## raise ToVerilogError(_error.TopLevelName)
h = _HierExtr(name, func, *args, **kwargs)
finally:
_converting = 0
@ -106,6 +117,9 @@ def toVerilog(func, *args, **kwargs):
return h.top
toVerilog = _ToVerilogConvertor()
def _writeModuleHeader(f, intf):
print >> f, "module %s (" % intf.name
b = StringIO()