Closed
Description
The following code is silently accepted by Argument Clinic:
/*[clinic input]
module m
module m
[clinic start generated code]*/
The duplicate module m
should have been caught by Argument Clinic, but the guard is faulty:
cpython/Tools/clinic/clinic.py
Lines 4481 to 4482 in 9e6590b
The check should be against .modules
, not .classes
:
diff --git a/Tools/clinic/clinic.py b/Tools/clinic/clinic.py
index 1bcdb6b1c3..dc4a7f9318 100755
--- a/Tools/clinic/clinic.py
+++ b/Tools/clinic/clinic.py
@@ -4478,7 +4478,7 @@ def directive_module(self, name: str) -> None:
if cls:
fail("Can't nest a module inside a class!")
- if name in module.classes:
+ if name in module.modules:
fail("Already defined module " + repr(name) + "!")
m = Module(name, module)
See also the Module
class:
cpython/Tools/clinic/clinic.py
Lines 2384 to 2392 in 9e6590b