lib64
/
python3.6
/
Go to Home Directory
+
Upload
Create File
root@0UT1S:~$
Execute
By Order of Mr.0UT1S
[DIR] ..
N/A
[DIR] __pycache__
N/A
[DIR] asyncio
N/A
[DIR] collections
N/A
[DIR] concurrent
N/A
[DIR] config-3.6m-x86_64-linux-gnu
N/A
[DIR] ctypes
N/A
[DIR] curses
N/A
[DIR] dbm
N/A
[DIR] distutils
N/A
[DIR] email
N/A
[DIR] encodings
N/A
[DIR] ensurepip
N/A
[DIR] html
N/A
[DIR] http
N/A
[DIR] importlib
N/A
[DIR] json
N/A
[DIR] lib-dynload
N/A
[DIR] lib2to3
N/A
[DIR] logging
N/A
[DIR] multiprocessing
N/A
[DIR] pydoc_data
N/A
[DIR] site-packages
N/A
[DIR] sqlite3
N/A
[DIR] test
N/A
[DIR] unittest
N/A
[DIR] urllib
N/A
[DIR] venv
N/A
[DIR] wsgiref
N/A
[DIR] xml
N/A
[DIR] xmlrpc
N/A
__future__.py
4.73 KB
Rename
Delete
__phello__.foo.py
64 bytes
Rename
Delete
_bootlocale.py
1.27 KB
Rename
Delete
_collections_abc.py
25.77 KB
Rename
Delete
_compat_pickle.py
8.54 KB
Rename
Delete
_compression.py
5.21 KB
Rename
Delete
_dummy_thread.py
5.00 KB
Rename
Delete
_markupbase.py
14.26 KB
Rename
Delete
_osx_support.py
18.69 KB
Rename
Delete
_pydecimal.py
224.83 KB
Rename
Delete
_pyio.py
86.03 KB
Rename
Delete
_sitebuiltins.py
3.04 KB
Rename
Delete
_strptime.py
24.17 KB
Rename
Delete
_sysconfigdata_dm_linux_x86_64-linux-gnu.py
29.48 KB
Rename
Delete
_sysconfigdata_m_linux_x86_64-linux-gnu.py
29.66 KB
Rename
Delete
_threading_local.py
7.04 KB
Rename
Delete
_weakrefset.py
5.57 KB
Rename
Delete
abc.py
8.52 KB
Rename
Delete
aifc.py
31.69 KB
Rename
Delete
antigravity.py
477 bytes
Rename
Delete
argparse.py
88.25 KB
Rename
Delete
ast.py
11.88 KB
Rename
Delete
asynchat.py
11.06 KB
Rename
Delete
asyncore.py
19.69 KB
Rename
Delete
base64.py
19.91 KB
Rename
Delete
bdb.py
23.00 KB
Rename
Delete
binhex.py
13.63 KB
Rename
Delete
bisect.py
2.53 KB
Rename
Delete
bz2.py
12.19 KB
Rename
Delete
cProfile.py
5.25 KB
Rename
Delete
calendar.py
22.67 KB
Rename
Delete
cgi.py
36.35 KB
Rename
Delete
cgitb.py
11.74 KB
Rename
Delete
chunk.py
5.30 KB
Rename
Delete
cmd.py
14.51 KB
Rename
Delete
code.py
10.37 KB
Rename
Delete
codecs.py
35.43 KB
Rename
Delete
codeop.py
5.85 KB
Rename
Delete
colorsys.py
3.97 KB
Rename
Delete
compileall.py
11.84 KB
Rename
Delete
configparser.py
52.34 KB
Rename
Delete
contextlib.py
12.85 KB
Rename
Delete
copy.py
8.61 KB
Rename
Delete
copyreg.py
6.84 KB
Rename
Delete
crypt.py
1.82 KB
Rename
Delete
csv.py
15.80 KB
Rename
Delete
datetime.py
80.11 KB
Rename
Delete
decimal.py
320 bytes
Rename
Delete
difflib.py
82.40 KB
Rename
Delete
dis.py
17.71 KB
Rename
Delete
doctest.py
101.94 KB
Rename
Delete
dummy_threading.py
2.75 KB
Rename
Delete
enum.py
32.82 KB
Rename
Delete
filecmp.py
9.60 KB
Rename
Delete
fileinput.py
14.13 KB
Rename
Delete
fnmatch.py
3.09 KB
Rename
Delete
formatter.py
14.79 KB
Rename
Delete
fractions.py
23.08 KB
Rename
Delete
ftplib.py
34.78 KB
Rename
Delete
functools.py
30.61 KB
Rename
Delete
genericpath.py
4.64 KB
Rename
Delete
getopt.py
7.31 KB
Rename
Delete
getpass.py
5.85 KB
Rename
Delete
gettext.py
21.03 KB
Rename
Delete
glob.py
5.51 KB
Rename
Delete
gzip.py
19.86 KB
Rename
Delete
hashlib.py
8.59 KB
Rename
Delete
heapq.py
22.39 KB
Rename
Delete
hmac.py
6.23 KB
Rename
Delete
imaplib.py
52.05 KB
Rename
Delete
imghdr.py
3.71 KB
Rename
Delete
imp.py
10.42 KB
Rename
Delete
inspect.py
114.22 KB
Rename
Delete
io.py
3.43 KB
Rename
Delete
ipaddress.py
75.99 KB
Rename
Delete
keyword.py
2.17 KB
Rename
Delete
linecache.py
5.19 KB
Rename
Delete
locale.py
75.49 KB
Rename
Delete
lzma.py
12.68 KB
Rename
Delete
macpath.py
5.83 KB
Rename
Delete
macurl2path.py
2.67 KB
Rename
Delete
mailbox.py
76.78 KB
Rename
Delete
mailcap.py
8.85 KB
Rename
Delete
mimetypes.py
20.55 KB
Rename
Delete
modulefinder.py
22.49 KB
Rename
Delete
netrc.py
5.55 KB
Rename
Delete
nntplib.py
42.07 KB
Rename
Delete
ntpath.py
22.55 KB
Rename
Delete
nturl2path.py
2.39 KB
Rename
Delete
numbers.py
10.00 KB
Rename
Delete
opcode.py
5.69 KB
Rename
Delete
operator.py
10.61 KB
Rename
Delete
optparse.py
58.96 KB
Rename
Delete
os.py
36.65 KB
Rename
Delete
pathlib.py
47.83 KB
Rename
Delete
pdb.py
59.88 KB
Rename
Delete
pickle.py
54.39 KB
Rename
Delete
pickletools.py
89.62 KB
Rename
Delete
pipes.py
8.71 KB
Rename
Delete
pkgutil.py
20.82 KB
Rename
Delete
platform.py
46.11 KB
Rename
Delete
plistlib.py
31.53 KB
Rename
Delete
poplib.py
14.61 KB
Rename
Delete
posixpath.py
15.40 KB
Rename
Delete
pprint.py
20.37 KB
Rename
Delete
profile.py
21.51 KB
Rename
Delete
pstats.py
25.94 KB
Rename
Delete
pty.py
4.65 KB
Rename
Delete
py_compile.py
7.01 KB
Rename
Delete
pyclbr.py
13.24 KB
Rename
Delete
pydoc.py
101.08 KB
Rename
Delete
queue.py
8.57 KB
Rename
Delete
quopri.py
7.09 KB
Rename
Delete
random.py
26.80 KB
Rename
Delete
re.py
15.19 KB
Rename
Delete
reprlib.py
5.21 KB
Rename
Delete
rlcompleter.py
6.93 KB
Rename
Delete
runpy.py
11.68 KB
Rename
Delete
sched.py
6.36 KB
Rename
Delete
secrets.py
1.99 KB
Rename
Delete
selectors.py
18.98 KB
Rename
Delete
shelve.py
8.32 KB
Rename
Delete
shlex.py
12.65 KB
Rename
Delete
shutil.py
39.87 KB
Rename
Delete
signal.py
2.07 KB
Rename
Delete
site.py
20.77 KB
Rename
Delete
smtpd.py
33.91 KB
Rename
Delete
smtplib.py
43.18 KB
Rename
Delete
sndhdr.py
6.92 KB
Rename
Delete
socket.py
26.80 KB
Rename
Delete
socketserver.py
26.38 KB
Rename
Delete
sre_compile.py
18.88 KB
Rename
Delete
sre_constants.py
6.66 KB
Rename
Delete
sre_parse.py
35.68 KB
Rename
Delete
ssl.py
43.47 KB
Rename
Delete
stat.py
4.92 KB
Rename
Delete
statistics.py
20.19 KB
Rename
Delete
string.py
11.52 KB
Rename
Delete
stringprep.py
12.61 KB
Rename
Delete
struct.py
257 bytes
Rename
Delete
subprocess.py
60.88 KB
Rename
Delete
sunau.py
17.67 KB
Rename
Delete
symbol.py
2.07 KB
Rename
Delete
symtable.py
7.11 KB
Rename
Delete
sysconfig.py
24.29 KB
Rename
Delete
tabnanny.py
11.14 KB
Rename
Delete
tarfile.py
104.88 KB
Rename
Delete
telnetlib.py
22.59 KB
Rename
Delete
tempfile.py
27.41 KB
Rename
Delete
textwrap.py
19.10 KB
Rename
Delete
this.py
1003 bytes
Rename
Delete
threading.py
48.96 KB
Rename
Delete
timeit.py
13.03 KB
Rename
Delete
token.py
3.00 KB
Rename
Delete
tokenize.py
28.80 KB
Rename
Delete
trace.py
28.06 KB
Rename
Delete
traceback.py
22.91 KB
Rename
Delete
tracemalloc.py
16.27 KB
Rename
Delete
tty.py
879 bytes
Rename
Delete
types.py
8.66 KB
Rename
Delete
typing.py
78.39 KB
Rename
Delete
uu.py
6.60 KB
Rename
Delete
uuid.py
23.46 KB
Rename
Delete
warnings.py
18.05 KB
Rename
Delete
wave.py
17.29 KB
Rename
Delete
weakref.py
19.99 KB
Rename
Delete
webbrowser.py
21.26 KB
Rename
Delete
xdrlib.py
5.77 KB
Rename
Delete
zipapp.py
6.99 KB
Rename
Delete
zipfile.py
78.05 KB
Rename
Delete
"""runpy.py - locating and running Python code using the module namespace Provides support for locating and running Python scripts using the Python module namespace instead of the native filesystem. This allows Python code to play nicely with non-filesystem based PEP 302 importers when locating support scripts as well as when importing modules. """ # Written by Nick Coghlan <ncoghlan at gmail.com> # to implement PEP 338 (Executing Modules as Scripts) import sys import importlib.machinery # importlib first so we can test #15386 via -m import importlib.util import types from pkgutil import read_code, get_importer __all__ = [ "run_module", "run_path", ] class _TempModule(object): """Temporarily replace a module in sys.modules with an empty namespace""" def __init__(self, mod_name): self.mod_name = mod_name self.module = types.ModuleType(mod_name) self._saved_module = [] def __enter__(self): mod_name = self.mod_name try: self._saved_module.append(sys.modules[mod_name]) except KeyError: pass sys.modules[mod_name] = self.module return self def __exit__(self, *args): if self._saved_module: sys.modules[self.mod_name] = self._saved_module[0] else: del sys.modules[self.mod_name] self._saved_module = [] class _ModifiedArgv0(object): def __init__(self, value): self.value = value self._saved_value = self._sentinel = object() def __enter__(self): if self._saved_value is not self._sentinel: raise RuntimeError("Already preserving saved value") self._saved_value = sys.argv[0] sys.argv[0] = self.value def __exit__(self, *args): self.value = self._sentinel sys.argv[0] = self._saved_value # TODO: Replace these helpers with importlib._bootstrap_external functions. def _run_code(code, run_globals, init_globals=None, mod_name=None, mod_spec=None, pkg_name=None, script_name=None): """Helper to run code in nominated namespace""" if init_globals is not None: run_globals.update(init_globals) if mod_spec is None: loader = None fname = script_name cached = None else: loader = mod_spec.loader fname = mod_spec.origin cached = mod_spec.cached if pkg_name is None: pkg_name = mod_spec.parent run_globals.update(__name__ = mod_name, __file__ = fname, __cached__ = cached, __doc__ = None, __loader__ = loader, __package__ = pkg_name, __spec__ = mod_spec) exec(code, run_globals) return run_globals def _run_module_code(code, init_globals=None, mod_name=None, mod_spec=None, pkg_name=None, script_name=None): """Helper to run code in new namespace with sys modified""" fname = script_name if mod_spec is None else mod_spec.origin with _TempModule(mod_name) as temp_module, _ModifiedArgv0(fname): mod_globals = temp_module.module.__dict__ _run_code(code, mod_globals, init_globals, mod_name, mod_spec, pkg_name, script_name) # Copy the globals of the temporary module, as they # may be cleared when the temporary module goes away return mod_globals.copy() # Helper to get the full name, spec and code for a module def _get_module_details(mod_name, error=ImportError): if mod_name.startswith("."): raise error("Relative module names not supported") pkg_name, _, _ = mod_name.rpartition(".") if pkg_name: # Try importing the parent to avoid catching initialization errors try: __import__(pkg_name) except ImportError as e: # If the parent or higher ancestor package is missing, let the # error be raised by find_spec() below and then be caught. But do # not allow other errors to be caught. if e.name is None or (e.name != pkg_name and not pkg_name.startswith(e.name + ".")): raise # Warn if the module has already been imported under its normal name existing = sys.modules.get(mod_name) if existing is not None and not hasattr(existing, "__path__"): from warnings import warn msg = "{mod_name!r} found in sys.modules after import of " \ "package {pkg_name!r}, but prior to execution of " \ "{mod_name!r}; this may result in unpredictable " \ "behaviour".format(mod_name=mod_name, pkg_name=pkg_name) warn(RuntimeWarning(msg)) try: spec = importlib.util.find_spec(mod_name) except (ImportError, AttributeError, TypeError, ValueError) as ex: # This hack fixes an impedance mismatch between pkgutil and # importlib, where the latter raises other errors for cases where # pkgutil previously raised ImportError msg = "Error while finding module specification for {!r} ({}: {})" raise error(msg.format(mod_name, type(ex).__name__, ex)) from ex if spec is None: raise error("No module named %s" % mod_name) if spec.submodule_search_locations is not None: if mod_name == "__main__" or mod_name.endswith(".__main__"): raise error("Cannot use package as __main__ module") try: pkg_main_name = mod_name + ".__main__" return _get_module_details(pkg_main_name, error) except error as e: if mod_name not in sys.modules: raise # No module loaded; being a package is irrelevant raise error(("%s; %r is a package and cannot " + "be directly executed") %(e, mod_name)) loader = spec.loader if loader is None: raise error("%r is a namespace package and cannot be executed" % mod_name) try: code = loader.get_code(mod_name) except ImportError as e: raise error(format(e)) from e if code is None: raise error("No code object available for %s" % mod_name) return mod_name, spec, code class _Error(Exception): """Error that _run_module_as_main() should report without a traceback""" # XXX ncoghlan: Should this be documented and made public? # (Current thoughts: don't repeat the mistake that lead to its # creation when run_module() no longer met the needs of # mainmodule.c, but couldn't be changed because it was public) def _run_module_as_main(mod_name, alter_argv=True): """Runs the designated module in the __main__ namespace Note that the executed module will have full access to the __main__ namespace. If this is not desirable, the run_module() function should be used to run the module code in a fresh namespace. At the very least, these variables in __main__ will be overwritten: __name__ __file__ __cached__ __loader__ __package__ """ try: if alter_argv or mod_name != "__main__": # i.e. -m switch mod_name, mod_spec, code = _get_module_details(mod_name, _Error) else: # i.e. directory or zipfile execution mod_name, mod_spec, code = _get_main_module_details(_Error) except _Error as exc: msg = "%s: %s" % (sys.executable, exc) sys.exit(msg) main_globals = sys.modules["__main__"].__dict__ if alter_argv: sys.argv[0] = mod_spec.origin return _run_code(code, main_globals, None, "__main__", mod_spec) def run_module(mod_name, init_globals=None, run_name=None, alter_sys=False): """Execute a module's code without importing it Returns the resulting top level namespace dictionary """ mod_name, mod_spec, code = _get_module_details(mod_name) if run_name is None: run_name = mod_name if alter_sys: return _run_module_code(code, init_globals, run_name, mod_spec) else: # Leave the sys module alone return _run_code(code, {}, init_globals, run_name, mod_spec) def _get_main_module_details(error=ImportError): # Helper that gives a nicer error message when attempting to # execute a zipfile or directory by invoking __main__.py # Also moves the standard __main__ out of the way so that the # preexisting __loader__ entry doesn't cause issues main_name = "__main__" saved_main = sys.modules[main_name] del sys.modules[main_name] try: return _get_module_details(main_name) except ImportError as exc: if main_name in str(exc): raise error("can't find %r module in %r" % (main_name, sys.path[0])) from exc raise finally: sys.modules[main_name] = saved_main def _get_code_from_file(run_name, fname): # Check for a compiled file first with open(fname, "rb") as f: code = read_code(f) if code is None: # That didn't work, so try it as normal source code with open(fname, "rb") as f: code = compile(f.read(), fname, 'exec') return code, fname def run_path(path_name, init_globals=None, run_name=None): """Execute code located at the specified filesystem location Returns the resulting top level namespace dictionary The file path may refer directly to a Python script (i.e. one that could be directly executed with execfile) or else it may refer to a zipfile or directory containing a top level __main__.py script. """ if run_name is None: run_name = "<run_path>" pkg_name = run_name.rpartition(".")[0] importer = get_importer(path_name) # Trying to avoid importing imp so as to not consume the deprecation warning. is_NullImporter = False if type(importer).__module__ == 'imp': if type(importer).__name__ == 'NullImporter': is_NullImporter = True if isinstance(importer, type(None)) or is_NullImporter: # Not a valid sys.path entry, so run the code directly # execfile() doesn't help as we want to allow compiled files code, fname = _get_code_from_file(run_name, path_name) return _run_module_code(code, init_globals, run_name, pkg_name=pkg_name, script_name=fname) else: # Finder is defined for path, so add it to # the start of sys.path sys.path.insert(0, path_name) try: # Here's where things are a little different from the run_module # case. There, we only had to replace the module in sys while the # code was running and doing so was somewhat optional. Here, we # have no choice and we have to remove it even while we read the # code. If we don't do this, a __loader__ attribute in the # existing __main__ module may prevent location of the new module. mod_name, mod_spec, code = _get_main_module_details() with _TempModule(run_name) as temp_module, \ _ModifiedArgv0(path_name): mod_globals = temp_module.module.__dict__ return _run_code(code, mod_globals, init_globals, run_name, mod_spec, pkg_name).copy() finally: try: sys.path.remove(path_name) except ValueError: pass if __name__ == "__main__": # Run the module specified as the next command line argument if len(sys.argv) < 2: print("No module specified for execution", file=sys.stderr) else: del sys.argv[0] # Make the requested module sys.argv[0] _run_module_as_main(sys.argv[0])
Save