From ac92aabce19b48f1a812d5c2e9d3d87fe4e12f4b Mon Sep 17 00:00:00 2001 From: whitequark Date: Fri, 28 Aug 2015 02:50:40 -0500 Subject: [PATCH] Fix default argument fiasco. --- artiq/compiler/embedding.py | 3 ++- artiq/compiler/types.py | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/artiq/compiler/embedding.py b/artiq/compiler/embedding.py index 1476dce4a..0b903dbe0 100644 --- a/artiq/compiler/embedding.py +++ b/artiq/compiler/embedding.py @@ -105,7 +105,8 @@ class ASTSynthesizer: if typ in self.type_map: instance_type, constructor_type = self.type_map[typ] else: - instance_type = types.TInstance("{}.{}".format(typ.__module__, typ.__qualname__)) + instance_type = types.TInstance("{}.{}".format(typ.__module__, typ.__qualname__), + OrderedDict()) instance_type.attributes['__objectid__'] = builtins.TInt(types.TValue(32)) constructor_type = types.TConstructor(instance_type) diff --git a/artiq/compiler/types.py b/artiq/compiler/types.py index 32501d961..73d53db52 100644 --- a/artiq/compiler/types.py +++ b/artiq/compiler/types.py @@ -359,7 +359,8 @@ class TInstance(TMono): was created """ - def __init__(self, name, attributes=OrderedDict()): + def __init__(self, name, attributes): + assert isinstance(attributes, OrderedDict) super().__init__(name) self.attributes = attributes