X7ROOT File Manager
Current Path:
/opt/alt/python36/lib64/python3.6
opt
/
alt
/
python36
/
lib64
/
python3.6
/
ðŸ“
..
📄
__future__.py
(4.73 KB)
📄
__phello__.foo.py
(64 B)
ðŸ“
__pycache__
📄
_bootlocale.py
(1.27 KB)
📄
_collections_abc.py
(25.77 KB)
📄
_compat_pickle.py
(8.54 KB)
📄
_compression.py
(5.21 KB)
📄
_dummy_thread.py
(5 KB)
📄
_markupbase.py
(14.26 KB)
📄
_osx_support.py
(18.69 KB)
📄
_pydecimal.py
(224.83 KB)
📄
_pyio.py
(86.03 KB)
📄
_sitebuiltins.py
(3.04 KB)
📄
_strptime.py
(24.17 KB)
📄
_sysconfigdata_dm_linux_x86_64-linux-gnu.py
(27.17 KB)
📄
_sysconfigdata_m_linux_x86_64-linux-gnu.py
(25.67 KB)
📄
_threading_local.py
(7.04 KB)
📄
_weakrefset.py
(5.57 KB)
📄
abc.py
(8.52 KB)
📄
aifc.py
(31.69 KB)
📄
antigravity.py
(477 B)
📄
argparse.py
(88.25 KB)
📄
ast.py
(11.88 KB)
📄
asynchat.py
(11.06 KB)
ðŸ“
asyncio
📄
asyncore.py
(19.69 KB)
📄
base64.py
(19.91 KB)
📄
bdb.py
(23 KB)
📄
binhex.py
(13.63 KB)
📄
bisect.py
(2.53 KB)
📄
bz2.py
(12.19 KB)
📄
cProfile.py
(5.26 KB)
📄
calendar.py
(22.67 KB)
📄
cgi.py
(36.21 KB)
📄
cgitb.py
(11.74 KB)
📄
chunk.py
(5.3 KB)
📄
cmd.py
(14.51 KB)
📄
code.py
(10.37 KB)
📄
codecs.py
(35.43 KB)
📄
codeop.py
(5.85 KB)
ðŸ“
collections
📄
colorsys.py
(3.97 KB)
📄
compileall.py
(11.84 KB)
ðŸ“
concurrent
ðŸ“
config-3.6m
📄
configparser.py
(52.34 KB)
📄
contextlib.py
(12.85 KB)
📄
copy.py
(8.61 KB)
📄
copyreg.py
(6.84 KB)
📄
crypt.py
(1.82 KB)
📄
csv.py
(15.8 KB)
ðŸ“
ctypes
ðŸ“
curses
📄
datetime.py
(80.11 KB)
ðŸ“
dbm
📄
decimal.py
(320 B)
📄
difflib.py
(82.4 KB)
📄
dis.py
(17.71 KB)
ðŸ“
distutils
📄
doctest.py
(101.94 KB)
📄
dummy_threading.py
(2.75 KB)
ðŸ“
email
ðŸ“
encodings
ðŸ“
ensurepip
📄
enum.py
(32.82 KB)
📄
filecmp.py
(9.6 KB)
📄
fileinput.py
(14.13 KB)
📄
fnmatch.py
(3.09 KB)
📄
formatter.py
(14.79 KB)
📄
fractions.py
(23.08 KB)
📄
ftplib.py
(34.78 KB)
📄
functools.py
(30.61 KB)
📄
genericpath.py
(4.64 KB)
📄
getopt.py
(7.31 KB)
📄
getpass.py
(5.85 KB)
📄
gettext.py
(21.03 KB)
📄
glob.py
(5.51 KB)
📄
gzip.py
(19.86 KB)
📄
hashlib.py
(9.31 KB)
📄
heapq.py
(22.39 KB)
📄
hmac.py
(4.94 KB)
ðŸ“
html
ðŸ“
http
ðŸ“
idlelib
📄
imaplib.py
(52.05 KB)
📄
imghdr.py
(3.71 KB)
📄
imp.py
(10.42 KB)
ðŸ“
importlib
📄
inspect.py
(114.22 KB)
📄
io.py
(3.43 KB)
📄
ipaddress.py
(72.82 KB)
ðŸ“
json
📄
keyword.py
(2.17 KB)
ðŸ“
lib-dynload
ðŸ“
lib2to3
📄
linecache.py
(5.19 KB)
📄
locale.py
(75.49 KB)
ðŸ“
logging
📄
lzma.py
(12.68 KB)
📄
macpath.py
(5.83 KB)
📄
macurl2path.py
(2.67 KB)
📄
mailbox.py
(76.78 KB)
📄
mailcap.py
(7.91 KB)
📄
mimetypes.py
(20.55 KB)
📄
modulefinder.py
(22.49 KB)
ðŸ“
multiprocessing
📄
netrc.py
(5.55 KB)
📄
nntplib.py
(42.07 KB)
📄
ntpath.py
(22.55 KB)
📄
nturl2path.py
(2.39 KB)
📄
numbers.py
(10 KB)
📄
opcode.py
(5.69 KB)
📄
operator.py
(10.61 KB)
📄
optparse.py
(58.96 KB)
📄
os.py
(36.65 KB)
📄
pathlib.py
(47.83 KB)
📄
pdb.py
(59.89 KB)
📄
pickle.py
(54.39 KB)
📄
pickletools.py
(89.62 KB)
📄
pipes.py
(8.71 KB)
📄
pkgutil.py
(20.82 KB)
📄
platform.py
(46.1 KB)
📄
plistlib.py
(32.02 KB)
📄
poplib.py
(14.61 KB)
📄
posixpath.py
(15.4 KB)
📄
pprint.py
(20.37 KB)
📄
profile.py
(21.52 KB)
📄
pstats.py
(25.94 KB)
📄
pty.py
(4.65 KB)
📄
py_compile.py
(7.01 KB)
📄
pyclbr.py
(13.24 KB)
📄
pydoc.py
(101.08 KB)
ðŸ“
pydoc_data
📄
queue.py
(8.57 KB)
📄
quopri.py
(7.09 KB)
📄
random.py
(26.8 KB)
📄
re.py
(15.19 KB)
📄
reprlib.py
(5.21 KB)
📄
rlcompleter.py
(6.93 KB)
📄
runpy.py
(11.68 KB)
📄
sched.py
(6.36 KB)
📄
secrets.py
(1.99 KB)
📄
selectors.py
(18.98 KB)
📄
shelve.py
(8.32 KB)
📄
shlex.py
(12.65 KB)
📄
shutil.py
(39.59 KB)
📄
signal.py
(2.07 KB)
ðŸ“
site-packages
📄
site.py
(20.53 KB)
📄
smtpd.py
(33.91 KB)
📄
smtplib.py
(43.38 KB)
📄
sndhdr.py
(6.92 KB)
📄
socket.py
(26.8 KB)
📄
socketserver.py
(26.38 KB)
ðŸ“
sqlite3
📄
sre_compile.py
(18.88 KB)
📄
sre_constants.py
(6.66 KB)
📄
sre_parse.py
(35.68 KB)
📄
ssl.py
(43.74 KB)
📄
stat.py
(4.92 KB)
📄
statistics.py
(20.19 KB)
📄
string.py
(11.52 KB)
📄
stringprep.py
(12.61 KB)
📄
struct.py
(257 B)
📄
subprocess.py
(60.88 KB)
📄
sunau.py
(17.67 KB)
📄
symbol.py
(2.07 KB)
📄
symtable.py
(7.11 KB)
📄
sysconfig.py
(24.4 KB)
📄
tabnanny.py
(11.15 KB)
📄
tarfile.py
(91.13 KB)
📄
telnetlib.py
(22.59 KB)
📄
tempfile.py
(26.15 KB)
ðŸ“
test
📄
textwrap.py
(19.1 KB)
📄
this.py
(1003 B)
📄
threading.py
(47.88 KB)
📄
timeit.py
(13.03 KB)
📄
token.py
(3 KB)
📄
tokenize.py
(28.8 KB)
📄
trace.py
(28.06 KB)
📄
traceback.py
(22.91 KB)
📄
tracemalloc.py
(16.27 KB)
📄
tty.py
(879 B)
📄
types.py
(8.66 KB)
📄
typing.py
(78.39 KB)
ðŸ“
unittest
ðŸ“
urllib
📄
uu.py
(6.75 KB)
📄
uuid.py
(23.41 KB)
ðŸ“
venv
📄
warnings.py
(18.05 KB)
📄
wave.py
(17.29 KB)
📄
weakref.py
(19.99 KB)
📄
webbrowser.py
(21.26 KB)
ðŸ“
wsgiref
📄
xdrlib.py
(5.77 KB)
ðŸ“
xml
ðŸ“
xmlrpc
📄
zipapp.py
(6.99 KB)
📄
zipfile.py
(74.49 KB)
Editing: mailcap.py
"""Mailcap file handling. See RFC 1524.""" import os import warnings __all__ = ["getcaps","findmatch"] def lineno_sort_key(entry): # Sort in ascending order, with unspecified entries at the end if 'lineno' in entry: return 0, entry['lineno'] else: return 1, 0 # Part 1: top-level interface. def getcaps(): """Return a dictionary containing the mailcap database. The dictionary maps a MIME type (in all lowercase, e.g. 'text/plain') to a list of dictionaries corresponding to mailcap entries. The list collects all the entries for that MIME type from all available mailcap files. Each dictionary contains key-value pairs for that MIME type, where the viewing command is stored with the key "view". """ caps = {} lineno = 0 for mailcap in listmailcapfiles(): try: fp = open(mailcap, 'r') except OSError: continue with fp: morecaps, lineno = _readmailcapfile(fp, lineno) for key, value in morecaps.items(): if not key in caps: caps[key] = value else: caps[key] = caps[key] + value return caps def listmailcapfiles(): """Return a list of all mailcap files found on the system.""" # This is mostly a Unix thing, but we use the OS path separator anyway if 'MAILCAPS' in os.environ: pathstr = os.environ['MAILCAPS'] mailcaps = pathstr.split(os.pathsep) else: if 'HOME' in os.environ: home = os.environ['HOME'] else: # Don't bother with getpwuid() home = '.' # Last resort mailcaps = [home + '/.mailcap', '/etc/mailcap', '/usr/etc/mailcap', '/usr/local/etc/mailcap'] return mailcaps # Part 2: the parser. def readmailcapfile(fp): """Read a mailcap file and return a dictionary keyed by MIME type.""" warnings.warn('readmailcapfile is deprecated, use getcaps instead', DeprecationWarning, 2) caps, _ = _readmailcapfile(fp, None) return caps def _readmailcapfile(fp, lineno): """Read a mailcap file and return a dictionary keyed by MIME type. Each MIME type is mapped to an entry consisting of a list of dictionaries; the list will contain more than one such dictionary if a given MIME type appears more than once in the mailcap file. Each dictionary contains key-value pairs for that MIME type, where the viewing command is stored with the key "view". """ caps = {} while 1: line = fp.readline() if not line: break # Ignore comments and blank lines if line[0] == '#' or line.strip() == '': continue nextline = line # Join continuation lines while nextline[-2:] == '\\\n': nextline = fp.readline() if not nextline: nextline = '\n' line = line[:-2] + nextline # Parse the line key, fields = parseline(line) if not (key and fields): continue if lineno is not None: fields['lineno'] = lineno lineno += 1 # Normalize the key types = key.split('/') for j in range(len(types)): types[j] = types[j].strip() key = '/'.join(types).lower() # Update the database if key in caps: caps[key].append(fields) else: caps[key] = [fields] return caps, lineno def parseline(line): """Parse one entry in a mailcap file and return a dictionary. The viewing command is stored as the value with the key "view", and the rest of the fields produce key-value pairs in the dict. """ fields = [] i, n = 0, len(line) while i < n: field, i = parsefield(line, i, n) fields.append(field) i = i+1 # Skip semicolon if len(fields) < 2: return None, None key, view, rest = fields[0], fields[1], fields[2:] fields = {'view': view} for field in rest: i = field.find('=') if i < 0: fkey = field fvalue = "" else: fkey = field[:i].strip() fvalue = field[i+1:].strip() if fkey in fields: # Ignore it pass else: fields[fkey] = fvalue return key, fields def parsefield(line, i, n): """Separate one key-value pair in a mailcap entry.""" start = i while i < n: c = line[i] if c == ';': break elif c == '\\': i = i+2 else: i = i+1 return line[start:i].strip(), i # Part 3: using the database. def findmatch(caps, MIMEtype, key='view', filename="/dev/null", plist=[]): """Find a match for a mailcap entry. Return a tuple containing the command line, and the mailcap entry used; (None, None) if no match is found. This may invoke the 'test' command of several matching entries before deciding which entry to use. """ entries = lookup(caps, MIMEtype, key) # XXX This code should somehow check for the needsterminal flag. for e in entries: if 'test' in e: test = subst(e['test'], filename, plist) if test and os.system(test) != 0: continue command = subst(e[key], MIMEtype, filename, plist) return command, e return None, None def lookup(caps, MIMEtype, key=None): entries = [] if MIMEtype in caps: entries = entries + caps[MIMEtype] MIMEtypes = MIMEtype.split('/') MIMEtype = MIMEtypes[0] + '/*' if MIMEtype in caps: entries = entries + caps[MIMEtype] if key is not None: entries = [e for e in entries if key in e] entries = sorted(entries, key=lineno_sort_key) return entries def subst(field, MIMEtype, filename, plist=[]): # XXX Actually, this is Unix-specific res = '' i, n = 0, len(field) while i < n: c = field[i]; i = i+1 if c != '%': if c == '\\': c = field[i:i+1]; i = i+1 res = res + c else: c = field[i]; i = i+1 if c == '%': res = res + c elif c == 's': res = res + filename elif c == 't': res = res + MIMEtype elif c == '{': start = i while i < n and field[i] != '}': i = i+1 name = field[start:i] i = i+1 res = res + findparam(name, plist) # XXX To do: # %n == number of parts if type is multipart/* # %F == list of alternating type and filename for parts else: res = res + '%' + c return res def findparam(name, plist): name = name.lower() + '=' n = len(name) for p in plist: if p[:n].lower() == name: return p[n:] return '' # Part 4: test program. def test(): import sys caps = getcaps() if not sys.argv[1:]: show(caps) return for i in range(1, len(sys.argv), 2): args = sys.argv[i:i+2] if len(args) < 2: print("usage: mailcap [MIMEtype file] ...") return MIMEtype = args[0] file = args[1] command, e = findmatch(caps, MIMEtype, 'view', file) if not command: print("No viewer found for", type) else: print("Executing:", command) sts = os.system(command) if sts: print("Exit status:", sts) def show(caps): print("Mailcap files:") for fn in listmailcapfiles(): print("\t" + fn) print() if not caps: caps = getcaps() print("Mailcap entries:") print() ckeys = sorted(caps) for type in ckeys: print(type) entries = caps[type] for e in entries: keys = sorted(e) for k in keys: print(" %-15s" % k, e[k]) print() if __name__ == '__main__': test()
Upload File
Create Folder