]> granicus.if.org Git - clang/commitdiff
ABITest: Fix a bug in generating test values for structures w/ no
authorDaniel Dunbar <daniel@zuster.org>
Fri, 8 May 2009 22:48:39 +0000 (22:48 +0000)
committerDaniel Dunbar <daniel@zuster.org>
Fri, 8 May 2009 22:48:39 +0000 (22:48 +0000)
non-padding fields.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71273 91177308-0d34-0410-b5e6-96231b3b80d8

utils/ABITest/ABITestGen.py

index afe58e58d0ff341e423f2c2fd46674d86a7423cf..539cc28fffc1cdf3485059af466f8e9f98a9afba 100755 (executable)
@@ -199,31 +199,27 @@ class TypePrinter:
                 yield '(%s) -1'%(t.name,)
                 yield '(%s) 1'%(t.name,)
         elif isinstance(t, RecordType):
-            if not t.fields:
+            nonPadding = [f for f in t.fields 
+                          if not f.isPaddingBitField()]
+
+            if not nonPadding:
                 yield '{ }'
                 return
+
             # FIXME: Use designated initializers to access non-first
             # fields of unions.
             if t.isUnion:
-                firstNonPadding = None
-                for t in t.fields:
-                    if not t.isPaddingBitField():
-                        firstNonPadding = t
-                        break
-                if firstNonPadding:
-                    for v in self.getTestValues(firstNonPadding):
-                        yield '{ %s }' % v
-                else:
-                    yield '{ }'
+                for v in self.getTestValues(nonPadding[0]):
+                    yield '{ %s }' % v
                 return
-            fieldValues = [list(self.getTestValues(f)) 
-                           for f in t.fields
-                           if not f.isPaddingBitField()]
+
+            fieldValues = map(list, map(self.getTestValues, nonPadding))
             for i,values in enumerate(fieldValues):
                 for v in values:
                     elements = map(random.choice,fieldValues)
                     elements[i] = v
                     yield '{ %s }'%(', '.join(elements))
+
         elif isinstance(t, ComplexType):
             for t in self.getTestValues(t.elementType):
                 yield '%s + %s * 1i'%(t,t)