404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.140.188.195: ~ $
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

Filemanager

Name Type Size Permission Actions
Icons Folder 0755
idle_test Folder 0755
AutoComplete.py File 8.75 KB 0644
AutoComplete.pyc File 7.99 KB 0644
AutoComplete.pyo File 7.99 KB 0644
AutoCompleteWindow.py File 16.91 KB 0644
AutoCompleteWindow.pyc File 12.42 KB 0644
AutoCompleteWindow.pyo File 12.36 KB 0644
AutoExpand.py File 3.32 KB 0644
AutoExpand.pyc File 3.5 KB 0644
AutoExpand.pyo File 3.5 KB 0644
Bindings.py File 2.91 KB 0644
Bindings.pyc File 4.6 KB 0644
Bindings.pyo File 4.6 KB 0644
CREDITS.txt File 1.82 KB 0644
CallTipWindow.py File 5.92 KB 0644
CallTipWindow.pyc File 6.14 KB 0644
CallTipWindow.pyo File 6.14 KB 0644
CallTips.py File 7.56 KB 0644
CallTips.pyc File 8.16 KB 0644
CallTips.pyo File 8.16 KB 0644
ChangeLog File 55.07 KB 0644
ClassBrowser.py File 6.83 KB 0644
ClassBrowser.pyc File 9.66 KB 0644
ClassBrowser.pyo File 9.66 KB 0644
CodeContext.py File 8.15 KB 0644
CodeContext.pyc File 6.63 KB 0644
CodeContext.pyo File 6.59 KB 0644
ColorDelegator.py File 9.53 KB 0644
ColorDelegator.pyc File 8.91 KB 0644
ColorDelegator.pyo File 8.91 KB 0644
Debugger.py File 17.81 KB 0644
Debugger.pyc File 17.72 KB 0644
Debugger.pyo File 17.72 KB 0644
Delegator.py File 665 B 0644
Delegator.pyc File 1.31 KB 0644
Delegator.pyo File 1.31 KB 0644
EditorWindow.py File 63.96 KB 0644
EditorWindow.pyc File 57.15 KB 0644
EditorWindow.pyo File 57.05 KB 0644
FileList.py File 3.63 KB 0644
FileList.pyc File 4.07 KB 0644
FileList.pyo File 4.04 KB 0644
FormatParagraph.py File 7.12 KB 0644
FormatParagraph.pyc File 7.14 KB 0644
FormatParagraph.pyo File 7.14 KB 0644
GrepDialog.py File 5.02 KB 0644
GrepDialog.pyc File 6.45 KB 0644
GrepDialog.pyo File 6.45 KB 0644
HISTORY.txt File 10.08 KB 0644
HyperParser.py File 10.25 KB 0644
HyperParser.pyc File 6.64 KB 0644
HyperParser.pyo File 6.64 KB 0644
IOBinding.py File 21.4 KB 0644
IOBinding.pyc File 18.62 KB 0644
IOBinding.pyo File 18.62 KB 0644
IdleHistory.py File 3.96 KB 0644
IdleHistory.pyc File 4.05 KB 0644
IdleHistory.pyo File 4.05 KB 0644
MultiCall.py File 17.29 KB 0644
MultiCall.pyc File 16.4 KB 0644
MultiCall.pyo File 16.33 KB 0644
MultiStatusBar.py File 1.32 KB 0644
MultiStatusBar.pyc File 2.3 KB 0644
MultiStatusBar.pyo File 2.3 KB 0644
NEWS.txt File 46.14 KB 0644
ObjectBrowser.py File 4.27 KB 0644
ObjectBrowser.pyc File 7.26 KB 0644
ObjectBrowser.pyo File 7.26 KB 0644
OutputWindow.py File 4.47 KB 0644
OutputWindow.pyc File 5.3 KB 0644
OutputWindow.pyo File 5.3 KB 0644
ParenMatch.py File 6.56 KB 0644
ParenMatch.pyc File 7.18 KB 0644
ParenMatch.pyo File 7.18 KB 0644
PathBrowser.py File 2.94 KB 0644
PathBrowser.pyc File 4.57 KB 0644
PathBrowser.pyo File 4.57 KB 0644
Percolator.py File 3.15 KB 0644
Percolator.pyc File 4.69 KB 0644
Percolator.pyo File 4.51 KB 0644
PyParse.py File 19.05 KB 0644
PyParse.pyc File 9.99 KB 0644
PyParse.pyo File 9.56 KB 0644
PyShell.py File 57.48 KB 0755
PyShell.pyc File 53 KB 0644
PyShell.pyo File 52.9 KB 0644
README.txt File 7.71 KB 0644
RemoteDebugger.py File 11.36 KB 0644
RemoteDebugger.pyc File 16.73 KB 0644
RemoteDebugger.pyo File 16.58 KB 0644
RemoteObjectBrowser.py File 942 B 0644
RemoteObjectBrowser.pyc File 2.23 KB 0644
RemoteObjectBrowser.pyo File 2.23 KB 0644
ReplaceDialog.py File 6.48 KB 0644
ReplaceDialog.pyc File 7.83 KB 0644
ReplaceDialog.pyo File 7.83 KB 0644
RstripExtension.py File 1.03 KB 0644
RstripExtension.pyc File 1.63 KB 0644
RstripExtension.pyo File 1.63 KB 0644
ScriptBinding.py File 8.26 KB 0644
ScriptBinding.pyc File 8.17 KB 0644
ScriptBinding.pyo File 8.17 KB 0644
ScrolledList.py File 4.27 KB 0644
ScrolledList.pyc File 6.61 KB 0644
ScrolledList.pyo File 6.61 KB 0644
SearchDialog.py File 2.57 KB 0644
SearchDialog.pyc File 4.04 KB 0644
SearchDialog.pyo File 4.04 KB 0644
SearchDialogBase.py File 6.93 KB 0644
SearchDialogBase.pyc File 8.43 KB 0644
SearchDialogBase.pyo File 8.43 KB 0644
SearchEngine.py File 7.29 KB 0644
SearchEngine.pyc File 8.37 KB 0644
SearchEngine.pyo File 8.37 KB 0644
StackViewer.py File 4.33 KB 0644
StackViewer.pyc File 6.52 KB 0644
StackViewer.pyo File 6.52 KB 0644
TODO.txt File 8.28 KB 0644
ToolTip.py File 3.1 KB 0644
ToolTip.pyc File 4.78 KB 0644
ToolTip.pyo File 4.78 KB 0644
TreeWidget.py File 14.68 KB 0644
TreeWidget.pyc File 17.95 KB 0644
TreeWidget.pyo File 17.95 KB 0644
UndoDelegator.py File 10.53 KB 0644
UndoDelegator.pyc File 13.88 KB 0644
UndoDelegator.pyo File 13.88 KB 0644
WidgetRedirector.py File 6.74 KB 0644
WidgetRedirector.pyc File 7.76 KB 0644
WidgetRedirector.pyo File 7.76 KB 0644
WindowList.py File 2.42 KB 0644
WindowList.pyc File 3.74 KB 0644
WindowList.pyo File 3.74 KB 0644
ZoomHeight.py File 1.27 KB 0644
ZoomHeight.pyc File 1.67 KB 0644
ZoomHeight.pyo File 1.67 KB 0644
__init__.py File 288 B 0644
__init__.pyc File 444 B 0644
__init__.pyo File 444 B 0644
aboutDialog.py File 6.85 KB 0644
aboutDialog.pyc File 6.85 KB 0644
aboutDialog.pyo File 6.85 KB 0644
config-extensions.def File 2.9 KB 0644
config-highlight.def File 2.46 KB 0644
config-keys.def File 7.59 KB 0644
config-main.def File 2.5 KB 0644
configDialog.py File 64.41 KB 0644
configDialog.pyc File 53.16 KB 0644
configDialog.pyo File 53.16 KB 0644
configHandler.py File 31.72 KB 0644
configHandler.pyc File 29.28 KB 0644
configHandler.pyo File 29.28 KB 0644
configHelpSourceEdit.py File 6.53 KB 0644
configHelpSourceEdit.pyc File 6.55 KB 0644
configHelpSourceEdit.pyo File 6.55 KB 0644
configSectionNameDialog.py File 3.95 KB 0644
configSectionNameDialog.pyc File 4.4 KB 0644
configSectionNameDialog.pyo File 4.4 KB 0644
dynOptionMenuWidget.py File 1.94 KB 0644
dynOptionMenuWidget.pyc File 2.8 KB 0644
dynOptionMenuWidget.pyo File 2.8 KB 0644
extend.txt File 3.56 KB 0644
help.html File 41.42 KB 0644
help.py File 10.78 KB 0644
help.pyc File 12.25 KB 0644
help.pyo File 12.25 KB 0644
help.txt File 11.86 KB 0644
idle.py File 453 B 0644
idle.pyc File 423 B 0644
idle.pyo File 423 B 0644
idle.pyw File 563 B 0644
idlever.py File 415 B 0644
idlever.pyc File 591 B 0644
idlever.pyo File 591 B 0644
keybindingDialog.py File 12.18 KB 0644
keybindingDialog.pyc File 12.08 KB 0644
keybindingDialog.pyo File 12.08 KB 0644
macosxSupport.py File 8.24 KB 0644
macosxSupport.pyc File 8.38 KB 0644
macosxSupport.pyo File 8.25 KB 0644
rpc.py File 19.68 KB 0644
rpc.pyc File 21.97 KB 0644
rpc.pyo File 21.86 KB 0644
run.py File 12.61 KB 0644
run.pyc File 13.45 KB 0644
run.pyo File 13.39 KB 0644
tabbedpages.py File 18.01 KB 0644
tabbedpages.pyc File 18.63 KB 0644
tabbedpages.pyo File 18.63 KB 0644
textView.py File 3.44 KB 0644
textView.pyc File 4.02 KB 0644
textView.pyo File 4.02 KB 0644