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.
Created on 2016年06月10日 09:37 by martin.panter, last changed 2022年04月11日 14:58 by admin. This issue is now closed.
| Files | ||||
|---|---|---|---|---|
| File name | Uploaded | Description | Edit | |
| BUILD_MAP_UNPACK_WITH_CALL-function_pos.patch | serhiy.storchaka, 2016年06月10日 13:15 | review | ||
| BUILD_MAP_UNPACK_WITH_CALL-function_pos2.patch | serhiy.storchaka, 2016年06月10日 16:59 | review | ||
| Pull Requests | |||
|---|---|---|---|
| URL | Status | Linked | Edit |
| PR 169 | merged | ncoghlan, 2017年02月19日 07:24 | |
| Messages (13) | |||
|---|---|---|---|
| msg268110 - (view) | Author: Martin Panter (martin.panter) * (Python committer) | Date: 2016年06月10日 09:37 | |
Playing with the generalized unpacking (PEP 448), I found a funny error message, when duplicate dictionary unpackings are included and also duplicate a literal keyword argument: >>> print(end=".\n", **dict(end="dupe")) # No problem TypeError: print() got multiple values for keyword argument 'end' >>> print(**dict(end=".\n"), **dict(end="dupe")) # No problem TypeError: print() got multiple values for keyword argument 'end' >>> print(end=".\n", **dict(end="dupe"), **dict(end="dupe 2")) # str object?! TypeError: str object got multiple values for keyword argument 'end' |
|||
| msg268121 - (view) | Author: Serhiy Storchaka (serhiy.storchaka) * (Python committer) | Date: 2016年06月10日 13:15 | |
Here is a fix. |
|||
| msg268123 - (view) | Author: Raymond Hettinger (rhettinger) * (Python committer) | Date: 2016年06月10日 15:46 | |
This patch looks correct. |
|||
| msg268128 - (view) | Author: Serhiy Storchaka (serhiy.storchaka) * (Python committer) | Date: 2016年06月10日 16:59 | |
Since currently generated bytecode is not correct, I think we should update the magic number for forcing the regenerating pyc-files. |
|||
| msg268336 - (view) | Author: Roundup Robot (python-dev) (Python triager) | Date: 2016年06月12日 06:49 | |
New changeset 34d24c51eab6 by Serhiy Storchaka in branch '3.5': Issue #27286: Fixed compiling BUILD_MAP_UNPACK_WITH_CALL opcode. Calling https://hg.python.org/cpython/rev/34d24c51eab6 New changeset 194549801bd5 by Serhiy Storchaka in branch 'default': Issue #27286: Fixed compiling BUILD_MAP_UNPACK_WITH_CALL opcode. Calling https://hg.python.org/cpython/rev/194549801bd5 |
|||
| msg272360 - (view) | Author: John Ehresman (jpe) * | Date: 2016年08月10日 19:10 | |
Should the bytecode magic number be bumped in the 3.5 branch? This breaks .pyc / .pyo binary compatibility for python 3.5. As far as I can tell this has never been done before in a release after the major.minor.0 final release. This patch has made its way into debian's python 3.5 and I've gotten a bug report because of it for an app distributed without python source. Looking at the 3.5.2 tarball, it does not look like the change was included in 3.5.2. If the magic number is bumped in 3.5, the comment should be changed to reflect that it changes in 3.5.3 and not in 3.5.2 |
|||
| msg272368 - (view) | Author: Serhiy Storchaka (serhiy.storchaka) * (Python committer) | Date: 2016年08月10日 19:46 | |
Bytecode generated by 3.5.1 is not correct (wrong error message can be not the only effect). The only way to resolve this issue is regenerating the bytecode. 3.5.2 was released two weeks after committing this patch. I expected it includes this change. |
|||
| msg278158 - (view) | Author: Łukasz Langa (lukasz.langa) * (Python committer) | Date: 2016年10月05日 23:29 | |
The magic number change in a minor release was a mistake. Let's not do that with 3.6.x releases. Since Python doesn't check if there's a corresponding .py file that can be used to rebuild the .pyc file, we shouldn't reject existing .pyc files on the basis that they *might* be broken. |
|||
| msg282148 - (view) | Author: Shai Berger (shai) | Date: 2016年12月01日 08:54 | |
Following the last comment, and just as clarification for anyone else running into this and thinking like me: The bumped code is not included in v3.5.2, and v3.5.3 hasn't been released yet. Should it be undone? No, because the bump which was encountered by John Ehresman on Debian Testing has also made it into Ubuntu 16.04LTS. Undoing it, at this point, is liable to bring even worse breakage than the original change caused. http://changelogs.ubuntu.com/changelogs/pool/main/p/python3.5/python3.5_3.5.2-2ubuntu0~16.04.1/changelog |
|||
| msg287506 - (view) | Author: Mark Dickinson (mark.dickinson) * (Python committer) | Date: 2017年02月10日 10:44 | |
It's difficult to track down which versions of Python 3.5.x the bytecode change is in because the Misc/NEWS entry has vanished, apparently in this merge commit: https://github.com/python/cpython/commit/aa0f9d8f26bbe63adcbce950aaadc844d996e7ac |
|||
| msg287508 - (view) | Author: Larry Hastings (larry) * (Python committer) | Date: 2017年02月10日 10:45 | |
Sorry about that! It's almost like manually updating Misc/NEWS is a bad design :( |
|||
| msg287526 - (view) | Author: Martin Panter (martin.panter) * (Python committer) | Date: 2017年02月10日 12:41 | |
Diff showing what changed relative to the main 3.5 branch when merging in the 3.5.2 release: <https://hg.python.org/cpython/rev/31a2a278dc85:1f8938164809>. There are four news entries deleted from the 3.5.2rc1 section. Ideally they should have been moved to the 3.5.3rc1 section instead, because they were added after 3.5.2rc1 was branched, but before the 3.5.3rc1 heading appeared. Also, there were some minor corrections of mine and Victor’s that were undone. And I would suggest to restrict merge commits to changes that are already in at least one of the branches being merged. The edit to "byte-like" was not present in either of the branches being merged. In Git I think they call these changes "evil merges". |
|||
| msg290270 - (view) | Author: Alyssa Coghlan (ncoghlan) * (Python committer) | Date: 2017年03月24日 22:42 | |
New changeset 93602e3af70d3b9f98ae2da654b16b3382b68d50 by Nick Coghlan in branch '3.5': [3.5] bpo-29537: Tolerate legacy invalid bytecode (#169) https://github.com/python/cpython/commit/93602e3af70d3b9f98ae2da654b16b3382b68d50 |
|||
| History | |||
|---|---|---|---|
| Date | User | Action | Args |
| 2022年04月11日 14:58:32 | admin | set | github: 71473 |
| 2017年03月24日 22:42:19 | ncoghlan | set | nosy:
+ ncoghlan messages: + msg290270 |
| 2017年02月19日 07:24:46 | ncoghlan | set | pull_requests: + pull_request134 |
| 2017年02月13日 12:30:07 | ishcherb | set | nosy:
+ ishcherb |
| 2017年02月10日 12:41:27 | martin.panter | set | messages: + msg287526 |
| 2017年02月10日 10:45:51 | larry | set | messages: + msg287508 |
| 2017年02月10日 10:44:44 | mark.dickinson | set | nosy:
+ mark.dickinson messages: + msg287506 |
| 2016年12月01日 08:54:43 | shai | set | nosy:
+ shai messages: + msg282148 |
| 2016年10月05日 23:29:06 | lukasz.langa | set | nosy:
+ lukasz.langa messages: + msg278158 |
| 2016年08月10日 19:46:19 | serhiy.storchaka | set | nosy:
+ larry messages: + msg272368 |
| 2016年08月10日 19:10:39 | jpe | set | nosy:
+ jpe messages: + msg272360 |
| 2016年06月12日 07:41:31 | serhiy.storchaka | set | status: open -> closed assignee: serhiy.storchaka resolution: fixed stage: patch review -> resolved |
| 2016年06月12日 06:49:48 | python-dev | set | nosy:
+ python-dev messages: + msg268336 |
| 2016年06月10日 16:59:49 | serhiy.storchaka | set | files:
+ BUILD_MAP_UNPACK_WITH_CALL-function_pos2.patch messages: + msg268128 |
| 2016年06月10日 15:46:17 | rhettinger | set | nosy:
+ rhettinger messages: + msg268123 |
| 2016年06月10日 13:15:43 | serhiy.storchaka | set | files:
+ BUILD_MAP_UNPACK_WITH_CALL-function_pos.patch nosy: + serhiy.storchaka messages: + msg268121 keywords: + patch stage: patch review |
| 2016年06月10日 09:37:11 | martin.panter | create | |