Psyduck - 可達鴨 之 鴨力山大2


Server : LiteSpeed
System : Linux premium217.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User : alloknri ( 880)
PHP Version : 8.1.34
Disable Function : NONE
Directory :  /opt/alt/python36/lib64/python3.6/idlelib/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python36/lib64/python3.6/idlelib/outwin.py
"""Editor window that can serve as an output file.
"""

import re

from tkinter import messagebox

from idlelib.editor import EditorWindow
from idlelib import iomenu


file_line_pats = [
    # order of patterns matters
    r'file "([^"]*)", line (\d+)',
    r'([^\s]+)\((\d+)\)',
    r'^(\s*\S.*?):\s*(\d+):',  # Win filename, maybe starting with spaces
    r'([^\s]+):\s*(\d+):',     # filename or path, ltrim
    r'^\s*(\S.*?):\s*(\d+):',  # Win abs path with embedded spaces, ltrim
]

file_line_progs = None


def compile_progs():
    "Compile the patterns for matching to file name and line number."
    global file_line_progs
    file_line_progs = [re.compile(pat, re.IGNORECASE)
                       for pat in file_line_pats]


def file_line_helper(line):
    """Extract file name and line number from line of text.

    Check if line of text contains one of the file/line patterns.
    If it does and if the file and line are valid, return
    a tuple of the file name and line number.  If it doesn't match
    or if the file or line is invalid, return None.
    """
    if not file_line_progs:
        compile_progs()
    for prog in file_line_progs:
        match = prog.search(line)
        if match:
            filename, lineno = match.group(1, 2)
            try:
                f = open(filename, "r")
                f.close()
                break
            except OSError:
                continue
    else:
        return None
    try:
        return filename, int(lineno)
    except TypeError:
        return None


class OutputWindow(EditorWindow):
    """An editor window that can serve as an output file.

    Also the future base class for the Python shell window.
    This class has no input facilities.

    Adds binding to open a file at a line to the text widget.
    """

    # Our own right-button menu
    rmenu_specs = [
        ("Cut", "<<cut>>", "rmenu_check_cut"),
        ("Copy", "<<copy>>", "rmenu_check_copy"),
        ("Paste", "<<paste>>", "rmenu_check_paste"),
        (None, None, None),
        ("Go to file/line", "<<goto-file-line>>", None),
    ]

    def __init__(self, *args):
        EditorWindow.__init__(self, *args)
        self.text.bind("<<goto-file-line>>", self.goto_file_line)
        self.text.unbind("<<toggle-code-context>>")

    # Customize EditorWindow
    def ispythonsource(self, filename):
        "Python source is only part of output: do not colorize."
        return False

    def short_title(self):
        "Customize EditorWindow title."
        return "Output"

    def maybesave(self):
        "Customize EditorWindow to not display save file messagebox."
        return 'yes' if self.get_saved() else 'no'

    # Act as output file
    def write(self, s, tags=(), mark="insert"):
        """Write text to text widget.

        The text is inserted at the given index with the provided
        tags.  The text widget is then scrolled to make it visible
        and updated to display it, giving the effect of seeing each
        line as it is added.

        Args:
            s: Text to insert into text widget.
            tags: Tuple of tag strings to apply on the insert.
            mark: Index for the insert.

        Return:
            Length of text inserted.
        """
        if isinstance(s, bytes):
            s = s.decode(iomenu.encoding, "replace")
        self.text.insert(mark, s, tags)
        self.text.see(mark)
        self.text.update()
        return len(s)

    def writelines(self, lines):
        "Write each item in lines iterable."
        for line in lines:
            self.write(line)

    def flush(self):
        "No flushing needed as write() directly writes to widget."
        pass

    def showerror(self, *args, **kwargs):
        messagebox.showerror(*args, **kwargs)

    def goto_file_line(self, event=None):
        """Handle request to open file/line.

        If the selected or previous line in the output window
        contains a file name and line number, then open that file
        name in a new window and position on the line number.

        Otherwise, display an error messagebox.
        """
        line = self.text.get("insert linestart", "insert lineend")
        result = file_line_helper(line)
        if not result:
            # Try the previous line.  This is handy e.g. in tracebacks,
            # where you tend to right-click on the displayed source line
            line = self.text.get("insert -1line linestart",
                                 "insert -1line lineend")
            result = file_line_helper(line)
            if not result:
                self.showerror(
                    "No special line",
                    "The line you point at doesn't look like "
                    "a valid file name followed by a line number.",
                    parent=self.text)
                return
        filename, lineno = result
        self.flist.gotofileline(filename, lineno)


