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 2012年10月14日 09:17 by fgracia, last changed 2022年04月11日 14:57 by admin. This issue is now closed.
| Files | ||||
|---|---|---|---|---|
| File name | Uploaded | Description | Edit | |
| issue16226.patch | roger.serwy, 2012年10月15日 01:25 | review | ||
| issue16226_test.patch | ned.deily, 2012年10月19日 01:31 | review | ||
| Messages (8) | |||
|---|---|---|---|
| msg172863 - (view) | Author: Francisco Gracia (fgracia) | Date: 2012年10月14日 09:17 | |
The menu option *File / Path browser* (as well in the *Shell* window as in the *Editor* one) shows a new window with a tree structure rooted at *sys.path*. The available leaf nodes show the *plus* sign that usually implies that they can be expanded by clicking on the desired one. On the performance of this action IDLE disappears immediately. If one clicks just on the legend of the node, IDLE remains undisturbed but nothing more happens. Idle's help says: *File Menu: ... Path Browser -- Show sys.path directories, modules, classes and methods* so that apparently the expansion should also work. I suppose that this command would be mostly used at the initial phases of learning Python (at least I would have done it if I had noticed then its existence and function), but its present status does not favor such didactic purpose. Regards |
|||
| msg172893 - (view) | Author: Ned Deily (ned.deily) * (Python committer) | Date: 2012年10月14日 17:18 | |
Thank you for the report. There does seem to be a regression in the 3.3 version of IDLE. Using the OS X version of bin/idle3.3 and selecting menu item File -> Path Browser results in the following exception: Exception in Tkinter callback Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/tkinter/__init__.py", line 1442, in __call__ return self.func(*args) File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 131, in expand self.update() File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 164, in update self.parent.update() File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 170, in update self.draw(7, 2) File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 197, in draw cy = child.draw(cx, cy) File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 184, in draw sublist = self.item._GetSubList() File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/TreeWidget.py", line 338, in _GetSubList sublist = self.GetSubList() File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/PathBrowser.py", line 61, in GetSubList for nn, name in self.listmodules(names): File "/Library/Frameworks/Python.framework/Versions/3.3/lib/python3.3/idlelib/PathBrowser.py", line 78, in listmodules for suff, mode, flag in suffixes: ValueError: too many values to unpack (expected 3) |
|||
| msg172936 - (view) | Author: Roger Serwy (roger.serwy) * (Python committer) | Date: 2012年10月15日 01:25 | |
Here's the revision that broke it: b81ddaf0db47 The 2.7 branch still uses imp.get_suffixes, whereas the 3.3 and 3.4 uses this importlib construct. The imp.get_suffixes returns a list of tuples of 3 items: (suffix, mode, type). The current code only returns what would be the first item of that tuple. The for-loop only uses that first item anyway, so the tuple unpacking can be removed safely. The attached patch fixes the issue. It also includes a basic unit test within the idlelib/test directory. We need to get the unittest framework started for IDLE, as given in issue15392. |
|||
| msg173302 - (view) | Author: Roundup Robot (python-dev) (Python triager) | Date: 2012年10月19日 01:19 | |
New changeset d369e50677a6 by Ned Deily in branch '3.3': Issue #16226: Fix IDLE Path Browser crash. http://hg.python.org/cpython/rev/d369e50677a6 New changeset 58f9523cf407 by Ned Deily in branch 'default': Issue #16226: Fix IDLE Path Browser crash. http://hg.python.org/cpython/rev/58f9523cf407 |
|||
| msg173303 - (view) | Author: Ned Deily (ned.deily) * (Python committer) | Date: 2012年10月19日 01:31 | |
I've committed Roger's fix for release in 3.3.1 and 3.4.0. Thanks, Roger. I did not apply the proposed test since, as it stands, it would never be run by test.regrtest without establishing a idlelib test runner infrastructure as proposed by Issue15392. I'm attaching the test as a separate patch and will add a comment to 15392 that the test should be added. |
|||
| msg190382 - (view) | Author: Terry J. Reedy (terry.reedy) * (Python committer) | Date: 2013年05月30日 21:08 | |
Test has been committed on all three branches as part of #15392 |
|||
| msg212341 - (view) | Author: Saimadhav Heblikar (Saimadhav.Heblikar) * | Date: 2014年02月27日 09:15 | |
This patch does 1.Remove pep8 violations in PathBrowser.py . Replaces "file","dir","sorted" by "file_","dir_","sorted_" respectively. 2.Extends test coverage for PathBrowser.py in idle_test/test_PathBrowser.py New modules now under tests include 1.dirBrowserTreeItem - getText,ispackagedir 2.pathBrowserTreeItem - getText,getSublist Only method missing a test after this patch will be listmodules.I am not too sure whether it requires a test for itself.it is indirectly being tested from lines 8 and 9(in the current tip). |
|||
| msg212362 - (view) | Author: Terry J. Reedy (terry.reedy) * (Python committer) | Date: 2014年02月27日 16:05 | |
S.H. moved his patch for new tests to new issue #20792. |
|||
| History | |||
|---|---|---|---|
| Date | User | Action | Args |
| 2022年04月11日 14:57:37 | admin | set | github: 60430 |
| 2014年02月27日 16:05:40 | terry.reedy | set | messages: + msg212362 |
| 2014年02月27日 09:27:51 | Saimadhav.Heblikar | set | files: - pathbrowser1.patch |
| 2014年02月27日 09:15:34 | Saimadhav.Heblikar | set | files:
+ pathbrowser1.patch nosy: + Saimadhav.Heblikar messages: + msg212341 |
| 2013年05月30日 21:08:44 | terry.reedy | set | nosy:
+ terry.reedy messages: + msg190382 |
| 2012年10月19日 01:31:04 | ned.deily | set | status: open -> closed files: + issue16226_test.patch messages: + msg173303 resolution: fixed stage: needs patch -> resolved |
| 2012年10月19日 01:19:55 | python-dev | set | nosy:
+ python-dev messages: + msg173302 |
| 2012年10月15日 01:25:38 | roger.serwy | set | files:
+ issue16226.patch nosy: + roger.serwy messages: + msg172936 keywords: + patch |
| 2012年10月14日 17:18:13 | ned.deily | set | priority: normal -> high versions: + Python 3.4 keywords: + 3.3regression nosy: + ned.deily messages: + msg172893 stage: needs patch |
| 2012年10月14日 09:17:59 | fgracia | create | |