X7ROOT File Manager
Current Path:
/lib64/python2.7/idlelib
lib64
/
python2.7
/
idlelib
/
??
..
??
AutoComplete.py
(8.75 KB)
??
AutoComplete.pyc
(7.82 KB)
??
AutoComplete.pyo
(7.82 KB)
??
AutoCompleteWindow.py
(16.91 KB)
??
AutoCompleteWindow.pyc
(12.19 KB)
??
AutoCompleteWindow.pyo
(12.13 KB)
??
AutoExpand.py
(3.32 KB)
??
AutoExpand.pyc
(3.42 KB)
??
AutoExpand.pyo
(3.42 KB)
??
Bindings.py
(2.91 KB)
??
Bindings.pyc
(4.58 KB)
??
Bindings.pyo
(4.58 KB)
??
CREDITS.txt
(1.82 KB)
??
CallTipWindow.py
(5.92 KB)
??
CallTipWindow.pyc
(5.99 KB)
??
CallTipWindow.pyo
(5.99 KB)
??
CallTips.py
(7.56 KB)
??
CallTips.pyc
(7.94 KB)
??
CallTips.pyo
(7.94 KB)
??
ChangeLog
(55.07 KB)
??
ClassBrowser.py
(6.83 KB)
??
ClassBrowser.pyc
(9.28 KB)
??
ClassBrowser.pyo
(9.28 KB)
??
CodeContext.py
(8.15 KB)
??
CodeContext.pyc
(6.5 KB)
??
CodeContext.pyo
(6.46 KB)
??
ColorDelegator.py
(9.53 KB)
??
ColorDelegator.pyc
(8.69 KB)
??
ColorDelegator.pyo
(8.69 KB)
??
Debugger.py
(17.81 KB)
??
Debugger.pyc
(17.13 KB)
??
Debugger.pyo
(17.13 KB)
??
Delegator.py
(665 B)
??
Delegator.pyc
(1.24 KB)
??
Delegator.pyo
(1.24 KB)
??
EditorWindow.py
(63.96 KB)
??
EditorWindow.pyc
(55.53 KB)
??
EditorWindow.pyo
(55.43 KB)
??
FileList.py
(3.63 KB)
??
FileList.pyc
(3.93 KB)
??
FileList.pyo
(3.9 KB)
??
FormatParagraph.py
(7.12 KB)
??
FormatParagraph.pyc
(6.97 KB)
??
FormatParagraph.pyo
(6.97 KB)
??
GrepDialog.py
(5.02 KB)
??
GrepDialog.pyc
(6.27 KB)
??
GrepDialog.pyo
(6.27 KB)
??
HISTORY.txt
(10.08 KB)
??
HyperParser.py
(10.25 KB)
??
HyperParser.pyc
(6.52 KB)
??
HyperParser.pyo
(6.52 KB)
??
IOBinding.py
(21.4 KB)
??
IOBinding.pyc
(18.1 KB)
??
IOBinding.pyo
(18.1 KB)
??
Icons
??
IdleHistory.py
(3.96 KB)
??
IdleHistory.pyc
(3.96 KB)
??
IdleHistory.pyo
(3.96 KB)
??
MultiCall.py
(17.29 KB)
??
MultiCall.pyc
(15.97 KB)
??
MultiCall.pyo
(15.9 KB)
??
MultiStatusBar.py
(1.32 KB)
??
MultiStatusBar.pyc
(2.23 KB)
??
MultiStatusBar.pyo
(2.23 KB)
??
NEWS.txt
(46.14 KB)
??
ObjectBrowser.py
(4.27 KB)
??
ObjectBrowser.pyc
(6.9 KB)
??
ObjectBrowser.pyo
(6.9 KB)
??
OutputWindow.py
(4.47 KB)
??
OutputWindow.pyc
(5.11 KB)
??
OutputWindow.pyo
(5.11 KB)
??
ParenMatch.py
(6.56 KB)
??
ParenMatch.pyc
(6.96 KB)
??
ParenMatch.pyo
(6.96 KB)
??
PathBrowser.py
(2.94 KB)
??
PathBrowser.pyc
(4.38 KB)
??
PathBrowser.pyo
(4.38 KB)
??
Percolator.py
(3.15 KB)
??
Percolator.pyc
(4.5 KB)
??
Percolator.pyo
(4.32 KB)
??
PyParse.py
(19.05 KB)
??
PyParse.pyc
(9.77 KB)
??
PyParse.pyo
(9.34 KB)
??
PyShell.py
(57.48 KB)
??
PyShell.pyc
(51.59 KB)
??
PyShell.pyo
(51.49 KB)
??
README.txt
(7.71 KB)
??
RemoteDebugger.py
(11.36 KB)
??
RemoteDebugger.pyc
(15.94 KB)
??
RemoteDebugger.pyo
(15.79 KB)
??
RemoteObjectBrowser.py
(942 B)
??
RemoteObjectBrowser.pyc
(2.1 KB)
??
RemoteObjectBrowser.pyo
(2.1 KB)
??
ReplaceDialog.py
(6.48 KB)
??
ReplaceDialog.pyc
(7.57 KB)
??
ReplaceDialog.pyo
(7.57 KB)
??
RstripExtension.py
(1.03 KB)
??
RstripExtension.pyc
(1.58 KB)
??
RstripExtension.pyo
(1.58 KB)
??
ScriptBinding.py
(8.26 KB)
??
ScriptBinding.pyc
(8.01 KB)
??
ScriptBinding.pyo
(8.01 KB)
??
ScrolledList.py
(4.27 KB)
??
ScrolledList.pyc
(6.33 KB)
??
ScrolledList.pyo
(6.33 KB)
??
SearchDialog.py
(2.57 KB)
??
SearchDialog.pyc
(3.89 KB)
??
SearchDialog.pyo
(3.89 KB)
??
SearchDialogBase.py
(6.93 KB)
??
SearchDialogBase.pyc
(8.26 KB)
??
SearchDialogBase.pyo
(8.26 KB)
??
SearchEngine.py
(7.29 KB)
??
SearchEngine.pyc
(8.11 KB)
??
SearchEngine.pyo
(8.11 KB)
??
StackViewer.py
(4.33 KB)
??
StackViewer.pyc
(6.25 KB)
??
StackViewer.pyo
(6.25 KB)
??
TODO.txt
(8.28 KB)
??
ToolTip.py
(3.1 KB)
??
ToolTip.pyc
(4.56 KB)
??
ToolTip.pyo
(4.56 KB)
??
TreeWidget.py
(14.68 KB)
??
TreeWidget.pyc
(17.28 KB)
??
TreeWidget.pyo
(17.28 KB)
??
UndoDelegator.py
(10.53 KB)
??
UndoDelegator.pyc
(13.24 KB)
??
UndoDelegator.pyo
(13.24 KB)
??
WidgetRedirector.py
(6.74 KB)
??
WidgetRedirector.pyc
(7.59 KB)
??
WidgetRedirector.pyo
(7.59 KB)
??
WindowList.py
(2.42 KB)
??
WindowList.pyc
(3.55 KB)
??
WindowList.pyo
(3.55 KB)
??
ZoomHeight.py
(1.27 KB)
??
ZoomHeight.pyc
(1.61 KB)
??
ZoomHeight.pyo
(1.61 KB)
??
__init__.py
(288 B)
??
__init__.pyc
(431 B)
??
__init__.pyo
(431 B)
??
aboutDialog.py
(6.85 KB)
??
aboutDialog.pyc
(6.69 KB)
??
aboutDialog.pyo
(6.69 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
(52.04 KB)
??
configDialog.pyo
(52.04 KB)
??
configHandler.py
(31.72 KB)
??
configHandler.pyc
(28.67 KB)
??
configHandler.pyo
(28.67 KB)
??
configHelpSourceEdit.py
(6.53 KB)
??
configHelpSourceEdit.pyc
(6.44 KB)
??
configHelpSourceEdit.pyo
(6.44 KB)
??
configSectionNameDialog.py
(3.95 KB)
??
configSectionNameDialog.pyc
(4.32 KB)
??
configSectionNameDialog.pyo
(4.32 KB)
??
dynOptionMenuWidget.py
(1.94 KB)
??
dynOptionMenuWidget.pyc
(2.72 KB)
??
dynOptionMenuWidget.pyo
(2.72 KB)
??
extend.txt
(3.56 KB)
??
help.html
(41.42 KB)
??
help.py
(10.78 KB)
??
help.pyc
(11.98 KB)
??
help.pyo
(11.98 KB)
??
help.txt
(11.86 KB)
??
idle.py
(453 B)
??
idle.pyc
(410 B)
??
idle.pyo
(410 B)
??
idle.pyw
(563 B)
??
idle_test
??
idlever.py
(415 B)
??
idlever.pyc
(578 B)
??
idlever.pyo
(578 B)
??
keybindingDialog.py
(12.18 KB)
??
keybindingDialog.pyc
(11.89 KB)
??
keybindingDialog.pyo
(11.89 KB)
??
macosxSupport.py
(8.24 KB)
??
macosxSupport.pyc
(8.16 KB)
??
macosxSupport.pyo
(8.02 KB)
??
rpc.py
(19.68 KB)
??
rpc.pyc
(21.22 KB)
??
rpc.pyo
(21.12 KB)
??
run.py
(12.61 KB)
??
run.pyc
(13.1 KB)
??
run.pyo
(13.05 KB)
??
tabbedpages.py
(18.01 KB)
??
tabbedpages.pyc
(18.13 KB)
??
tabbedpages.pyo
(18.13 KB)
??
textView.py
(3.44 KB)
??
textView.pyc
(3.93 KB)
??
textView.pyo
(3.93 KB)
Editing: UndoDelegator.py
import string from Tkinter import * from idlelib.Delegator import Delegator #$ event <<redo>> #$ win <Control-y> #$ unix <Alt-z> #$ event <<undo>> #$ win <Control-z> #$ unix <Control-z> #$ event <<dump-undo-state>> #$ win <Control-backslash> #$ unix <Control-backslash> class UndoDelegator(Delegator): max_undo = 1000 def __init__(self): Delegator.__init__(self) self.reset_undo() def setdelegate(self, delegate): if self.delegate is not None: self.unbind("<<undo>>") self.unbind("<<redo>>") self.unbind("<<dump-undo-state>>") Delegator.setdelegate(self, delegate) if delegate is not None: self.bind("<<undo>>", self.undo_event) self.bind("<<redo>>", self.redo_event) self.bind("<<dump-undo-state>>", self.dump_event) def dump_event(self, event): from pprint import pprint pprint(self.undolist[:self.pointer]) print "pointer:", self.pointer, print "saved:", self.saved, print "can_merge:", self.can_merge, print "get_saved():", self.get_saved() pprint(self.undolist[self.pointer:]) return "break" def reset_undo(self): self.was_saved = -1 self.pointer = 0 self.undolist = [] self.undoblock = 0 # or a CommandSequence instance self.set_saved(1) def set_saved(self, flag): if flag: self.saved = self.pointer else: self.saved = -1 self.can_merge = False self.check_saved() def get_saved(self): return self.saved == self.pointer saved_change_hook = None def set_saved_change_hook(self, hook): self.saved_change_hook = hook was_saved = -1 def check_saved(self): is_saved = self.get_saved() if is_saved != self.was_saved: self.was_saved = is_saved if self.saved_change_hook: self.saved_change_hook() def insert(self, index, chars, tags=None): self.addcmd(InsertCommand(index, chars, tags)) def delete(self, index1, index2=None): self.addcmd(DeleteCommand(index1, index2)) # Clients should call undo_block_start() and undo_block_stop() # around a sequence of editing cmds to be treated as a unit by # undo & redo. Nested matching calls are OK, and the inner calls # then act like nops. OK too if no editing cmds, or only one # editing cmd, is issued in between: if no cmds, the whole # sequence has no effect; and if only one cmd, that cmd is entered # directly into the undo list, as if undo_block_xxx hadn't been # called. The intent of all that is to make this scheme easy # to use: all the client has to worry about is making sure each # _start() call is matched by a _stop() call. def undo_block_start(self): if self.undoblock == 0: self.undoblock = CommandSequence() self.undoblock.bump_depth() def undo_block_stop(self): if self.undoblock.bump_depth(-1) == 0: cmd = self.undoblock self.undoblock = 0 if len(cmd) > 0: if len(cmd) == 1: # no need to wrap a single cmd cmd = cmd.getcmd(0) # this blk of cmds, or single cmd, has already # been done, so don't execute it again self.addcmd(cmd, 0) def addcmd(self, cmd, execute=True): if execute: cmd.do(self.delegate) if self.undoblock != 0: self.undoblock.append(cmd) return if self.can_merge and self.pointer > 0: lastcmd = self.undolist[self.pointer-1] if lastcmd.merge(cmd): return self.undolist[self.pointer:] = [cmd] if self.saved > self.pointer: self.saved = -1 self.pointer = self.pointer + 1 if len(self.undolist) > self.max_undo: ##print "truncating undo list" del self.undolist[0] self.pointer = self.pointer - 1 if self.saved >= 0: self.saved = self.saved - 1 self.can_merge = True self.check_saved() def undo_event(self, event): if self.pointer == 0: self.bell() return "break" cmd = self.undolist[self.pointer - 1] cmd.undo(self.delegate) self.pointer = self.pointer - 1 self.can_merge = False self.check_saved() return "break" def redo_event(self, event): if self.pointer >= len(self.undolist): self.bell() return "break" cmd = self.undolist[self.pointer] cmd.redo(self.delegate) self.pointer = self.pointer + 1 self.can_merge = False self.check_saved() return "break" class Command: # Base class for Undoable commands tags = None def __init__(self, index1, index2, chars, tags=None): self.marks_before = {} self.marks_after = {} self.index1 = index1 self.index2 = index2 self.chars = chars if tags: self.tags = tags def __repr__(self): s = self.__class__.__name__ t = (self.index1, self.index2, self.chars, self.tags) if self.tags is None: t = t[:-1] return s + repr(t) def do(self, text): pass def redo(self, text): pass def undo(self, text): pass def merge(self, cmd): return 0 def save_marks(self, text): marks = {} for name in text.mark_names(): if name != "insert" and name != "current": marks[name] = text.index(name) return marks def set_marks(self, text, marks): for name, index in marks.items(): text.mark_set(name, index) class InsertCommand(Command): # Undoable insert command def __init__(self, index1, chars, tags=None): Command.__init__(self, index1, None, chars, tags) def do(self, text): self.marks_before = self.save_marks(text) self.index1 = text.index(self.index1) if text.compare(self.index1, ">", "end-1c"): # Insert before the final newline self.index1 = text.index("end-1c") text.insert(self.index1, self.chars, self.tags) self.index2 = text.index("%s+%dc" % (self.index1, len(self.chars))) self.marks_after = self.save_marks(text) ##sys.__stderr__.write("do: %s\n" % self) def redo(self, text): text.mark_set('insert', self.index1) text.insert(self.index1, self.chars, self.tags) self.set_marks(text, self.marks_after) text.see('insert') ##sys.__stderr__.write("redo: %s\n" % self) def undo(self, text): text.mark_set('insert', self.index1) text.delete(self.index1, self.index2) self.set_marks(text, self.marks_before) text.see('insert') ##sys.__stderr__.write("undo: %s\n" % self) def merge(self, cmd): if self.__class__ is not cmd.__class__: return False if self.index2 != cmd.index1: return False if self.tags != cmd.tags: return False if len(cmd.chars) != 1: return False if self.chars and \ self.classify(self.chars[-1]) != self.classify(cmd.chars): return False self.index2 = cmd.index2 self.chars = self.chars + cmd.chars return True alphanumeric = string.ascii_letters + string.digits + "_" def classify(self, c): if c in self.alphanumeric: return "alphanumeric" if c == "\n": return "newline" return "punctuation" class DeleteCommand(Command): # Undoable delete command def __init__(self, index1, index2=None): Command.__init__(self, index1, index2, None, None) def do(self, text): self.marks_before = self.save_marks(text) self.index1 = text.index(self.index1) if self.index2: self.index2 = text.index(self.index2) else: self.index2 = text.index(self.index1 + " +1c") if text.compare(self.index2, ">", "end-1c"): # Don't delete the final newline self.index2 = text.index("end-1c") self.chars = text.get(self.index1, self.index2) text.delete(self.index1, self.index2) self.marks_after = self.save_marks(text) ##sys.__stderr__.write("do: %s\n" % self) def redo(self, text): text.mark_set('insert', self.index1) text.delete(self.index1, self.index2) self.set_marks(text, self.marks_after) text.see('insert') ##sys.__stderr__.write("redo: %s\n" % self) def undo(self, text): text.mark_set('insert', self.index1) text.insert(self.index1, self.chars) self.set_marks(text, self.marks_before) text.see('insert') ##sys.__stderr__.write("undo: %s\n" % self) class CommandSequence(Command): # Wrapper for a sequence of undoable cmds to be undone/redone # as a unit def __init__(self): self.cmds = [] self.depth = 0 def __repr__(self): s = self.__class__.__name__ strs = [] for cmd in self.cmds: strs.append(" %r" % (cmd,)) return s + "(\n" + ",\n".join(strs) + "\n)" def __len__(self): return len(self.cmds) def append(self, cmd): self.cmds.append(cmd) def getcmd(self, i): return self.cmds[i] def redo(self, text): for cmd in self.cmds: cmd.redo(text) def undo(self, text): cmds = self.cmds[:] cmds.reverse() for cmd in cmds: cmd.undo(text) def bump_depth(self, incr=1): self.depth = self.depth + incr return self.depth def _undo_delegator(parent): from idlelib.Percolator import Percolator root = Tk() root.title("Test UndoDelegator") width, height, x, y = list(map(int, re.split('[x+]', parent.geometry()))) root.geometry("+%d+%d"%(x, y + 150)) text = Text(root) text.config(height=10) text.pack() text.focus_set() p = Percolator(text) d = UndoDelegator() p.insertfilter(d) undo = Button(root, text="Undo", command=lambda:d.undo_event(None)) undo.pack(side='left') redo = Button(root, text="Redo", command=lambda:d.redo_event(None)) redo.pack(side='left') dump = Button(root, text="Dump", command=lambda:d.dump_event(None)) dump.pack(side='left') root.mainloop() if __name__ == "__main__": from idlelib.idle_test.htest import run run(_undo_delegator)
Upload File
Create Folder