mirror of
https://github.com/m-labs/artiq.git
synced 2025-01-26 18:38:13 +08:00
compiler: refactor to use builtins.TInt{32,64}. (NFC)
This commit is contained in:
parent
143bae4bd3
commit
4888e897b9
@ -122,10 +122,10 @@ class ASTSynthesizer:
|
||||
else:
|
||||
instance_type = types.TInstance("{}.{}".format(typ.__module__, typ.__qualname__),
|
||||
OrderedDict())
|
||||
instance_type.attributes['__objectid__'] = builtins.TInt(types.TValue(32))
|
||||
instance_type.attributes['__objectid__'] = builtins.TInt32()
|
||||
|
||||
constructor_type = types.TConstructor(instance_type)
|
||||
constructor_type.attributes['__objectid__'] = builtins.TInt(types.TValue(32))
|
||||
constructor_type.attributes['__objectid__'] = builtins.TInt32()
|
||||
instance_type.constructor = constructor_type
|
||||
|
||||
self.type_map[typ] = instance_type, constructor_type
|
||||
|
@ -80,7 +80,7 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
the called function inside a translated :class:`ast.CallT` node
|
||||
"""
|
||||
|
||||
_size_type = builtins.TInt(types.TValue(32))
|
||||
_size_type = builtins.TInt32()
|
||||
|
||||
def __init__(self, module_name, engine, ref_period):
|
||||
self.engine = engine
|
||||
@ -542,8 +542,8 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
loc = self.current_loc
|
||||
|
||||
loc_file = ir.Constant(loc.source_buffer.name, builtins.TStr())
|
||||
loc_line = ir.Constant(loc.line(), builtins.TInt(types.TValue(32)))
|
||||
loc_column = ir.Constant(loc.column(), builtins.TInt(types.TValue(32)))
|
||||
loc_line = ir.Constant(loc.line(), builtins.TInt32())
|
||||
loc_column = ir.Constant(loc.column(), builtins.TInt32())
|
||||
loc_function = ir.Constant(".".join(self.name), builtins.TStr())
|
||||
|
||||
self.append(ir.SetAttr(exn, "__file__", loc_file))
|
||||
@ -1397,8 +1397,8 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
attributes = [
|
||||
ir.Constant(typ.find().name, ir.TExceptionTypeInfo()), # typeinfo
|
||||
ir.Constant("<not thrown>", builtins.TStr()), # file
|
||||
ir.Constant(0, builtins.TInt(types.TValue(32))), # line
|
||||
ir.Constant(0, builtins.TInt(types.TValue(32))), # column
|
||||
ir.Constant(0, builtins.TInt32()), # line
|
||||
ir.Constant(0, builtins.TInt32()), # column
|
||||
ir.Constant("<not thrown>", builtins.TStr()), # function
|
||||
]
|
||||
|
||||
@ -1407,10 +1407,10 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
else:
|
||||
attributes.append(message) # message
|
||||
|
||||
param_type = builtins.TInt(types.TValue(64))
|
||||
param_type = builtins.TInt64()
|
||||
for param in [param0, param1, param2]:
|
||||
if param is None:
|
||||
attributes.append(ir.Constant(0, builtins.TInt(types.TValue(64))))
|
||||
attributes.append(ir.Constant(0, builtins.TInt64()))
|
||||
else:
|
||||
if param.type != param_type:
|
||||
param = self.append(ir.Coerce(param, param_type))
|
||||
@ -1450,7 +1450,7 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
assert False
|
||||
elif types.is_builtin(typ, "list"):
|
||||
if len(node.args) == 0 and len(node.keywords) == 0:
|
||||
length = ir.Constant(0, builtins.TInt(types.TValue(32)))
|
||||
length = ir.Constant(0, builtins.TInt32())
|
||||
return self.append(ir.Alloc([length], node.type))
|
||||
elif len(node.args) == 1 and len(node.keywords) == 0:
|
||||
arg = self.visit(node.args[0])
|
||||
@ -1515,7 +1515,7 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
return ir.Constant(None, builtins.TNone())
|
||||
elif types.is_builtin(typ, "now"):
|
||||
if len(node.args) == 0 and len(node.keywords) == 0:
|
||||
now_mu = self.append(ir.Builtin("now_mu", [], builtins.TInt(types.TValue(64))))
|
||||
now_mu = self.append(ir.Builtin("now_mu", [], builtins.TInt64()))
|
||||
now_mu_float = self.append(ir.Coerce(now_mu, builtins.TFloat()))
|
||||
return self.append(ir.Arith(ast.Mult(loc=None), now_mu_float, self.ref_period))
|
||||
else:
|
||||
@ -1524,7 +1524,7 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
if len(node.args) == 1 and len(node.keywords) == 0:
|
||||
arg = self.visit(node.args[0])
|
||||
arg_mu_float = self.append(ir.Arith(ast.Div(loc=None), arg, self.ref_period))
|
||||
arg_mu = self.append(ir.Coerce(arg_mu_float, builtins.TInt(types.TValue(64))))
|
||||
arg_mu = self.append(ir.Coerce(arg_mu_float, builtins.TInt64()))
|
||||
return self.append(ir.Builtin(typ.name + "_mu", [arg_mu], builtins.TNone()))
|
||||
else:
|
||||
assert False
|
||||
@ -1543,7 +1543,7 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||
if len(node.args) == 1 and len(node.keywords) == 0:
|
||||
arg = self.visit(node.args[0])
|
||||
arg_mu = self.append(ir.Arith(ast.Div(loc=None), arg, self.ref_period))
|
||||
return self.append(ir.Coerce(arg_mu, builtins.TInt(types.TValue(64))))
|
||||
return self.append(ir.Coerce(arg_mu, builtins.TInt64()))
|
||||
else:
|
||||
assert False
|
||||
elif types.is_exn_constructor(typ):
|
||||
|
@ -540,7 +540,7 @@ class Inferencer(algorithm.Visitor):
|
||||
self._unify(message.type, builtins.TStr(),
|
||||
message.loc, None)
|
||||
for param in params:
|
||||
self._unify(param.type, builtins.TInt(types.TValue(64)),
|
||||
self._unify(param.type, builtins.TInt64(),
|
||||
param.loc, None)
|
||||
else:
|
||||
diagnose(valid_forms())
|
||||
@ -690,7 +690,7 @@ class Inferencer(algorithm.Visitor):
|
||||
node.loc, None)
|
||||
elif builtins.is_list(arg.type):
|
||||
# TODO: should be ssize_t-sized
|
||||
self._unify(node.type, builtins.TInt(types.TValue(32)),
|
||||
self._unify(node.type, builtins.TInt32(),
|
||||
node.loc, None)
|
||||
elif types.is_var(arg.type):
|
||||
pass # undetermined yet
|
||||
@ -744,19 +744,19 @@ class Inferencer(algorithm.Visitor):
|
||||
[builtins.TFloat()])
|
||||
elif types.is_builtin(typ, "now_mu"):
|
||||
simple_form("now_mu() -> int(width=64)",
|
||||
[], builtins.TInt(types.TValue(64)))
|
||||
[], builtins.TInt64())
|
||||
elif types.is_builtin(typ, "delay_mu"):
|
||||
simple_form("delay_mu(time_mu:int(width=64)) -> None",
|
||||
[builtins.TInt(types.TValue(64))])
|
||||
[builtins.TInt64()])
|
||||
elif types.is_builtin(typ, "at_mu"):
|
||||
simple_form("at_mu(time_mu:int(width=64)) -> None",
|
||||
[builtins.TInt(types.TValue(64))])
|
||||
[builtins.TInt64()])
|
||||
elif types.is_builtin(typ, "mu_to_seconds"):
|
||||
simple_form("mu_to_seconds(time_mu:int(width=64)) -> float",
|
||||
[builtins.TInt(types.TValue(64))], builtins.TFloat())
|
||||
[builtins.TInt64()], builtins.TFloat())
|
||||
elif types.is_builtin(typ, "seconds_to_mu"):
|
||||
simple_form("seconds_to_mu(time:float) -> int(width=64)",
|
||||
[builtins.TFloat()], builtins.TInt(types.TValue(64)))
|
||||
[builtins.TFloat()], builtins.TInt64())
|
||||
elif types.is_constructor(typ):
|
||||
# An user-defined class.
|
||||
self._unify(node.type, typ.find().instance,
|
||||
|
Loading…
Reference in New Issue
Block a user