reverted support for cdef functions in __test__ dict: increases module size and init...
authorStefan Behnel <scoder@users.berlios.de>
Tue, 2 Nov 2010 11:42:31 +0000 (12:42 +0100)
committerStefan Behnel <scoder@users.berlios.de>
Tue, 2 Nov 2010 11:42:31 +0000 (12:42 +0100)
Cython/Compiler/AnalysedTreeTransforms.py
tests/run/autotestdict.pyx

index bb2996fd2e04c9d3d0dbc26acab2f16eca36c1ea..69667abf6589c1bdb08f12de15ab245fe33942b3 100644 (file)
@@ -59,15 +59,16 @@ class AutoTestDictTransform(ScopeTrackingTransform):
     def visit_FuncDefNode(self, node):
         if not node.doc:
             return node
+        if isinstance(node, CFuncDefNode) and not node.py_func:
+            # skip non-cpdef cdef functions
+            return node
+
         pos = self.testspos
         if self.scope_type == 'module':
             path = node.entry.name
         elif self.scope_type in ('pyclass', 'cclass'):
             if isinstance(node, CFuncDefNode):
-                if node.py_func is not None:
-                    name = node.py_func.name
-                else:
-                    name = node.entry.name
+                name = node.py_func.name
             else:
                 name = node.name
             if self.scope_type == 'cclass' and name in self.blacklist:
index eb3744eddff73090513a70bd986315f2f787f242..0e3bc09ee285a703ec3560218c35efec97d4ae89 100644 (file)
@@ -12,25 +12,28 @@ all_tests_run() is executed which does final validation.
 >>> items.sort()
 >>> for key, value in items:
 ...     print('%s ; %s' % (key, value))
-MyCdefClass.cdef_method (line 79) ; >>> add_log("cdef class method")
-MyCdefClass.cpdef_method (line 76) ; >>> add_log("cpdef class method")
-MyCdefClass.method (line 73) ; >>> add_log("cdef class method")
-MyClass.method (line 62) ; >>> add_log("class method")
-cdeffunc (line 28) ; >>> add_log("cdef")
-doc_without_test (line 44) ; Some docs
-mycpdeffunc (line 50) ; >>> add_log("cpdef")
-myfunc (line 41) ; >>> add_log("def")
+MyCdefClass.cpdef_method (line 79) ; >>> add_log("cpdef class method")
+MyCdefClass.method (line 76) ; >>> add_log("cdef class method")
+MyClass.method (line 65) ; >>> add_log("class method")
+doc_without_test (line 47) ; Some docs
+mycpdeffunc (line 53) ; >>> add_log("cpdef")
+myfunc (line 44) ; >>> add_log("def")
 
 """
 
 log = []
 
 cdef cdeffunc():
-    """>>> add_log("cdef")"""
+    """
+    Please don't include me!
+
+    >>> True
+    False
+    """
 
 def all_tests_run():
     log.sort()
-    assert log == [u'cdef', u'cdef class', u'cdef class method', u'class method', u'cpdef', u'cpdef class method', u'def'], log
+    assert log == [u'cdef class', u'cdef class method', u'class method', u'cpdef', u'cpdef class method', u'def'], log
 
 def add_log(s):
     log.append(unicode(s))
@@ -76,9 +79,6 @@ cdef class MyCdefClass:
     cpdef cpdef_method(self):
         """>>> add_log("cpdef class method")"""
 
-    cdef cdef_method(self):
-        """>>> add_log("cdef class method")"""
-
     def __cinit__(self):
         """
         Should not be included, as it can't be looked up with getattr