This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Code objects from same line can compare equal
Type: behavior Stage:
Components: Interpreter Core Versions: Python 3.6, Python 3.2, Python 3.3, Python 3.4, Python 3.5, Python 2.7
process
Status: closed Resolution: duplicate
Dependencies: Superseder:
Assigned To: Nosy List: KirkMcDonald
Priority: normal Keywords:

Created on 2015-12-16 04:07 by KirkMcDonald, last changed 2022-04-11 14:58 by admin. This issue is now closed.

Messages (2)
msg256508 - (view) Author: Kirk McDonald (KirkMcDonald) Date: 2015-12-16 04:07
The following code gives an unexpected result:

>>> a, b = lambda: 1, lambda: 1.0
>>> a()
1
>>> b()
1
>>> type(b())
<class 'int'>
>>> a.__code__ is b.__code__
True

The cause boils down to this line of code:

https://hg.python.org/cpython/file/33ff335da34c/Objects/codeobject.c#l442

When it compiles the two lambdas, their code objects compare equal. They have the same name, the same bytecode, and start on the same line. And, because 1 == 1.0, their constants compare equal. This then prompts the compiler to combine the two code objects into a single constant in the enclosing code object, discarding the second one.

I think the solution is to have code_richcompare also check whether the types of the constants are equal, in addition to the constants themselves.
msg256509 - (view) Author: Kirk McDonald (KirkMcDonald) Date: 2015-12-16 04:17
This is a duplicate of http://bugs.python.org/issue25843
History
Date User Action Args
2022-04-11 14:58:25adminsetgithub: 70067
2015-12-16 04:17:28KirkMcDonaldsetstatus: open -> closed
resolution: duplicate
messages: + msg256509
2015-12-16 04:10:04KirkMcDonaldsettype: behavior
components: + Interpreter Core
versions: + Python 2.7, Python 3.2, Python 3.3, Python 3.4, Python 3.5, Python 3.6
2015-12-16 04:07:47KirkMcDonaldcreate