GRAYBYTE WORDPRESS FILE MANAGER1138

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.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
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/python36/lib64/python3.6/idlelib/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/python36/lib64/python3.6/idlelib//undo.py
import string

from idlelib.delegator import Delegator

# tkintter import not needed because module does not create widgets,
# although many methods operate on text widget arguments.

#$ 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, end=' ')
        print("saved:", self.saved, end=' ')
        print("can_merge:", self.can_merge, end=' ')
        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):  # htest #
    from tkinter import Toplevel, Text, Button
    from idlelib.percolator import Percolator
    undowin = Toplevel(parent)
    undowin.title("Test UndoDelegator")
    x, y = map(int, parent.geometry().split('+')[1:])
    undowin.geometry("+%d+%d" % (x, y + 175))

    text = Text(undowin, height=10)
    text.pack()
    text.focus_set()
    p = Percolator(text)
    d = UndoDelegator()
    p.insertfilter(d)

    undo = Button(undowin, text="Undo", command=lambda:d.undo_event(None))
    undo.pack(side='left')
    redo = Button(undowin, text="Redo", command=lambda:d.redo_event(None))
    redo.pack(side='left')
    dump = Button(undowin, text="Dump", command=lambda:d.dump_event(None))
    dump.pack(side='left')

if __name__ == "__main__":
    from unittest import main
    main('idlelib.idle_test.test_undo', verbosity=2, exit=False)

    from idlelib.idle_test.htest import run
    run(_undo_delegator)

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
May 20 2024 08:31:55
root / linksafe
0755
Icons
--
May 20 2024 08:31:54
root / linksafe
0755
__pycache__
--
May 20 2024 08:31:54
root / linksafe
0755
idle_test
--
May 20 2024 08:31:55
root / linksafe
0755
CREDITS.txt
1.822 KB
September 04 2021 03:49:41
root / linksafe
0644
ChangeLog
55.039 KB
September 04 2021 03:49:41
root / linksafe
0644
HISTORY.txt
10.07 KB
September 04 2021 03:49:41
root / linksafe
0644
NEWS.txt
38.905 KB
September 04 2021 03:49:41
root / linksafe
0644
NEWS2x.txt
26.535 KB
September 04 2021 03:49:41
root / linksafe
0644
README.txt
9.367 KB
September 04 2021 03:49:41
root / linksafe
0644
TODO.txt
8.279 KB
September 04 2021 03:49:41
root / linksafe
0644
__init__.py
0.387 KB
April 17 2024 17:19:35
root / linksafe
0644
__main__.py
0.155 KB
April 17 2024 17:19:35
root / linksafe
0644
_pyclbr.py
14.843 KB
April 17 2024 17:19:35
root / linksafe
0644
autocomplete.py
9.105 KB
April 17 2024 17:19:35
root / linksafe
0644
autocomplete_w.py
19.364 KB
April 17 2024 17:19:35
root / linksafe
0644
autoexpand.py
3.141 KB
April 17 2024 17:19:35
root / linksafe
0644
browser.py
8.087 KB
April 17 2024 17:19:35
root / linksafe
0644
calltip.py
5.925 KB
April 17 2024 17:19:35
root / linksafe
0644
calltip_w.py
6.944 KB
April 17 2024 17:19:35
root / linksafe
0644
codecontext.py
10.244 KB
April 17 2024 17:19:35
root / linksafe
0644
colorizer.py
11.011 KB
April 17 2024 17:19:35
root / linksafe
0644
config-extensions.def
2.213 KB
September 04 2021 03:49:41
root / linksafe
0644
config-highlight.def
2.624 KB
September 04 2021 03:49:41
root / linksafe
0644
config-keys.def
10.522 KB
September 04 2021 03:49:41
root / linksafe
0644
config-main.def
3.055 KB
September 04 2021 03:49:41
root / linksafe
0644
config.py
37.967 KB
April 17 2024 17:19:35
root / linksafe
0644
config_key.py
13.094 KB
April 17 2024 17:19:35
root / linksafe
0644
configdialog.py
98.688 KB
April 17 2024 17:19:35
root / linksafe
0644
debugger.py
18.649 KB
April 17 2024 17:19:35
root / linksafe
0644
debugger_r.py
11.855 KB
April 17 2024 17:19:35
root / linksafe
0644
debugobj.py
3.96 KB
April 17 2024 17:19:35
root / linksafe
0644
debugobj_r.py
1.057 KB
April 17 2024 17:19:35
root / linksafe
0644
delegator.py
1.019 KB
April 17 2024 17:19:35
root / linksafe
0644
dynoption.py
1.97 KB
April 17 2024 17:19:35
root / linksafe
0644
editor.py
65.698 KB
April 17 2024 17:19:35
root / linksafe
0644
extend.txt
3.557 KB
September 04 2021 03:49:41
root / linksafe
0644
filelist.py
3.805 KB
April 17 2024 17:19:35
root / linksafe
0644
grep.py
6.584 KB
April 17 2024 17:19:35
root / linksafe
0644
help.html
53.822 KB
September 04 2021 03:49:41
root / linksafe
0644
help.py
11.06 KB
April 17 2024 17:19:35
root / linksafe
0644
help_about.py
8.771 KB
April 17 2024 17:19:35
root / linksafe
0644
history.py
3.948 KB
April 17 2024 17:19:35
root / linksafe
0644
hyperparser.py
12.58 KB
April 17 2024 17:19:35
root / linksafe
0644
idle.py
0.443 KB
April 17 2024 17:19:35
root / linksafe
0644
idle.pyw
0.557 KB
September 04 2021 03:49:41
root / linksafe
0644
iomenu.py
20.248 KB
April 17 2024 17:19:35
root / linksafe
0644
macosx.py
9.434 KB
April 17 2024 17:19:35
root / linksafe
0644
mainmenu.py
3.616 KB
April 17 2024 17:19:35
root / linksafe
0644
multicall.py
18.211 KB
April 17 2024 17:19:35
root / linksafe
0644
outwin.py
5.672 KB
April 17 2024 17:19:35
root / linksafe
0644
paragraph.py
6.999 KB
April 17 2024 17:19:35
root / linksafe
0644
parenmatch.py
7.035 KB
April 17 2024 17:19:35
root / linksafe
0644
pathbrowser.py
3.118 KB
April 17 2024 17:19:35
root / linksafe
0644
percolator.py
3.057 KB
April 17 2024 17:19:35
root / linksafe
0644
pyparse.py
19.646 KB
April 17 2024 17:19:35
root / linksafe
0644
pyshell.py
56.375 KB
April 17 2024 17:19:35
root / linksafe
0755
query.py
12.143 KB
April 17 2024 17:19:35
root / linksafe
0644
redirector.py
6.714 KB
April 17 2024 17:19:35
root / linksafe
0644
replace.py
7.326 KB
April 17 2024 17:19:35
root / linksafe
0644
rpc.py
20.642 KB
April 17 2024 17:19:35
root / linksafe
0644
rstrip.py
0.848 KB
April 17 2024 17:19:35
root / linksafe
0644
run.py
16.867 KB
April 17 2024 17:19:35
root / linksafe
0644
runscript.py
7.657 KB
April 17 2024 17:19:35
root / linksafe
0644
scrolledlist.py
4.354 KB
April 17 2024 17:19:35
root / linksafe
0644
search.py
3.09 KB
April 17 2024 17:19:35
root / linksafe
0644
searchbase.py
7.276 KB
April 17 2024 17:19:35
root / linksafe
0644
searchengine.py
7.297 KB
April 17 2024 17:19:35
root / linksafe
0644
squeezer.py
12.996 KB
April 17 2024 17:19:35
root / linksafe
0644
stackviewer.py
4.35 KB
April 17 2024 17:19:35
root / linksafe
0644
statusbar.py
1.407 KB
April 17 2024 17:19:35
root / linksafe
0644
textview.py
5.978 KB
April 17 2024 17:19:35
root / linksafe
0644
tooltip.py
6.334 KB
April 17 2024 17:19:35
root / linksafe
0644
tree.py
14.735 KB
April 17 2024 17:19:35
root / linksafe
0644
undo.py
10.788 KB
April 17 2024 17:19:35
root / linksafe
0644
window.py
2.527 KB
April 17 2024 17:19:35
root / linksafe
0644
zoomheight.py
1.309 KB
April 17 2024 17:19:35
root / linksafe
0644
zzdummy.py
0.938 KB
April 17 2024 17:19:35
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF