X7ROOT File Manager
Current Path:
/opt/alt/python27/lib64/python2.7/idlelib
opt
/
alt
/
python27
/
lib64
/
python2.7
/
idlelib
/
ðŸ“
..
📄
AutoComplete.py
(8.75 KB)
📄
AutoComplete.pyc
(7.99 KB)
📄
AutoComplete.pyo
(7.99 KB)
📄
AutoCompleteWindow.py
(16.91 KB)
📄
AutoCompleteWindow.pyc
(12.42 KB)
📄
AutoCompleteWindow.pyo
(12.36 KB)
📄
AutoExpand.py
(3.32 KB)
📄
AutoExpand.pyc
(3.5 KB)
📄
AutoExpand.pyo
(3.5 KB)
📄
Bindings.py
(2.91 KB)
📄
Bindings.pyc
(4.6 KB)
📄
Bindings.pyo
(4.6 KB)
📄
CREDITS.txt
(1.82 KB)
📄
CallTipWindow.py
(5.92 KB)
📄
CallTipWindow.pyc
(6.14 KB)
📄
CallTipWindow.pyo
(6.14 KB)
📄
CallTips.py
(7.56 KB)
📄
CallTips.pyc
(8.16 KB)
📄
CallTips.pyo
(8.16 KB)
📄
ChangeLog
(55.07 KB)
📄
ClassBrowser.py
(6.83 KB)
📄
ClassBrowser.pyc
(9.66 KB)
📄
ClassBrowser.pyo
(9.66 KB)
📄
CodeContext.py
(8.15 KB)
📄
CodeContext.pyc
(6.63 KB)
📄
CodeContext.pyo
(6.59 KB)
📄
ColorDelegator.py
(9.53 KB)
📄
ColorDelegator.pyc
(8.91 KB)
📄
ColorDelegator.pyo
(8.91 KB)
📄
Debugger.py
(17.81 KB)
📄
Debugger.pyc
(17.72 KB)
📄
Debugger.pyo
(17.72 KB)
📄
Delegator.py
(665 B)
📄
Delegator.pyc
(1.31 KB)
📄
Delegator.pyo
(1.31 KB)
📄
EditorWindow.py
(63.96 KB)
📄
EditorWindow.pyc
(57.15 KB)
📄
EditorWindow.pyo
(57.05 KB)
📄
FileList.py
(3.63 KB)
📄
FileList.pyc
(4.07 KB)
📄
FileList.pyo
(4.04 KB)
📄
FormatParagraph.py
(7.12 KB)
📄
FormatParagraph.pyc
(7.14 KB)
📄
FormatParagraph.pyo
(7.14 KB)
📄
GrepDialog.py
(5.02 KB)
📄
GrepDialog.pyc
(6.45 KB)
📄
GrepDialog.pyo
(6.45 KB)
📄
HISTORY.txt
(10.08 KB)
📄
HyperParser.py
(10.25 KB)
📄
HyperParser.pyc
(6.64 KB)
📄
HyperParser.pyo
(6.64 KB)
📄
IOBinding.py
(21.4 KB)
📄
IOBinding.pyc
(18.62 KB)
📄
IOBinding.pyo
(18.62 KB)
ðŸ“
Icons
📄
IdleHistory.py
(3.96 KB)
📄
IdleHistory.pyc
(4.05 KB)
📄
IdleHistory.pyo
(4.05 KB)
📄
MultiCall.py
(17.29 KB)
📄
MultiCall.pyc
(16.4 KB)
📄
MultiCall.pyo
(16.33 KB)
📄
MultiStatusBar.py
(1.32 KB)
📄
MultiStatusBar.pyc
(2.3 KB)
📄
MultiStatusBar.pyo
(2.3 KB)
📄
NEWS.txt
(46.14 KB)
📄
ObjectBrowser.py
(4.27 KB)
📄
ObjectBrowser.pyc
(7.26 KB)
📄
ObjectBrowser.pyo
(7.26 KB)
📄
OutputWindow.py
(4.47 KB)
📄
OutputWindow.pyc
(5.3 KB)
📄
OutputWindow.pyo
(5.3 KB)
📄
ParenMatch.py
(6.56 KB)
📄
ParenMatch.pyc
(7.18 KB)
📄
ParenMatch.pyo
(7.18 KB)
📄
PathBrowser.py
(2.94 KB)
📄
PathBrowser.pyc
(4.57 KB)
📄
PathBrowser.pyo
(4.57 KB)
📄
Percolator.py
(3.15 KB)
📄
Percolator.pyc
(4.69 KB)
📄
Percolator.pyo
(4.51 KB)
📄
PyParse.py
(19.05 KB)
📄
PyParse.pyc
(9.99 KB)
📄
PyParse.pyo
(9.56 KB)
📄
PyShell.py
(57.49 KB)
📄
PyShell.pyc
(53 KB)
📄
PyShell.pyo
(52.9 KB)
📄
README.txt
(7.71 KB)
📄
RemoteDebugger.py
(11.36 KB)
📄
RemoteDebugger.pyc
(16.73 KB)
📄
RemoteDebugger.pyo
(16.58 KB)
📄
RemoteObjectBrowser.py
(942 B)
📄
RemoteObjectBrowser.pyc
(2.23 KB)
📄
RemoteObjectBrowser.pyo
(2.23 KB)
📄
ReplaceDialog.py
(6.48 KB)
📄
ReplaceDialog.pyc
(7.83 KB)
📄
ReplaceDialog.pyo
(7.83 KB)
📄
RstripExtension.py
(1.03 KB)
📄
RstripExtension.pyc
(1.63 KB)
📄
RstripExtension.pyo
(1.63 KB)
📄
ScriptBinding.py
(8.26 KB)
📄
ScriptBinding.pyc
(8.17 KB)
📄
ScriptBinding.pyo
(8.17 KB)
📄
ScrolledList.py
(4.27 KB)
📄
ScrolledList.pyc
(6.61 KB)
📄
ScrolledList.pyo
(6.61 KB)
📄
SearchDialog.py
(2.57 KB)
📄
SearchDialog.pyc
(4.04 KB)
📄
SearchDialog.pyo
(4.04 KB)
📄
SearchDialogBase.py
(6.93 KB)
📄
SearchDialogBase.pyc
(8.43 KB)
📄
SearchDialogBase.pyo
(8.43 KB)
📄
SearchEngine.py
(7.29 KB)
📄
SearchEngine.pyc
(8.37 KB)
📄
SearchEngine.pyo
(8.37 KB)
📄
StackViewer.py
(4.33 KB)
📄
StackViewer.pyc
(6.52 KB)
📄
StackViewer.pyo
(6.52 KB)
📄
TODO.txt
(8.28 KB)
📄
ToolTip.py
(3.1 KB)
📄
ToolTip.pyc
(4.78 KB)
📄
ToolTip.pyo
(4.78 KB)
📄
TreeWidget.py
(14.68 KB)
📄
TreeWidget.pyc
(17.95 KB)
📄
TreeWidget.pyo
(17.95 KB)
📄
UndoDelegator.py
(10.53 KB)
📄
UndoDelegator.pyc
(13.88 KB)
📄
UndoDelegator.pyo
(13.88 KB)
📄
WidgetRedirector.py
(6.74 KB)
📄
WidgetRedirector.pyc
(7.76 KB)
📄
WidgetRedirector.pyo
(7.76 KB)
📄
WindowList.py
(2.42 KB)
📄
WindowList.pyc
(3.74 KB)
📄
WindowList.pyo
(3.74 KB)
📄
ZoomHeight.py
(1.27 KB)
📄
ZoomHeight.pyc
(1.67 KB)
📄
ZoomHeight.pyo
(1.67 KB)
📄
__init__.py
(288 B)
📄
__init__.pyc
(444 B)
📄
__init__.pyo
(444 B)
📄
aboutDialog.py
(6.85 KB)
📄
aboutDialog.pyc
(6.85 KB)
📄
aboutDialog.pyo
(6.85 KB)
📄
config-extensions.def
(2.9 KB)
📄
config-highlight.def
(2.46 KB)
📄
config-keys.def
(7.59 KB)
📄
config-main.def
(2.5 KB)
📄
configDialog.py
(64.41 KB)
📄
configDialog.pyc
(53.16 KB)
📄
configDialog.pyo
(53.16 KB)
📄
configHandler.py
(31.72 KB)
📄
configHandler.pyc
(29.28 KB)
📄
configHandler.pyo
(29.28 KB)
📄
configHelpSourceEdit.py
(6.53 KB)
📄
configHelpSourceEdit.pyc
(6.55 KB)
📄
configHelpSourceEdit.pyo
(6.55 KB)
📄
configSectionNameDialog.py
(3.95 KB)
📄
configSectionNameDialog.pyc
(4.4 KB)
📄
configSectionNameDialog.pyo
(4.4 KB)
📄
dynOptionMenuWidget.py
(1.94 KB)
📄
dynOptionMenuWidget.pyc
(2.8 KB)
📄
dynOptionMenuWidget.pyo
(2.8 KB)
📄
extend.txt
(3.56 KB)
📄
help.html
(41.42 KB)
📄
help.py
(10.78 KB)
📄
help.pyc
(12.25 KB)
📄
help.pyo
(12.25 KB)
📄
help.txt
(11.86 KB)
📄
idle.py
(453 B)
📄
idle.pyc
(423 B)
📄
idle.pyo
(423 B)
📄
idle.pyw
(563 B)
ðŸ“
idle_test
📄
idlever.py
(415 B)
📄
idlever.pyc
(591 B)
📄
idlever.pyo
(591 B)
📄
keybindingDialog.py
(12.18 KB)
📄
keybindingDialog.pyc
(12.08 KB)
📄
keybindingDialog.pyo
(12.08 KB)
📄
macosxSupport.py
(8.24 KB)
📄
macosxSupport.pyc
(8.38 KB)
📄
macosxSupport.pyo
(8.25 KB)
📄
rpc.py
(19.68 KB)
📄
rpc.pyc
(21.97 KB)
📄
rpc.pyo
(21.86 KB)
📄
run.py
(12.61 KB)
📄
run.pyc
(13.45 KB)
📄
run.pyo
(13.39 KB)
📄
tabbedpages.py
(18.01 KB)
📄
tabbedpages.pyc
(18.63 KB)
📄
tabbedpages.pyo
(18.63 KB)
📄
textView.py
(3.44 KB)
📄
textView.pyc
(4.02 KB)
📄
textView.pyo
(4.02 KB)
Editing: ColorDelegator.py
import time import re import keyword import __builtin__ from idlelib.Delegator import Delegator from idlelib.configHandler import idleConf DEBUG = False def any(name, alternates): "Return a named group pattern matching list of alternates." return "(?P<%s>" % name + "|".join(alternates) + ")" def make_pat(): kw = r"\b" + any("KEYWORD", keyword.kwlist) + r"\b" builtinlist = [str(name) for name in dir(__builtin__) if not name.startswith('_')] # We don't know whether "print" is a function or a keyword, # so we always treat is as a keyword (the most common case). builtinlist.remove('print') # self.file = file("file") : # 1st 'file' colorized normal, 2nd as builtin, 3rd as string builtin = r"([^.'\"\\#]\b|^)" + any("BUILTIN", builtinlist) + r"\b" comment = any("COMMENT", [r"#[^\n]*"]) stringprefix = r"(\br|u|ur|R|U|UR|Ur|uR|b|B|br|Br|bR|BR)?" sqstring = stringprefix + r"'[^'\\\n]*(\\.[^'\\\n]*)*'?" dqstring = stringprefix + r'"[^"\\\n]*(\\.[^"\\\n]*)*"?' sq3string = stringprefix + r"'''[^'\\]*((\\.|'(?!''))[^'\\]*)*(''')?" dq3string = stringprefix + r'"""[^"\\]*((\\.|"(?!""))[^"\\]*)*(""")?' string = any("STRING", [sq3string, dq3string, sqstring, dqstring]) return kw + "|" + builtin + "|" + comment + "|" + string +\ "|" + any("SYNC", [r"\n"]) prog = re.compile(make_pat(), re.S) idprog = re.compile(r"\s+(\w+)", re.S) class ColorDelegator(Delegator): def __init__(self): Delegator.__init__(self) self.prog = prog self.idprog = idprog self.LoadTagDefs() def setdelegate(self, delegate): if self.delegate is not None: self.unbind("<<toggle-auto-coloring>>") Delegator.setdelegate(self, delegate) if delegate is not None: self.config_colors() self.bind("<<toggle-auto-coloring>>", self.toggle_colorize_event) self.notify_range("1.0", "end") else: # No delegate - stop any colorizing self.stop_colorizing = True self.allow_colorizing = False def config_colors(self): for tag, cnf in self.tagdefs.items(): if cnf: self.tag_configure(tag, **cnf) self.tag_raise('sel') def LoadTagDefs(self): theme = idleConf.CurrentTheme() self.tagdefs = { "COMMENT": idleConf.GetHighlight(theme, "comment"), "KEYWORD": idleConf.GetHighlight(theme, "keyword"), "BUILTIN": idleConf.GetHighlight(theme, "builtin"), "STRING": idleConf.GetHighlight(theme, "string"), "DEFINITION": idleConf.GetHighlight(theme, "definition"), "SYNC": {'background':None,'foreground':None}, "TODO": {'background':None,'foreground':None}, "ERROR": idleConf.GetHighlight(theme, "error"), # The following is used by ReplaceDialog: "hit": idleConf.GetHighlight(theme, "hit"), } if DEBUG: print 'tagdefs',self.tagdefs def insert(self, index, chars, tags=None): index = self.index(index) self.delegate.insert(index, chars, tags) self.notify_range(index, index + "+%dc" % len(chars)) def delete(self, index1, index2=None): index1 = self.index(index1) self.delegate.delete(index1, index2) self.notify_range(index1) after_id = None allow_colorizing = True colorizing = False def notify_range(self, index1, index2=None): self.tag_add("TODO", index1, index2) if self.after_id: if DEBUG: print "colorizing already scheduled" return if self.colorizing: self.stop_colorizing = True if DEBUG: print "stop colorizing" if self.allow_colorizing: if DEBUG: print "schedule colorizing" self.after_id = self.after(1, self.recolorize) close_when_done = None # Window to be closed when done colorizing def close(self, close_when_done=None): if self.after_id: after_id = self.after_id self.after_id = None if DEBUG: print "cancel scheduled recolorizer" self.after_cancel(after_id) self.allow_colorizing = False self.stop_colorizing = True if close_when_done: if not self.colorizing: close_when_done.destroy() else: self.close_when_done = close_when_done def toggle_colorize_event(self, event): if self.after_id: after_id = self.after_id self.after_id = None if DEBUG: print "cancel scheduled recolorizer" self.after_cancel(after_id) if self.allow_colorizing and self.colorizing: if DEBUG: print "stop colorizing" self.stop_colorizing = True self.allow_colorizing = not self.allow_colorizing if self.allow_colorizing and not self.colorizing: self.after_id = self.after(1, self.recolorize) if DEBUG: print "auto colorizing turned",\ self.allow_colorizing and "on" or "off" return "break" def recolorize(self): self.after_id = None if not self.delegate: if DEBUG: print "no delegate" return if not self.allow_colorizing: if DEBUG: print "auto colorizing is off" return if self.colorizing: if DEBUG: print "already colorizing" return try: self.stop_colorizing = False self.colorizing = True if DEBUG: print "colorizing..." t0 = time.clock() self.recolorize_main() t1 = time.clock() if DEBUG: print "%.3f seconds" % (t1-t0) finally: self.colorizing = False if self.allow_colorizing and self.tag_nextrange("TODO", "1.0"): if DEBUG: print "reschedule colorizing" self.after_id = self.after(1, self.recolorize) if self.close_when_done: top = self.close_when_done self.close_when_done = None top.destroy() def recolorize_main(self): next = "1.0" while True: item = self.tag_nextrange("TODO", next) if not item: break head, tail = item self.tag_remove("SYNC", head, tail) item = self.tag_prevrange("SYNC", head) if item: head = item[1] else: head = "1.0" chars = "" next = head lines_to_get = 1 ok = False while not ok: mark = next next = self.index(mark + "+%d lines linestart" % lines_to_get) lines_to_get = min(lines_to_get * 2, 100) ok = "SYNC" in self.tag_names(next + "-1c") line = self.get(mark, next) ##print head, "get", mark, next, "->", repr(line) if not line: return for tag in self.tagdefs.keys(): self.tag_remove(tag, mark, next) chars = chars + line m = self.prog.search(chars) while m: for key, value in m.groupdict().items(): if value: a, b = m.span(key) self.tag_add(key, head + "+%dc" % a, head + "+%dc" % b) if value in ("def", "class"): m1 = self.idprog.match(chars, b) if m1: a, b = m1.span(1) self.tag_add("DEFINITION", head + "+%dc" % a, head + "+%dc" % b) m = self.prog.search(chars, m.end()) if "SYNC" in self.tag_names(next + "-1c"): head = next chars = "" else: ok = False if not ok: # We're in an inconsistent state, and the call to # update may tell us to stop. It may also change # the correct value for "next" (since this is a # line.col string, not a true mark). So leave a # crumb telling the next invocation to resume here # in case update tells us to leave. self.tag_add("TODO", next) self.update() if self.stop_colorizing: if DEBUG: print "colorizing stopped" return def removecolors(self): for tag in self.tagdefs.keys(): self.tag_remove(tag, "1.0", "end") def _color_delegator(parent): # htest # from Tkinter import Toplevel, Text from idlelib.Percolator import Percolator top = Toplevel(parent) top.title("Test ColorDelegator") top.geometry("200x100+%d+%d" % (parent.winfo_rootx() + 200, parent.winfo_rooty() + 150)) source = "if somename: x = 'abc' # comment\nprint\n" text = Text(top, background="white") text.pack(expand=1, fill="both") text.insert("insert", source) text.focus_set() p = Percolator(text) d = ColorDelegator() p.insertfilter(d) if __name__ == "__main__": from idlelib.idle_test.htest import run run(_color_delegator)
Upload File
Create Folder