Current Path: > > opt > alt > python36 > > lib64 > python3.6 > idlelib
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
Icons | Directory | - | - | |
__pycache__ | Directory | - | - | |
idle_test | Directory | - | - | |
CREDITS.txt | File | 1866 bytes | September 04 2021 03:49:41. | |
ChangeLog | File | 56360 bytes | September 04 2021 03:49:41. | |
HISTORY.txt | File | 10312 bytes | September 04 2021 03:49:41. | |
NEWS.txt | File | 39839 bytes | September 04 2021 03:49:41. | |
NEWS2x.txt | File | 27172 bytes | September 04 2021 03:49:41. | |
README.txt | File | 9592 bytes | September 04 2021 03:49:41. | |
TODO.txt | File | 8478 bytes | September 04 2021 03:49:41. | |
__init__.py | File | 396 bytes | April 17 2024 17:19:35. | |
__main__.py | File | 159 bytes | April 17 2024 17:19:35. | |
_pyclbr.py | File | 15199 bytes | April 17 2024 17:19:35. | |
autocomplete.py | File | 9324 bytes | April 17 2024 17:19:35. | |
autocomplete_w.py | File | 19829 bytes | April 17 2024 17:19:35. | |
autoexpand.py | File | 3216 bytes | April 17 2024 17:19:35. | |
browser.py | File | 8281 bytes | April 17 2024 17:19:35. | |
calltip.py | File | 6067 bytes | April 17 2024 17:19:35. | |
calltip_w.py | File | 7111 bytes | April 17 2024 17:19:35. | |
codecontext.py | File | 10490 bytes | April 17 2024 17:19:35. | |
colorizer.py | File | 11275 bytes | April 17 2024 17:19:35. | |
config-extensions.def | File | 2266 bytes | September 04 2021 03:49:41. | |
config-highlight.def | File | 2687 bytes | September 04 2021 03:49:41. | |
config-keys.def | File | 10775 bytes | September 04 2021 03:49:41. | |
config-main.def | File | 3128 bytes | September 04 2021 03:49:41. | |
config.py | File | 38878 bytes | April 17 2024 17:19:35. | |
config_key.py | File | 13408 bytes | April 17 2024 17:19:35. | |
configdialog.py | File | 101057 bytes | April 17 2024 17:19:35. | |
debugger.py | File | 19097 bytes | April 17 2024 17:19:35. | |
debugger_r.py | File | 12140 bytes | April 17 2024 17:19:35. | |
debugobj.py | File | 4055 bytes | April 17 2024 17:19:35. | |
debugobj_r.py | File | 1082 bytes | April 17 2024 17:19:35. | |
delegator.py | File | 1043 bytes | April 17 2024 17:19:35. | |
dynoption.py | File | 2017 bytes | April 17 2024 17:19:35. | |
editor.py | File | 67275 bytes | April 17 2024 17:19:35. | |
extend.txt | File | 3642 bytes | September 04 2021 03:49:41. | |
filelist.py | File | 3896 bytes | April 17 2024 17:19:35. | |
grep.py | File | 6742 bytes | April 17 2024 17:19:35. | |
help.html | File | 55114 bytes | September 04 2021 03:49:41. | |
help.py | File | 11325 bytes | April 17 2024 17:19:35. | |
help_about.py | File | 8981 bytes | April 17 2024 17:19:35. | |
history.py | File | 4043 bytes | April 17 2024 17:19:35. | |
hyperparser.py | File | 12882 bytes | April 17 2024 17:19:35. | |
idle.py | File | 454 bytes | April 17 2024 17:19:35. | |
idle.pyw | File | 570 bytes | September 04 2021 03:49:41. | |
iomenu.py | File | 20734 bytes | April 17 2024 17:19:35. | |
macosx.py | File | 9660 bytes | April 17 2024 17:19:35. | |
mainmenu.py | File | 3703 bytes | April 17 2024 17:19:35. | |
multicall.py | File | 18648 bytes | April 17 2024 17:19:35. | |
outwin.py | File | 5808 bytes | April 17 2024 17:19:35. | |
paragraph.py | File | 7167 bytes | April 17 2024 17:19:35. | |
parenmatch.py | File | 7204 bytes | April 17 2024 17:19:35. | |
pathbrowser.py | File | 3193 bytes | April 17 2024 17:19:35. | |
percolator.py | File | 3130 bytes | April 17 2024 17:19:35. | |
pyparse.py | File | 20118 bytes | April 17 2024 17:19:35. | |
pyshell.py | File | 57728 bytes | April 17 2024 17:19:35. | |
query.py | File | 12434 bytes | April 17 2024 17:19:35. | |
redirector.py | File | 6875 bytes | April 17 2024 17:19:35. | |
replace.py | File | 7502 bytes | April 17 2024 17:19:35. | |
rpc.py | File | 21137 bytes | April 17 2024 17:19:35. | |
rstrip.py | File | 868 bytes | April 17 2024 17:19:35. | |
run.py | File | 17272 bytes | April 17 2024 17:19:35. | |
runscript.py | File | 7841 bytes | April 17 2024 17:19:35. | |
scrolledlist.py | File | 4458 bytes | April 17 2024 17:19:35. | |
search.py | File | 3164 bytes | April 17 2024 17:19:35. | |
searchbase.py | File | 7451 bytes | April 17 2024 17:19:35. | |
searchengine.py | File | 7472 bytes | April 17 2024 17:19:35. | |
squeezer.py | File | 13308 bytes | April 17 2024 17:19:35. | |
stackviewer.py | File | 4454 bytes | April 17 2024 17:19:35. | |
statusbar.py | File | 1441 bytes | April 17 2024 17:19:35. | |
textview.py | File | 6121 bytes | April 17 2024 17:19:35. | |
tooltip.py | File | 6486 bytes | April 17 2024 17:19:35. | |
tree.py | File | 15089 bytes | April 17 2024 17:19:35. | |
undo.py | File | 11047 bytes | April 17 2024 17:19:35. | |
window.py | File | 2588 bytes | April 17 2024 17:19:35. | |
zoomheight.py | File | 1340 bytes | April 17 2024 17:19:35. | |
zzdummy.py | File | 961 bytes | April 17 2024 17:19:35. |
"""codecontext - display the block context above the edit window Once code has scrolled off the top of a window, it can be difficult to determine which block you are in. This extension implements a pane at the top of each IDLE edit window which provides block structure hints. These hints are the lines which contain the block opening keywords, e.g. 'if', for the enclosing block. The number of hint lines is determined by the maxlines variable in the codecontext section of config-extensions.def. Lines which do not open blocks are not shown in the context hints pane. """ import re from sys import maxsize as INFINITY import tkinter from tkinter.constants import TOP, X, SUNKEN from idlelib.config import idleConf BLOCKOPENERS = {"class", "def", "elif", "else", "except", "finally", "for", "if", "try", "while", "with", "async"} UPDATEINTERVAL = 100 # millisec CONFIGUPDATEINTERVAL = 1000 # millisec def get_spaces_firstword(codeline, c=re.compile(r"^(\s*)(\w*)")): "Extract the beginning whitespace and first word from codeline." return c.match(codeline).groups() def get_line_info(codeline): """Return tuple of (line indent value, codeline, block start keyword). The indentation of empty lines (or comment lines) is INFINITY. If the line does not start a block, the keyword value is False. """ spaces, firstword = get_spaces_firstword(codeline) indent = len(spaces) if len(codeline) == indent or codeline[indent] == '#': indent = INFINITY opener = firstword in BLOCKOPENERS and firstword return indent, codeline, opener class CodeContext: "Display block context above the edit window." def __init__(self, editwin): """Initialize settings for context block. editwin is the Editor window for the context block. self.text is the editor window text widget. self.textfont is the editor window font. self.context displays the code context text above the editor text. Initially None, it is toggled via <<toggle-code-context>>. self.topvisible is the number of the top text line displayed. self.info is a list of (line number, indent level, line text, block keyword) tuples for the block structure above topvisible. self.info[0] is initialized with a 'dummy' line which starts the toplevel 'block' of the module. self.t1 and self.t2 are two timer events on the editor text widget to monitor for changes to the context text or editor font. """ self.editwin = editwin self.text = editwin.text self.textfont = self.text["font"] self.contextcolors = CodeContext.colors self.context = None self.topvisible = 1 self.info = [(0, -1, "", False)] # Start two update cycles, one for context lines, one for font changes. self.t1 = self.text.after(UPDATEINTERVAL, self.timer_event) self.t2 = self.text.after(CONFIGUPDATEINTERVAL, self.config_timer_event) @classmethod def reload(cls): "Load class variables from config." cls.context_depth = idleConf.GetOption("extensions", "CodeContext", "maxlines", type="int", default=15) cls.colors = idleConf.GetHighlight(idleConf.CurrentTheme(), 'context') def __del__(self): "Cancel scheduled events." try: self.text.after_cancel(self.t1) self.text.after_cancel(self.t2) except: pass def toggle_code_context_event(self, event=None): """Toggle code context display. If self.context doesn't exist, create it to match the size of the editor window text (toggle on). If it does exist, destroy it (toggle off). Return 'break' to complete the processing of the binding. """ if not self.context: # Calculate the border width and horizontal padding required to # align the context with the text in the main Text widget. # # All values are passed through getint(), since some # values may be pixel objects, which can't simply be added to ints. widgets = self.editwin.text, self.editwin.text_frame # Calculate the required horizontal padding and border width. padx = 0 border = 0 for widget in widgets: padx += widget.tk.getint(widget.pack_info()['padx']) padx += widget.tk.getint(widget.cget('padx')) border += widget.tk.getint(widget.cget('border')) self.context = tkinter.Text( self.editwin.top, font=self.textfont, bg=self.contextcolors['background'], fg=self.contextcolors['foreground'], height=1, width=1, # Don't request more than we get. padx=padx, border=border, relief=SUNKEN, state='disabled') self.context.bind('<ButtonRelease-1>', self.jumptoline) # Pack the context widget before and above the text_frame widget, # thus ensuring that it will appear directly above text_frame. self.context.pack(side=TOP, fill=X, expand=False, before=self.editwin.text_frame) else: self.context.destroy() self.context = None return "break" def get_context(self, new_topvisible, stopline=1, stopindent=0): """Return a list of block line tuples and the 'last' indent. The tuple fields are (linenum, indent, text, opener). The list represents header lines from new_topvisible back to stopline with successively shorter indents > stopindent. The list is returned ordered by line number. Last indent returned is the smallest indent observed. """ assert stopline > 0 lines = [] # The indentation level we are currently in. lastindent = INFINITY # For a line to be interesting, it must begin with a block opening # keyword, and have less indentation than lastindent. for linenum in range(new_topvisible, stopline-1, -1): codeline = self.text.get(f'{linenum}.0', f'{linenum}.end') indent, text, opener = get_line_info(codeline) if indent < lastindent: lastindent = indent if opener in ("else", "elif"): # Also show the if statement. lastindent += 1 if opener and linenum < new_topvisible and indent >= stopindent: lines.append((linenum, indent, text, opener)) if lastindent <= stopindent: break lines.reverse() return lines, lastindent def update_code_context(self): """Update context information and lines visible in the context pane. No update is done if the text hasn't been scrolled. If the text was scrolled, the lines that should be shown in the context will be retrieved and the context area will be updated with the code, up to the number of maxlines. """ new_topvisible = int(self.text.index("@0,0").split('.')[0]) if self.topvisible == new_topvisible: # Haven't scrolled. return if self.topvisible < new_topvisible: # Scroll down. lines, lastindent = self.get_context(new_topvisible, self.topvisible) # Retain only context info applicable to the region # between topvisible and new_topvisible. while self.info[-1][1] >= lastindent: del self.info[-1] else: # self.topvisible > new_topvisible: # Scroll up. stopindent = self.info[-1][1] + 1 # Retain only context info associated # with lines above new_topvisible. while self.info[-1][0] >= new_topvisible: stopindent = self.info[-1][1] del self.info[-1] lines, lastindent = self.get_context(new_topvisible, self.info[-1][0]+1, stopindent) self.info.extend(lines) self.topvisible = new_topvisible # Last context_depth context lines. context_strings = [x[2] for x in self.info[-self.context_depth:]] showfirst = 0 if context_strings[0] else 1 # Update widget. self.context['height'] = len(context_strings) - showfirst self.context['state'] = 'normal' self.context.delete('1.0', 'end') self.context.insert('end', '\n'.join(context_strings[showfirst:])) self.context['state'] = 'disabled' def jumptoline(self, event=None): "Show clicked context line at top of editor." lines = len(self.info) if lines == 1: # No context lines are showing. newtop = 1 else: # Line number clicked. contextline = int(float(self.context.index('insert'))) # Lines not displayed due to maxlines. offset = max(1, lines - self.context_depth) - 1 newtop = self.info[offset + contextline][0] self.text.yview(f'{newtop}.0') self.update_code_context() def timer_event(self): "Event on editor text widget triggered every UPDATEINTERVAL ms." if self.context: self.update_code_context() self.t1 = self.text.after(UPDATEINTERVAL, self.timer_event) def config_timer_event(self): "Event on editor text widget triggered every CONFIGUPDATEINTERVAL ms." newtextfont = self.text["font"] if (self.context and (newtextfont != self.textfont or CodeContext.colors != self.contextcolors)): self.textfont = newtextfont self.contextcolors = CodeContext.colors self.context["font"] = self.textfont self.context['background'] = self.contextcolors['background'] self.context['foreground'] = self.contextcolors['foreground'] self.t2 = self.text.after(CONFIGUPDATEINTERVAL, self.config_timer_event) CodeContext.reload() if __name__ == "__main__": from unittest import main main('idlelib.idle_test.test_codecontext', verbosity=2, exit=False) # Add htest.
SILENT KILLER Tool