golden hour
/usr/lib64/python2.7/idlelib
⬆️ Go Up
Upload
File/Folder
Size
Actions
AutoComplete.py
8.79 KB
Del
OK
AutoComplete.pyc
7.69 KB
Del
OK
AutoComplete.pyo
7.69 KB
Del
OK
AutoCompleteWindow.py
16.8 KB
Del
OK
AutoCompleteWindow.pyc
12.15 KB
Del
OK
AutoCompleteWindow.pyo
12.09 KB
Del
OK
AutoExpand.py
2.42 KB
Del
OK
AutoExpand.pyc
2.5 KB
Del
OK
AutoExpand.pyo
2.5 KB
Del
OK
Bindings.py
3.22 KB
Del
OK
Bindings.pyc
4.76 KB
Del
OK
Bindings.pyo
4.76 KB
Del
OK
CREDITS.txt
1.82 KB
Del
OK
CallTipWindow.py
5.98 KB
Del
OK
CallTipWindow.pyc
6.14 KB
Del
OK
CallTipWindow.pyo
6.14 KB
Del
OK
CallTips.py
7.75 KB
Del
OK
CallTips.pyc
10.14 KB
Del
OK
CallTips.pyo
10.14 KB
Del
OK
ChangeLog
55.07 KB
Del
OK
ClassBrowser.py
6.22 KB
Del
OK
ClassBrowser.pyc
8.95 KB
Del
OK
ClassBrowser.pyo
8.95 KB
Del
OK
CodeContext.py
8.15 KB
Del
OK
CodeContext.pyc
6.52 KB
Del
OK
CodeContext.pyo
6.47 KB
Del
OK
ColorDelegator.py
10.13 KB
Del
OK
ColorDelegator.pyc
8.71 KB
Del
OK
ColorDelegator.pyo
8.71 KB
Del
OK
Debugger.py
15.45 KB
Del
OK
Debugger.pyc
16.55 KB
Del
OK
Debugger.pyo
16.55 KB
Del
OK
Delegator.py
831 B
Del
OK
Delegator.pyc
1.58 KB
Del
OK
Delegator.pyo
1.58 KB
Del
OK
EditorWindow.py
63.29 KB
Del
OK
EditorWindow.pyc
55.13 KB
Del
OK
EditorWindow.pyo
55.03 KB
Del
OK
FileList.py
3.57 KB
Del
OK
FileList.pyc
3.86 KB
Del
OK
FileList.pyo
3.82 KB
Del
OK
FormatParagraph.py
5.66 KB
Del
OK
FormatParagraph.pyc
4.69 KB
Del
OK
FormatParagraph.pyo
4.69 KB
Del
OK
GrepDialog.py
3.96 KB
Del
OK
GrepDialog.pyc
4.9 KB
Del
OK
GrepDialog.pyo
4.9 KB
Del
OK
HISTORY.txt
10.08 KB
Del
OK
HyperParser.py
10.31 KB
Del
OK
HyperParser.pyc
6.49 KB
Del
OK
HyperParser.pyo
6.49 KB
Del
OK
IOBinding.py
20.69 KB
Del
OK
IOBinding.pyc
17.16 KB
Del
OK
IOBinding.pyo
17.16 KB
Del
OK
Icons
-
Del
OK
IdleHistory.py
3.07 KB
Del
OK
IdleHistory.pyc
3.13 KB
Del
OK
IdleHistory.pyo
3.13 KB
Del
OK
MultiCall.py
17.07 KB
Del
OK
MultiCall.pyc
15.55 KB
Del
OK
MultiCall.pyo
15.48 KB
Del
OK
MultiStatusBar.py
783 B
Del
OK
MultiStatusBar.pyc
1.49 KB
Del
OK
MultiStatusBar.pyo
1.49 KB
Del
OK
NEWS.txt
28.32 KB
Del
OK
ObjectBrowser.py
4.05 KB
Del
OK
ObjectBrowser.pyc
6.56 KB
Del
OK
ObjectBrowser.pyo
6.56 KB
Del
OK
OutputWindow.py
4.47 KB
Del
OK
OutputWindow.pyc
5.11 KB
Del
OK
OutputWindow.pyo
5.11 KB
Del
OK
ParenMatch.py
6.47 KB
Del
OK
ParenMatch.pyc
6.82 KB
Del
OK
ParenMatch.pyo
6.82 KB
Del
OK
PathBrowser.py
2.58 KB
Del
OK
PathBrowser.pyc
4.02 KB
Del
OK
PathBrowser.pyo
4.02 KB
Del
OK
Percolator.py
2.55 KB
Del
OK
Percolator.pyc
3.55 KB
Del
OK
Percolator.pyo
3.37 KB
Del
OK
PyParse.py
19.05 KB
Del
OK
PyParse.pyc
9.77 KB
Del
OK
PyParse.pyo
9.34 KB
Del
OK
PyShell.py
54.81 KB
Del
OK
PyShell.pyc
49.14 KB
Del
OK
PyShell.pyo
49.04 KB
Del
OK
README.txt
2.56 KB
Del
OK
RemoteDebugger.py
11.38 KB
Del
OK
RemoteDebugger.pyc
15.97 KB
Del
OK
RemoteDebugger.pyo
15.82 KB
Del
OK
RemoteObjectBrowser.py
942 B
Del
OK
RemoteObjectBrowser.pyc
2.1 KB
Del
OK
RemoteObjectBrowser.pyo
2.1 KB
Del
OK
ReplaceDialog.py
5.69 KB
Del
OK
ReplaceDialog.pyc
6.32 KB
Del
OK
ReplaceDialog.pyo
6.32 KB
Del
OK
RstripExtension.py
824 B
Del
OK
RstripExtension.pyc
1.45 KB
Del
OK
RstripExtension.pyo
1.45 KB
Del
OK
ScriptBinding.py
8.22 KB
Del
OK
ScriptBinding.pyc
7.96 KB
Del
OK
ScriptBinding.pyo
7.96 KB
Del
OK
ScrolledList.py
3.9 KB
Del
OK
ScrolledList.pyc
6.03 KB
Del
OK
ScrolledList.pyo
6.03 KB
Del
OK
SearchDialog.py
1.99 KB
Del
OK
SearchDialog.pyc
2.93 KB
Del
OK
SearchDialog.pyo
2.93 KB
Del
OK
SearchDialogBase.py
4.28 KB
Del
OK
SearchDialogBase.pyc
5.37 KB
Del
OK
SearchDialogBase.pyo
5.37 KB
Del
OK
SearchEngine.py
6.57 KB
Del
OK
SearchEngine.pyc
7.02 KB
Del
OK
SearchEngine.pyo
7.02 KB
Del
OK
StackViewer.py
3.77 KB
Del
OK
StackViewer.pyc
5.79 KB
Del
OK
StackViewer.pyo
5.79 KB
Del
OK
TODO.txt
8.28 KB
Del
OK
ToolTip.py
2.67 KB
Del
OK
ToolTip.pyc
4.05 KB
Del
OK
ToolTip.pyo
4.05 KB
Del
OK
TreeWidget.py
14.87 KB
Del
OK
TreeWidget.pyc
17.48 KB
Del
OK
TreeWidget.pyo
17.48 KB
Del
OK
UndoDelegator.py
10.04 KB
Del
OK
UndoDelegator.pyc
12.27 KB
Del
OK
UndoDelegator.pyo
12.27 KB
Del
OK
WidgetRedirector.py
4.37 KB
Del
OK
WidgetRedirector.pyc
5.23 KB
Del
OK
WidgetRedirector.pyo
5.23 KB
Del
OK
WindowList.py
2.42 KB
Del
OK
WindowList.pyc
3.55 KB
Del
OK
WindowList.pyo
3.55 KB
Del
OK
ZoomHeight.py
1.28 KB
Del
OK
ZoomHeight.pyc
1.61 KB
Del
OK
ZoomHeight.pyo
1.61 KB
Del
OK
__init__.py
37 B
Del
OK
__init__.pyc
127 B
Del
OK
__init__.pyo
127 B
Del
OK
aboutDialog.py
6.42 KB
Del
OK
aboutDialog.pyc
6.63 KB
Del
OK
aboutDialog.pyo
6.63 KB
Del
OK
config-extensions.def
2.72 KB
Del
OK
config-highlight.def
1.7 KB
Del
OK
config-keys.def
7.35 KB
Del
OK
config-main.def
2.45 KB
Del
OK
configDialog.py
52.23 KB
Del
OK
configDialog.pyc
43.81 KB
Del
OK
configDialog.pyo
43.81 KB
Del
OK
configHandler.py
28.68 KB
Del
OK
configHandler.pyc
26.83 KB
Del
OK
configHandler.pyo
26.83 KB
Del
OK
configHelpSourceEdit.py
6.52 KB
Del
OK
configHelpSourceEdit.pyc
6.56 KB
Del
OK
configHelpSourceEdit.pyo
6.56 KB
Del
OK
configSectionNameDialog.py
3.63 KB
Del
OK
configSectionNameDialog.pyc
4.21 KB
Del
OK
configSectionNameDialog.pyo
4.21 KB
Del
OK
dynOptionMenuWidget.py
1.27 KB
Del
OK
dynOptionMenuWidget.pyc
1.66 KB
Del
OK
dynOptionMenuWidget.pyo
1.66 KB
Del
OK
extend.txt
3.56 KB
Del
OK
help.txt
11.72 KB
Del
OK
idle.py
400 B
Del
OK
idle.pyc
406 B
Del
OK
idle.pyo
406 B
Del
OK
idle.pyw
664 B
Del
OK
idlever.py
23 B
Del
OK
idlever.pyc
159 B
Del
OK
idlever.pyo
159 B
Del
OK
keybindingDialog.py
12.12 KB
Del
OK
keybindingDialog.pyc
12.05 KB
Del
OK
keybindingDialog.pyo
12.05 KB
Del
OK
macosxSupport.py
6.08 KB
Del
OK
macosxSupport.pyc
6.25 KB
Del
OK
macosxSupport.pyo
6.25 KB
Del
OK
rpc.py
19.75 KB
Del
OK
rpc.pyc
21.26 KB
Del
OK
rpc.pyo
21.16 KB
Del
OK
run.py
11.54 KB
Del
OK
run.pyc
12.14 KB
Del
OK
run.pyo
12.08 KB
Del
OK
tabbedpages.py
17.76 KB
Del
OK
tabbedpages.pyc
17.67 KB
Del
OK
tabbedpages.pyo
17.67 KB
Del
OK
textView.py
3.46 KB
Del
OK
textView.pyc
4.2 KB
Del
OK
textView.pyo
4.2 KB
Del
OK
Edit: TreeWidget.py
# XXX TO DO: # - popup menu # - support partial or total redisplay # - key bindings (instead of quick-n-dirty bindings on Canvas): # - up/down arrow keys to move focus around # - ditto for page up/down, home/end # - left/right arrows to expand/collapse & move out/in # - more doc strings # - add icons for "file", "module", "class", "method"; better "python" icon # - callback for selection??? # - multiple-item selection # - tooltips # - redo geometry without magic numbers # - keep track of object ids to allow more careful cleaning # - optimize tree redraw after expand of subnode import os from Tkinter import * import imp from idlelib import ZoomHeight from idlelib.configHandler import idleConf ICONDIR = "Icons" # Look for Icons subdirectory in the same directory as this module try: _icondir = os.path.join(os.path.dirname(__file__), ICONDIR) except NameError: _icondir = ICONDIR if os.path.isdir(_icondir): ICONDIR = _icondir elif not os.path.isdir(ICONDIR): raise RuntimeError, "can't find icon directory (%r)" % (ICONDIR,) def listicons(icondir=ICONDIR): """Utility to display the available icons.""" root = Tk() import glob list = glob.glob(os.path.join(icondir, "*.gif")) list.sort() images = [] row = column = 0 for file in list: name = os.path.splitext(os.path.basename(file))[0] image = PhotoImage(file=file, master=root) images.append(image) label = Label(root, image=image, bd=1, relief="raised") label.grid(row=row, column=column) label = Label(root, text=name) label.grid(row=row+1, column=column) column = column + 1 if column >= 10: row = row+2 column = 0 root.images = images class TreeNode: def __init__(self, canvas, parent, item): self.canvas = canvas self.parent = parent self.item = item self.state = 'collapsed' self.selected = False self.children = [] self.x = self.y = None self.iconimages = {} # cache of PhotoImage instances for icons def destroy(self): for c in self.children[:]: self.children.remove(c) c.destroy() self.parent = None def geticonimage(self, name): try: return self.iconimages[name] except KeyError: pass file, ext = os.path.splitext(name) ext = ext or ".gif" fullname = os.path.join(ICONDIR, file + ext) image = PhotoImage(master=self.canvas, file=fullname) self.iconimages[name] = image return image def select(self, event=None): if self.selected: return self.deselectall() self.selected = True self.canvas.delete(self.image_id) self.drawicon() self.drawtext() def deselect(self, event=None): if not self.selected: return self.selected = False self.canvas.delete(self.image_id) self.drawicon() self.drawtext() def deselectall(self): if self.parent: self.parent.deselectall() else: self.deselecttree() def deselecttree(self): if self.selected: self.deselect() for child in self.children: child.deselecttree() def flip(self, event=None): if self.state == 'expanded': self.collapse() else: self.expand() self.item.OnDoubleClick() return "break" def expand(self, event=None): if not self.item._IsExpandable(): return if self.state != 'expanded': self.state = 'expanded' self.update() self.view() def collapse(self, event=None): if self.state != 'collapsed': self.state = 'collapsed' self.update() def view(self): top = self.y - 2 bottom = self.lastvisiblechild().y + 17 height = bottom - top visible_top = self.canvas.canvasy(0) visible_height = self.canvas.winfo_height() visible_bottom = self.canvas.canvasy(visible_height) if visible_top <= top and bottom <= visible_bottom: return x0, y0, x1, y1 = self.canvas._getints(self.canvas['scrollregion']) if top >= visible_top and height <= visible_height: fraction = top + height - visible_height else: fraction = top fraction = float(fraction) / y1 self.canvas.yview_moveto(fraction) def lastvisiblechild(self): if self.children and self.state == 'expanded': return self.children[-1].lastvisiblechild() else: return self def update(self): if self.parent: self.parent.update() else: oldcursor = self.canvas['cursor'] self.canvas['cursor'] = "watch" self.canvas.update() self.canvas.delete(ALL) # XXX could be more subtle self.draw(7, 2) x0, y0, x1, y1 = self.canvas.bbox(ALL) self.canvas.configure(scrollregion=(0, 0, x1, y1)) self.canvas['cursor'] = oldcursor def draw(self, x, y): # XXX This hard-codes too many geometry constants! self.x, self.y = x, y self.drawicon() self.drawtext() if self.state != 'expanded': return y+17 # draw children if not self.children: sublist = self.item._GetSubList() if not sublist: # _IsExpandable() was mistaken; that's allowed return y+17 for item in sublist: child = self.__class__(self.canvas, self, item) self.children.append(child) cx = x+20 cy = y+17 cylast = 0 for child in self.children: cylast = cy self.canvas.create_line(x+9, cy+7, cx, cy+7, fill="gray50") cy = child.draw(cx, cy) if child.item._IsExpandable(): if child.state == 'expanded': iconname = "minusnode" callback = child.collapse else: iconname = "plusnode" callback = child.expand image = self.geticonimage(iconname) id = self.canvas.create_image(x+9, cylast+7, image=image) # XXX This leaks bindings until canvas is deleted: self.canvas.tag_bind(id, "<1>", callback) self.canvas.tag_bind(id, "<Double-1>", lambda x: None) id = self.canvas.create_line(x+9, y+10, x+9, cylast+7, ##stipple="gray50", # XXX Seems broken in Tk 8.0.x fill="gray50") self.canvas.tag_lower(id) # XXX .lower(id) before Python 1.5.2 return cy def drawicon(self): if self.selected: imagename = (self.item.GetSelectedIconName() or self.item.GetIconName() or "openfolder") else: imagename = self.item.GetIconName() or "folder" image = self.geticonimage(imagename) id = self.canvas.create_image(self.x, self.y, anchor="nw", image=image) self.image_id = id self.canvas.tag_bind(id, "<1>", self.select) self.canvas.tag_bind(id, "<Double-1>", self.flip) def drawtext(self): textx = self.x+20-1 texty = self.y-1 labeltext = self.item.GetLabelText() if labeltext: id = self.canvas.create_text(textx, texty, anchor="nw", text=labeltext) self.canvas.tag_bind(id, "<1>", self.select) self.canvas.tag_bind(id, "<Double-1>", self.flip) x0, y0, x1, y1 = self.canvas.bbox(id) textx = max(x1, 200) + 10 text = self.item.GetText() or "<no text>" try: self.entry except AttributeError: pass else: self.edit_finish() try: label = self.label except AttributeError: # padding carefully selected (on Windows) to match Entry widget: self.label = Label(self.canvas, text=text, bd=0, padx=2, pady=2) theme = idleConf.GetOption('main','Theme','name') if self.selected: self.label.configure(idleConf.GetHighlight(theme, 'hilite')) else: self.label.configure(idleConf.GetHighlight(theme, 'normal')) id = self.canvas.create_window(textx, texty, anchor="nw", window=self.label) self.label.bind("<1>", self.select_or_edit) self.label.bind("<Double-1>", self.flip) self.text_id = id def select_or_edit(self, event=None): if self.selected and self.item.IsEditable(): self.edit(event) else: self.select(event) def edit(self, event=None): self.entry = Entry(self.label, bd=0, highlightthickness=1, width=0) self.entry.insert(0, self.label['text']) self.entry.selection_range(0, END) self.entry.pack(ipadx=5) self.entry.focus_set() self.entry.bind("<Return>", self.edit_finish) self.entry.bind("<Escape>", self.edit_cancel) def edit_finish(self, event=None): try: entry = self.entry del self.entry except AttributeError: return text = entry.get() entry.destroy() if text and text != self.item.GetText(): self.item.SetText(text) text = self.item.GetText() self.label['text'] = text self.drawtext() self.canvas.focus_set() def edit_cancel(self, event=None): try: entry = self.entry del self.entry except AttributeError: return entry.destroy() self.drawtext() self.canvas.focus_set() class TreeItem: """Abstract class representing tree items. Methods should typically be overridden, otherwise a default action is used. """ def __init__(self): """Constructor. Do whatever you need to do.""" def GetText(self): """Return text string to display.""" def GetLabelText(self): """Return label text string to display in front of text (if any).""" expandable = None def _IsExpandable(self): """Do not override! Called by TreeNode.""" if self.expandable is None: self.expandable = self.IsExpandable() return self.expandable def IsExpandable(self): """Return whether there are subitems.""" return 1 def _GetSubList(self): """Do not override! Called by TreeNode.""" if not self.IsExpandable(): return [] sublist = self.GetSubList() if not sublist: self.expandable = 0 return sublist def IsEditable(self): """Return whether the item's text may be edited.""" def SetText(self, text): """Change the item's text (if it is editable).""" def GetIconName(self): """Return name of icon to be displayed normally.""" def GetSelectedIconName(self): """Return name of icon to be displayed when selected.""" def GetSubList(self): """Return list of items forming sublist.""" def OnDoubleClick(self): """Called on a double-click on the item.""" # Example application class FileTreeItem(TreeItem): """Example TreeItem subclass -- browse the file system.""" def __init__(self, path): self.path = path def GetText(self): return os.path.basename(self.path) or self.path def IsEditable(self): return os.path.basename(self.path) != "" def SetText(self, text): newpath = os.path.dirname(self.path) newpath = os.path.join(newpath, text) if os.path.dirname(newpath) != os.path.dirname(self.path): return try: os.rename(self.path, newpath) self.path = newpath except os.error: pass def GetIconName(self): if not self.IsExpandable(): return "python" # XXX wish there was a "file" icon def IsExpandable(self): return os.path.isdir(self.path) def GetSubList(self): try: names = os.listdir(self.path) except os.error: return [] names.sort(key = os.path.normcase) sublist = [] for name in names: item = FileTreeItem(os.path.join(self.path, name)) sublist.append(item) return sublist # A canvas widget with scroll bars and some useful bindings class ScrolledCanvas: def __init__(self, master, **opts): if 'yscrollincrement' not in opts: opts['yscrollincrement'] = 17 self.master = master self.frame = Frame(master) self.frame.rowconfigure(0, weight=1) self.frame.columnconfigure(0, weight=1) self.canvas = Canvas(self.frame, **opts) self.canvas.grid(row=0, column=0, sticky="nsew") self.vbar = Scrollbar(self.frame, name="vbar") self.vbar.grid(row=0, column=1, sticky="nse") self.hbar = Scrollbar(self.frame, name="hbar", orient="horizontal") self.hbar.grid(row=1, column=0, sticky="ews") self.canvas['yscrollcommand'] = self.vbar.set self.vbar['command'] = self.canvas.yview self.canvas['xscrollcommand'] = self.hbar.set self.hbar['command'] = self.canvas.xview self.canvas.bind("<Key-Prior>", self.page_up) self.canvas.bind("<Key-Next>", self.page_down) self.canvas.bind("<Key-Up>", self.unit_up) self.canvas.bind("<Key-Down>", self.unit_down) #if isinstance(master, Toplevel) or isinstance(master, Tk): self.canvas.bind("<Alt-Key-2>", self.zoom_height) self.canvas.focus_set() def page_up(self, event): self.canvas.yview_scroll(-1, "page") return "break" def page_down(self, event): self.canvas.yview_scroll(1, "page") return "break" def unit_up(self, event): self.canvas.yview_scroll(-1, "unit") return "break" def unit_down(self, event): self.canvas.yview_scroll(1, "unit") return "break" def zoom_height(self, event): ZoomHeight.zoom_height(self.master) return "break" # Testing functions def test(): from idlelib import PyShell root = Toplevel(PyShell.root) root.configure(bd=0, bg="yellow") root.focus_set() sc = ScrolledCanvas(root, bg="white", highlightthickness=0, takefocus=1) sc.frame.pack(expand=1, fill="both") item = FileTreeItem("C:/windows/desktop") node = TreeNode(sc.canvas, None, item) node.expand() def test2(): # test w/o scrolling canvas root = Tk() root.configure(bd=0) canvas = Canvas(root, bg="white", highlightthickness=0) canvas.pack(expand=1, fill="both") item = FileTreeItem(os.curdir) node = TreeNode(canvas, None, item) node.update() canvas.focus_set() if __name__ == '__main__': test()
Save