# These classes are currently not used but might come in handy
class OnDemandOutputWindow:

    tagdefs = {
        # XXX Should use IdlePrefs.ColorPrefs
        "stdout":  {"foreground": "blue"},
        "stderr":  {"foreground": "#007700"},
    }

    def __init__(self, flist):
        self.flist = flist
        self.owin = None

    def write(self, s, tags, mark):
        if not self.owin:
            self.setup()
        self.owin.write(s, tags, mark)

    def setup(self):
        self.owin = owin = OutputWindow(self.flist)
        text = owin.text
        for tag, cnf in self.tagdefs.items():
            if cnf:
                text.tag_configure(tag, **cnf)
        text.tag_raise('sel')
        self.write = self.owin.write

if __name__ == '__main__':
    from unittest import main
    main('idlelib.idle_test.test_outwin', verbosity=2, exit=False)
Name
Size
Permissions
Options
Icons
--
drwxr-xr-x
__pycache__
--
drwxr-xr-x
idle_test
--
drwxr-xr-x
CREDITS.txt
1.822 KB
-rw-r--r--
ChangeLog
55.039 KB
-rw-r--r--
HISTORY.txt
10.07 KB
-rw-r--r--
NEWS.txt
38.905 KB
-rw-r--r--
NEWS2x.txt
26.535 KB
-rw-r--r--
README.txt
9.367 KB
-rw-r--r--
TODO.txt
8.279 KB
-rw-r--r--
__init__.py
0.387 KB
-rw-r--r--
__main__.py
0.155 KB
-rw-r--r--
_pyclbr.py
14.843 KB
-rw-r--r--
autocomplete.py
9.105 KB
-rw-r--r--
autocomplete_w.py
19.364 KB
-rw-r--r--
autoexpand.py
3.141 KB
-rw-r--r--
browser.py
8.087 KB
-rw-r--r--
calltip.py
5.925 KB
-rw-r--r--
calltip_w.py
6.944 KB
-rw-r--r--
codecontext.py
10.244 KB
-rw-r--r--
colorizer.py
11.011 KB
-rw-r--r--
config-extensions.def
2.213 KB
-rw-r--r--
config-highlight.def
2.624 KB
-rw-r--r--
config-keys.def
10.522 KB
-rw-r--r--
config-main.def
3.055 KB
-rw-r--r--
config.py
37.967 KB
-rw-r--r--
config_key.py
13.094 KB
-rw-r--r--
configdialog.py
98.688 KB
-rw-r--r--
debugger.py
18.649 KB
-rw-r--r--
debugger_r.py
11.855 KB
-rw-r--r--
debugobj.py
3.96 KB
-rw-r--r--
debugobj_r.py
1.057 KB
-rw-r--r--
delegator.py
1.019 KB
-rw-r--r--
dynoption.py
1.97 KB
-rw-r--r--
editor.py
65.698 KB
-rw-r--r--
extend.txt
3.557 KB
-rw-r--r--
filelist.py
3.805 KB
-rw-r--r--
grep.py
6.584 KB
-rw-r--r--
help.html
53.822 KB
-rw-r--r--
help.py
11.06 KB
-rw-r--r--
help_about.py
8.771 KB
-rw-r--r--
history.py
3.948 KB
-rw-r--r--
hyperparser.py
12.58 KB
-rw-r--r--
idle.py
0.443 KB
-rw-r--r--
idle.pyw
0.557 KB
-rw-r--r--
iomenu.py
20.248 KB
-rw-r--r--
macosx.py
9.434 KB
-rw-r--r--
mainmenu.py
3.616 KB
-rw-r--r--
multicall.py
18.211 KB
-rw-r--r--
outwin.py
5.672 KB
-rw-r--r--
paragraph.py
6.999 KB
-rw-r--r--
parenmatch.py
7.035 KB
-rw-r--r--
pathbrowser.py
3.118 KB
-rw-r--r--
percolator.py
3.057 KB
-rw-r--r--
pyparse.py
19.646 KB
-rw-r--r--
pyshell.py
56.375 KB
-rwxr-xr-x
query.py
12.143 KB
-rw-r--r--
redirector.py
6.714 KB
-rw-r--r--
replace.py
7.326 KB
-rw-r--r--
rpc.py
20.642 KB
-rw-r--r--
rstrip.py
0.848 KB
-rw-r--r--
run.py
16.867 KB
-rw-r--r--
runscript.py
7.657 KB
-rw-r--r--
scrolledlist.py
4.354 KB
-rw-r--r--
search.py
3.09 KB
-rw-r--r--
searchbase.py
7.276 KB
-rw-r--r--
searchengine.py
7.297 KB
-rw-r--r--
squeezer.py
12.996 KB
-rw-r--r--
stackviewer.py
4.35 KB
-rw-r--r--
statusbar.py
1.407 KB
-rw-r--r--
textview.py
5.978 KB
-rw-r--r--
tooltip.py
6.334 KB
-rw-r--r--
tree.py
14.735 KB
-rw-r--r--
undo.py
10.788 KB
-rw-r--r--
window.py
2.527 KB
-rw-r--r--
zoomheight.py
1.309 KB
-rw-r--r--
zzdummy.py
0.938 KB
-rw-r--r--