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/python27/lib64/python2.7/idlelib/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //opt/alt/python27/lib64/python2.7/idlelib/run.py
import sys
import linecache
import time
import socket
import traceback
import thread
import threading
import Queue

from idlelib import CallTips
from idlelib import AutoComplete

from idlelib import RemoteDebugger
from idlelib import RemoteObjectBrowser
from idlelib import StackViewer
from idlelib import rpc
from idlelib import PyShell
from idlelib import IOBinding

import __main__

LOCALHOST = '127.0.0.1'

import warnings

def idle_showwarning_subproc(
        message, category, filename, lineno, file=None, line=None):
    """Show Idle-format warning after replacing warnings.showwarning.

    The only difference is the formatter called.
    """
    if file is None:
        file = sys.stderr
    try:
        file.write(PyShell.idle_formatwarning(
                message, category, filename, lineno, line))
    except IOError:
        pass # the file (probably stderr) is invalid - this warning gets lost.

_warnings_showwarning = None

def capture_warnings(capture):
    "Replace warning.showwarning with idle_showwarning_subproc, or reverse."

    global _warnings_showwarning
    if capture:
        if _warnings_showwarning is None:
            _warnings_showwarning = warnings.showwarning
            warnings.showwarning = idle_showwarning_subproc
    else:
        if _warnings_showwarning is not None:
            warnings.showwarning = _warnings_showwarning
            _warnings_showwarning = None

capture_warnings(True)

# Thread shared globals: Establish a queue between a subthread (which handles
# the socket) and the main thread (which runs user code), plus global
# completion, exit and interruptable (the main thread) flags:

exit_now = False
quitting = False
interruptable = False

def main(del_exitfunc=False):
    """Start the Python execution server in a subprocess

    In the Python subprocess, RPCServer is instantiated with handlerclass
    MyHandler, which inherits register/unregister methods from RPCHandler via
    the mix-in class SocketIO.

    When the RPCServer 'server' is instantiated, the TCPServer initialization
    creates an instance of run.MyHandler and calls its handle() method.
    handle() instantiates a run.Executive object, passing it a reference to the
    MyHandler object.  That reference is saved as attribute rpchandler of the
    Executive instance.  The Executive methods have access to the reference and
    can pass it on to entities that they command
    (e.g. RemoteDebugger.Debugger.start_debugger()).  The latter, in turn, can
    call MyHandler(SocketIO) register/unregister methods via the reference to
    register and unregister themselves.

    """
    global exit_now
    global quitting
    global no_exitfunc
    no_exitfunc = del_exitfunc
    #time.sleep(15) # test subprocess not responding
    try:
        assert(len(sys.argv) > 1)
        port = int(sys.argv[-1])
    except:
        print>>sys.stderr, "IDLE Subprocess: no IP port passed in sys.argv."
        return

    capture_warnings(True)
    sys.argv[:] = [""]
    sockthread = threading.Thread(target=manage_socket,
                                  name='SockThread',
                                  args=((LOCALHOST, port),))
    sockthread.setDaemon(True)
    sockthread.start()
    while 1:
        try:
            if exit_now:
                try:
                    exit()
                except KeyboardInterrupt:
                    # exiting but got an extra KBI? Try again!
                    continue
            try:
                seq, request = rpc.request_queue.get(block=True, timeout=0.05)
            except Queue.Empty:
                continue
            method, args, kwargs = request
            ret = method(*args, **kwargs)
            rpc.response_queue.put((seq, ret))
        except KeyboardInterrupt:
            if quitting:
                exit_now = True
            continue
        except SystemExit:
            capture_warnings(False)
            raise
        except:
            type, value, tb = sys.exc_info()
            try:
                print_exception()
                rpc.response_queue.put((seq, None))
            except:
                # Link didn't work, print same exception to __stderr__
                traceback.print_exception(type, value, tb, file=sys.__stderr__)
                exit()
            else:
                continue

def manage_socket(address):
    for i in range(3):
        time.sleep(i)
        try:
            server = MyRPCServer(address, MyHandler)
            break
        except socket.error as err:
            print>>sys.__stderr__,"IDLE Subprocess: socket error: "\
                                        + err.args[1] + ", retrying...."
    else:
        print>>sys.__stderr__, "IDLE Subprocess: Connection to "\
                               "IDLE GUI failed, exiting."
        show_socket_error(err, address)
        global exit_now
        exit_now = True
        return
    server.handle_request() # A single request only

def show_socket_error(err, address):
    import Tkinter
    import tkMessageBox
    root = Tkinter.Tk()
    fix_scaling(root)
    root.withdraw()
    if err.args[0] == 61: # connection refused
        msg = "IDLE's subprocess can't connect to %s:%d.  This may be due "\
              "to your personal firewall configuration.  It is safe to "\
              "allow this internal connection because no data is visible on "\
              "external ports." % address
        tkMessageBox.showerror("IDLE Subprocess Error", msg, parent=root)
    else:
        tkMessageBox.showerror("IDLE Subprocess Error",
                               "Socket Error: %s" % err.args[1], parent=root)
    root.destroy()

def print_exception():
    import linecache
    linecache.checkcache()
    flush_stdout()
    efile = sys.stderr
    typ, val, tb = excinfo = sys.exc_info()
    sys.last_type, sys.last_value, sys.last_traceback = excinfo
    tbe = traceback.extract_tb(tb)
    print>>efile, '\nTraceback (most recent call last):'
    exclude = ("run.py", "rpc.py", "threading.py", "Queue.py",
               "RemoteDebugger.py", "bdb.py")
    cleanup_traceback(tbe, exclude)
    traceback.print_list(tbe, file=efile)
    lines = traceback.format_exception_only(typ, val)
    for line in lines:
        print>>efile, line,

def cleanup_traceback(tb, exclude):
    "Remove excluded traces from beginning/end of tb; get cached lines"
    orig_tb = tb[:]
    while tb:
        for rpcfile in exclude:
            if tb[0][0].count(rpcfile):
                break    # found an exclude, break for: and delete tb[0]
        else:
            break        # no excludes, have left RPC code, break while:
        del tb[0]
    while tb:
        for rpcfile in exclude:
            if tb[-1][0].count(rpcfile):
                break
        else:
            break
        del tb[-1]
    if len(tb) == 0:
        # exception was in IDLE internals, don't prune!
        tb[:] = orig_tb[:]
        print>>sys.stderr, "** IDLE Internal Exception: "
    rpchandler = rpc.objecttable['exec'].rpchandler
    for i in range(len(tb)):
        fn, ln, nm, line = tb[i]
        if nm == '?':
            nm = "-toplevel-"
        if fn.startswith("<pyshell#") and IOBinding.encoding != 'utf-8':
            ln -= 1  # correction for coding cookie
        if not line and fn.startswith("<pyshell#"):
            line = rpchandler.remotecall('linecache', 'getline',
                                              (fn, ln), {})
        tb[i] = fn, ln, nm, line

def flush_stdout():
    try:
        if sys.stdout.softspace:
            sys.stdout.softspace = 0
            sys.stdout.write("\n")
    except (AttributeError, EOFError):
        pass

def exit():
    """Exit subprocess, possibly after first deleting sys.exitfunc

    If config-main.cfg/.def 'General' 'delete-exitfunc' is True, then any
    sys.exitfunc will be removed before exiting.  (VPython support)

    """
    if no_exitfunc:
        try:
            del sys.exitfunc
        except AttributeError:
            pass
    capture_warnings(False)
    sys.exit(0)


def fix_scaling(root):
    """Scale fonts on HiDPI displays."""
    import tkFont
    scaling = float(root.tk.call('tk', 'scaling'))
    if scaling > 1.4:
        for name in tkFont.names(root):
            font = tkFont.Font(root=root, name=name, exists=True)
            size = int(font['size'])
            if size < 0:
                font['size'] = int(round(-0.75*size))


class MyRPCServer(rpc.RPCServer):

    def handle_error(self, request, client_address):
        """Override RPCServer method for IDLE

        Interrupt the MainThread and exit server if link is dropped.

        """
        global quitting
        try:
            raise
        except SystemExit:
            raise
        except EOFError:
            global exit_now
            exit_now = True
            thread.interrupt_main()
        except:
            erf = sys.__stderr__
            print>>erf, '\n' + '-'*40
            print>>erf, 'Unhandled server exception!'
            print>>erf, 'Thread: %s' % threading.currentThread().getName()
            print>>erf, 'Client Address: ', client_address
            print>>erf, 'Request: ', repr(request)
            traceback.print_exc(file=erf)
            print>>erf, '\n*** Unrecoverable, server exiting!'
            print>>erf, '-'*40
            quitting = True
            thread.interrupt_main()

class MyHandler(rpc.RPCHandler):

    def handle(self):
        """Override base method"""
        executive = Executive(self)
        self.register("exec", executive)
        self.console = self.get_remote_proxy("console")
        sys.stdin = PyShell.PseudoInputFile(self.console, "stdin",
                IOBinding.encoding)
        sys.stdout = PyShell.PseudoOutputFile(self.console, "stdout",
                IOBinding.encoding)
        sys.stderr = PyShell.PseudoOutputFile(self.console, "stderr",
                IOBinding.encoding)

        # Keep a reference to stdin so that it won't try to exit IDLE if
        # sys.stdin gets changed from within IDLE's shell. See issue17838.
        self._keep_stdin = sys.stdin

        self.interp = self.get_remote_proxy("interp")
        rpc.RPCHandler.getresponse(self, myseq=None, wait=0.05)

    def exithook(self):
        "override SocketIO method - wait for MainThread to shut us down"
        time.sleep(10)

    def EOFhook(self):
        "Override SocketIO method - terminate wait on callback and exit thread"
        global quitting
        quitting = True
        thread.interrupt_main()

    def decode_interrupthook(self):
        "interrupt awakened thread"
        global quitting
        quitting = True
        thread.interrupt_main()


class Executive(object):

    def __init__(self, rpchandler):
        self.rpchandler = rpchandler
        self.locals = __main__.__dict__
        self.calltip = CallTips.CallTips()
        self.autocomplete = AutoComplete.AutoComplete()

    def runcode(self, code):
        global interruptable
        try:
            self.usr_exc_info = None
            interruptable = True
            try:
                exec code in self.locals
            finally:
                interruptable = False
        except SystemExit:
            # Scripts that raise SystemExit should just
            # return to the interactive prompt
            pass
        except:
            self.usr_exc_info = sys.exc_info()
            if quitting:
                exit()
            print_exception()
            jit = self.rpchandler.console.getvar("<<toggle-jit-stack-viewer>>")
            if jit:
                self.rpchandler.interp.open_remote_stack_viewer()
        else:
            flush_stdout()

    def interrupt_the_server(self):
        if interruptable:
            thread.interrupt_main()

    def start_the_debugger(self, gui_adap_oid):
        return RemoteDebugger.start_debugger(self.rpchandler, gui_adap_oid)

    def stop_the_debugger(self, idb_adap_oid):
        "Unregister the Idb Adapter.  Link objects and Idb then subject to GC"
        self.rpchandler.unregister(idb_adap_oid)

    def get_the_calltip(self, name):
        return self.calltip.fetch_tip(name)

    def get_the_completion_list(self, what, mode):
        return self.autocomplete.fetch_completions(what, mode)

    def stackviewer(self, flist_oid=None):
        if self.usr_exc_info:
            typ, val, tb = self.usr_exc_info
        else:
            return None
        flist = None
        if flist_oid is not None:
            flist = self.rpchandler.get_remote_proxy(flist_oid)
        while tb and tb.tb_frame.f_globals["__name__"] in ["rpc", "run"]:
            tb = tb.tb_next
        sys.last_type = typ
        sys.last_value = val
        item = StackViewer.StackTreeItem(flist, tb)
        return RemoteObjectBrowser.remote_object_tree_item(item)

capture_warnings(False)  # Make sure turned off; see issue 18081
Name
Size
Permissions
Options
Icons
--
drwxr-xr-x
idle_test
--
drwxr-xr-x
AutoComplete.py
8.754 KB
-rw-r--r--
AutoComplete.pyc
7.989 KB
-rw-r--r--
AutoComplete.pyo
7.989 KB
-rw-r--r--
AutoCompleteWindow.py
16.912 KB
-rw-r--r--
AutoCompleteWindow.pyc
12.416 KB
-rw-r--r--
AutoCompleteWindow.pyo
12.358 KB
-rw-r--r--
AutoExpand.py
3.315 KB
-rw-r--r--
AutoExpand.pyc
3.496 KB
-rw-r--r--
AutoExpand.pyo
3.496 KB
-rw-r--r--
Bindings.py
2.906 KB
-rw-r--r--
Bindings.pyc
4.598 KB
-rw-r--r--
Bindings.pyo
4.598 KB
-rw-r--r--
CREDITS.txt
1.822 KB
-rw-r--r--
CallTipWindow.py
5.923 KB
-rw-r--r--
CallTipWindow.pyc
6.145 KB
-rw-r--r--
CallTipWindow.pyo
6.145 KB
-rw-r--r--
CallTips.py
7.559 KB
-rw-r--r--
CallTips.pyc
8.158 KB
-rw-r--r--
CallTips.pyo
8.158 KB
-rw-r--r--
ChangeLog
55.071 KB
-rw-r--r--
ClassBrowser.py
6.835 KB
-rw-r--r--
ClassBrowser.pyc
9.658 KB
-rw-r--r--
ClassBrowser.pyo
9.658 KB
-rw-r--r--
CodeContext.py
8.146 KB
-rw-r--r--
CodeContext.pyc
6.629 KB
-rw-r--r--
CodeContext.pyo
6.586 KB
-rw-r--r--
ColorDelegator.py
9.533 KB
-rw-r--r--
ColorDelegator.pyc
8.905 KB
-rw-r--r--
ColorDelegator.pyo
8.905 KB
-rw-r--r--
Debugger.py
17.809 KB
-rw-r--r--
Debugger.pyc
17.719 KB
-rw-r--r--
Debugger.pyo
17.719 KB
-rw-r--r--
Delegator.py
0.649 KB
-rw-r--r--
Delegator.pyc
1.314 KB
-rw-r--r--
Delegator.pyo
1.314 KB
-rw-r--r--
EditorWindow.py
63.963 KB
-rw-r--r--
EditorWindow.pyc
57.15 KB
-rw-r--r--
EditorWindow.pyo
57.051 KB
-rw-r--r--
FileList.py
3.631 KB
-rw-r--r--
FileList.pyc
4.07 KB
-rw-r--r--
FileList.pyo
4.038 KB
-rw-r--r--
FormatParagraph.py
7.116 KB
-rw-r--r--
FormatParagraph.pyc
7.14 KB
-rw-r--r--
FormatParagraph.pyo
7.14 KB
-rw-r--r--
GrepDialog.py
5.024 KB
-rw-r--r--
GrepDialog.pyc
6.452 KB
-rw-r--r--
GrepDialog.pyo
6.452 KB
-rw-r--r--
HISTORY.txt
10.075 KB
-rw-r--r--
HyperParser.py
10.251 KB
-rw-r--r--
HyperParser.pyc
6.644 KB
-rw-r--r--
HyperParser.pyo
6.644 KB
-rw-r--r--
IOBinding.py
21.397 KB
-rw-r--r--
IOBinding.pyc
18.621 KB
-rw-r--r--
IOBinding.pyo
18.621 KB
-rw-r--r--
IdleHistory.py
3.957 KB
-rw-r--r--
IdleHistory.pyc
4.054 KB
-rw-r--r--
IdleHistory.pyo
4.054 KB
-rw-r--r--
MultiCall.py
17.286 KB
-rw-r--r--
MultiCall.pyc
16.399 KB
-rw-r--r--
MultiCall.pyo
16.327 KB
-rw-r--r--
MultiStatusBar.py
1.316 KB
-rw-r--r--
MultiStatusBar.pyc
2.302 KB
-rw-r--r--
MultiStatusBar.pyo
2.302 KB
-rw-r--r--
NEWS.txt
46.14 KB
-rw-r--r--
ObjectBrowser.py
4.273 KB
-rw-r--r--
ObjectBrowser.pyc
7.257 KB
-rw-r--r--
ObjectBrowser.pyo
7.257 KB
-rw-r--r--
OutputWindow.py
4.469 KB
-rw-r--r--
OutputWindow.pyc
5.3 KB
-rw-r--r--
OutputWindow.pyo
5.3 KB
-rw-r--r--
ParenMatch.py
6.557 KB
-rw-r--r--
ParenMatch.pyc
7.178 KB
-rw-r--r--
ParenMatch.pyo
7.178 KB
-rw-r--r--
PathBrowser.py
2.938 KB
-rw-r--r--
PathBrowser.pyc
4.571 KB
-rw-r--r--
PathBrowser.pyo
4.571 KB
-rw-r--r--
Percolator.py
3.146 KB
-rw-r--r--
Percolator.pyc
4.69 KB
-rw-r--r--
Percolator.pyo
4.511 KB
-rw-r--r--
PyParse.py
19.053 KB
-rw-r--r--
PyParse.pyc
9.986 KB
-rw-r--r--
PyParse.pyo
9.559 KB
-rw-r--r--
PyShell.py
57.492 KB
-rwxr-xr-x
PyShell.pyc
52.997 KB
-rw-r--r--
PyShell.pyo
52.897 KB
-rw-r--r--
README.txt
7.705 KB
-rw-r--r--
RemoteDebugger.py
11.359 KB
-rw-r--r--
RemoteDebugger.pyc
16.729 KB
-rw-r--r--
RemoteDebugger.pyo
16.579 KB
-rw-r--r--
RemoteObjectBrowser.py
0.92 KB
-rw-r--r--
RemoteObjectBrowser.pyc
2.227 KB
-rw-r--r--
RemoteObjectBrowser.pyo
2.227 KB
-rw-r--r--
ReplaceDialog.py
6.483 KB
-rw-r--r--
ReplaceDialog.pyc
7.828 KB
-rw-r--r--
ReplaceDialog.pyo
7.828 KB
-rw-r--r--
RstripExtension.py
1.025 KB
-rw-r--r--
RstripExtension.pyc
1.626 KB
-rw-r--r--
RstripExtension.pyo
1.626 KB
-rw-r--r--
ScriptBinding.py
8.261 KB
-rw-r--r--
ScriptBinding.pyc
8.174 KB
-rw-r--r--
ScriptBinding.pyo
8.174 KB
-rw-r--r--
ScrolledList.py
4.271 KB
-rw-r--r--
ScrolledList.pyc
6.609 KB
-rw-r--r--
ScrolledList.pyo
6.609 KB
-rw-r--r--
SearchDialog.py
2.568 KB
-rw-r--r--
SearchDialog.pyc
4.042 KB
-rw-r--r--
SearchDialog.pyo
4.042 KB
-rw-r--r--
SearchDialogBase.py
6.928 KB
-rw-r--r--
SearchDialogBase.pyc
8.429 KB
-rw-r--r--
SearchDialogBase.pyo
8.429 KB
-rw-r--r--
SearchEngine.py
7.288 KB
-rw-r--r--
SearchEngine.pyc
8.374 KB
-rw-r--r--
SearchEngine.pyo
8.374 KB
-rw-r--r--
StackViewer.py
4.327 KB
-rw-r--r--
StackViewer.pyc
6.521 KB
-rw-r--r--
StackViewer.pyo
6.521 KB
-rw-r--r--
TODO.txt
8.279 KB
-rw-r--r--
ToolTip.py
3.099 KB
-rw-r--r--
ToolTip.pyc
4.775 KB
-rw-r--r--
ToolTip.pyo
4.775 KB
-rw-r--r--
TreeWidget.py
14.685 KB
-rw-r--r--
TreeWidget.pyc
17.952 KB
-rw-r--r--
TreeWidget.pyo
17.952 KB
-rw-r--r--
UndoDelegator.py
10.534 KB
-rw-r--r--
UndoDelegator.pyc
13.885 KB
-rw-r--r--
UndoDelegator.pyo
13.885 KB
-rw-r--r--
WidgetRedirector.py
6.744 KB
-rw-r--r--
WidgetRedirector.pyc
7.765 KB
-rw-r--r--
WidgetRedirector.pyo
7.765 KB
-rw-r--r--
WindowList.py
2.415 KB
-rw-r--r--
WindowList.pyc
3.741 KB
-rw-r--r--
WindowList.pyo
3.741 KB
-rw-r--r--
ZoomHeight.py
1.27 KB
-rw-r--r--
ZoomHeight.pyc
1.671 KB
-rw-r--r--
ZoomHeight.pyo
1.671 KB
-rw-r--r--
__init__.py
0.281 KB
-rw-r--r--
__init__.pyc
0.434 KB
-rw-r--r--
__init__.pyo
0.434 KB
-rw-r--r--
aboutDialog.py
6.85 KB
-rw-r--r--
aboutDialog.pyc
6.853 KB
-rw-r--r--
aboutDialog.pyo
6.853 KB
-rw-r--r--
config-extensions.def
2.896 KB
-rw-r--r--
config-highlight.def
2.456 KB
-rw-r--r--
config-keys.def
7.595 KB
-rw-r--r--
config-main.def
2.501 KB
-rw-r--r--
configDialog.py
64.412 KB
-rw-r--r--
configDialog.pyc
53.159 KB
-rw-r--r--
configDialog.pyo
53.159 KB
-rw-r--r--
configHandler.py
31.724 KB
-rw-r--r--
configHandler.pyc
29.282 KB
-rw-r--r--
configHandler.pyo
29.282 KB
-rw-r--r--
configHelpSourceEdit.py
6.529 KB
-rw-r--r--
configHelpSourceEdit.pyc
6.555 KB
-rw-r--r--
configHelpSourceEdit.pyo
6.555 KB
-rw-r--r--
configSectionNameDialog.py
3.945 KB
-rw-r--r--
configSectionNameDialog.pyc
4.404 KB
-rw-r--r--
configSectionNameDialog.pyo
4.404 KB
-rw-r--r--
dynOptionMenuWidget.py
1.938 KB
-rw-r--r--
dynOptionMenuWidget.pyc
2.801 KB
-rw-r--r--
dynOptionMenuWidget.pyo
2.801 KB
-rw-r--r--
extend.txt
3.557 KB
-rw-r--r--
help.html
41.42 KB
-rw-r--r--
help.py
10.776 KB
-rw-r--r--
help.pyc
12.249 KB
-rw-r--r--
help.pyo
12.249 KB
-rw-r--r--
help.txt
11.859 KB
-rw-r--r--
idle.py
0.442 KB
-rw-r--r--
idle.pyc
0.413 KB
-rw-r--r--
idle.pyo
0.413 KB
-rw-r--r--
idle.pyw
0.55 KB
-rw-r--r--
idlever.py
0.405 KB
-rw-r--r--
idlever.pyc
0.577 KB
-rw-r--r--
idlever.pyo
0.577 KB
-rw-r--r--
keybindingDialog.py
12.176 KB
-rw-r--r--
keybindingDialog.pyc
12.078 KB
-rw-r--r--
keybindingDialog.pyo
12.078 KB
-rw-r--r--
macosxSupport.py
8.237 KB
-rw-r--r--
macosxSupport.pyc
8.384 KB
-rw-r--r--
macosxSupport.pyo
8.249 KB
-rw-r--r--
rpc.py
19.678 KB
-rw-r--r--
rpc.pyc
21.968 KB
-rw-r--r--
rpc.pyo
21.864 KB
-rw-r--r--
run.py
12.614 KB
-rw-r--r--
run.pyc
13.447 KB
-rw-r--r--
run.pyo
13.391 KB
-rw-r--r--
tabbedpages.py
18.007 KB
-rw-r--r--
tabbedpages.pyc
18.634 KB
-rw-r--r--
tabbedpages.pyo
18.634 KB
-rw-r--r--
textView.py
3.438 KB
-rw-r--r--
textView.pyc
4.02 KB
-rw-r--r--
textView.pyo
4.02 KB
-rw-r--r--