Commit 930f687d authored by scoder's avatar scoder

Merge pull request #220 from nnemkin/elide_empty_slots

Do not generate tables for completely empty slot suites.
parents 44188cf6 51e1f2cb
...@@ -418,21 +418,30 @@ class SuiteSlot(SlotDescriptor): ...@@ -418,21 +418,30 @@ class SuiteSlot(SlotDescriptor):
self.slot_type = slot_type self.slot_type = slot_type
substructures.append(self) substructures.append(self)
def is_empty(self, scope):
for slot in self.sub_slots:
if slot.slot_code(scope) != "0":
return False
return True
def substructure_cname(self, scope): def substructure_cname(self, scope):
return "%s%s_%s" % (Naming.pyrex_prefix, self.slot_name, scope.class_name) return "%s%s_%s" % (Naming.pyrex_prefix, self.slot_name, scope.class_name)
def slot_code(self, scope): def slot_code(self, scope):
return "&%s" % self.substructure_cname(scope) if not self.is_empty(scope):
return "&%s" % self.substructure_cname(scope)
return "0"
def generate_substructure(self, scope, code): def generate_substructure(self, scope, code):
code.putln("") if not self.is_empty(scope):
code.putln( code.putln("")
"static %s %s = {" % ( code.putln(
self.slot_type, "static %s %s = {" % (
self.substructure_cname(scope))) self.slot_type,
for slot in self.sub_slots: self.substructure_cname(scope)))
slot.generate(scope, code) for slot in self.sub_slots:
code.putln("};") slot.generate(scope, code)
code.putln("};")
substructures = [] # List of all SuiteSlot instances substructures = [] # List of all SuiteSlot instances
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment