X7ROOT File Manager
Current Path:
/opt/alt/python35/lib64/python3.5
opt
/
alt
/
python35
/
lib64
/
python3.5
/
๐
..
๐
__future__.py
(4.73 KB)
๐
__phello__.foo.py
(64 B)
๐
__pycache__
๐
_bootlocale.py
(1.27 KB)
๐
_collections_abc.py
(24.21 KB)
๐
_compat_pickle.py
(8.36 KB)
๐
_compression.py
(5.21 KB)
๐
_dummy_thread.py
(5 KB)
๐
_markupbase.py
(14.26 KB)
๐
_osx_support.py
(18.67 KB)
๐
_pydecimal.py
(223.27 KB)
๐
_pyio.py
(85.91 KB)
๐
_sitebuiltins.py
(3.04 KB)
๐
_strptime.py
(21.67 KB)
๐
_sysconfigdata.py
(26.32 KB)
๐
_threading_local.py
(7.24 KB)
๐
_weakrefset.py
(5.57 KB)
๐
abc.py
(8.43 KB)
๐
aifc.py
(31.22 KB)
๐
antigravity.py
(476 B)
๐
argparse.py
(88.03 KB)
๐
ast.py
(11.72 KB)
๐
asynchat.py
(11.69 KB)
๐
asyncio
๐
asyncore.py
(19.63 KB)
๐
base64.py
(20.04 KB)
๐
bdb.py
(22.81 KB)
๐
binhex.py
(13.63 KB)
๐
bisect.py
(2.53 KB)
๐
bz2.py
(12.13 KB)
๐
cProfile.py
(5.2 KB)
๐
calendar.py
(22.46 KB)
๐
cgi.py
(35.2 KB)
๐
cgitb.py
(11.74 KB)
๐
chunk.py
(5.3 KB)
๐
cmd.py
(14.51 KB)
๐
code.py
(9.88 KB)
๐
codecs.py
(35.38 KB)
๐
codeop.py
(5.85 KB)
๐
collections
๐
colorsys.py
(3.97 KB)
๐
compileall.py
(11.44 KB)
๐
concurrent
๐
config-3.5m
๐
configparser.py
(52.2 KB)
๐
contextlib.py
(12.16 KB)
๐
copy.py
(8.74 KB)
๐
copyreg.py
(6.67 KB)
๐
crypt.py
(1.83 KB)
๐
csv.py
(15.75 KB)
๐
ctypes
๐
curses
๐
datetime.py
(74.12 KB)
๐
dbm
๐
decimal.py
(320 B)
๐
difflib.py
(82.23 KB)
๐
dis.py
(16.94 KB)
๐
distutils
๐
doctest.py
(101.6 KB)
๐
dummy_threading.py
(2.75 KB)
๐
email
๐
encodings
๐
ensurepip
๐
enum.py
(21.71 KB)
๐
filecmp.py
(9.6 KB)
๐
fileinput.py
(13.92 KB)
๐
fnmatch.py
(3.09 KB)
๐
formatter.py
(14.79 KB)
๐
fractions.py
(24.04 KB)
๐
ftplib.py
(34.13 KB)
๐
functools.py
(28.27 KB)
๐
genericpath.py
(4.26 KB)
๐
getopt.py
(7.31 KB)
๐
getpass.py
(5.85 KB)
๐
gettext.py
(21.03 KB)
๐
glob.py
(4.95 KB)
๐
gzip.py
(19.79 KB)
๐
hashlib.py
(7.79 KB)
๐
heapq.py
(22.39 KB)
๐
hmac.py
(4.94 KB)
๐
html
๐
http
๐
idlelib
๐
imaplib.py
(50.96 KB)
๐
imghdr.py
(3.67 KB)
๐
imp.py
(10.43 KB)
๐
importlib
๐
inspect.py
(111.52 KB)
๐
io.py
(3.32 KB)
๐
ipaddress.py
(73.96 KB)
๐
json
๐
keyword.py
(2.17 KB)
๐
lib-dynload
๐
lib2to3
๐
linecache.py
(5.19 KB)
๐
locale.py
(72.96 KB)
๐
logging
๐
lzma.py
(12.62 KB)
๐
macpath.py
(5.77 KB)
๐
macurl2path.py
(2.67 KB)
๐
mailbox.py
(76.58 KB)
๐
mailcap.py
(7.91 KB)
๐
mimetypes.py
(20.36 KB)
๐
modulefinder.py
(22.54 KB)
๐
multiprocessing
๐
netrc.py
(5.61 KB)
๐
nntplib.py
(42.07 KB)
๐
ntpath.py
(22.26 KB)
๐
nturl2path.py
(2.39 KB)
๐
numbers.py
(10 KB)
๐
opcode.py
(5.75 KB)
๐
operator.py
(10.61 KB)
๐
optparse.py
(58.93 KB)
๐
os.py
(36.17 KB)
๐
pathlib.py
(45.9 KB)
๐
pdb.py
(59.72 KB)
๐
pickle.py
(54.86 KB)
๐
pickletools.py
(89.61 KB)
๐
pipes.py
(8.71 KB)
๐
pkgutil.py
(20.85 KB)
๐
plat-linux
๐
platform.py
(45.07 KB)
๐
plistlib.py
(31.06 KB)
๐
poplib.py
(14.37 KB)
๐
posixpath.py
(14.56 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.25 KB)
๐
pydoc.py
(101.22 KB)
๐
pydoc_data
๐
queue.py
(8.57 KB)
๐
quopri.py
(7.09 KB)
๐
random.py
(25.84 KB)
๐
re.py
(15.14 KB)
๐
reprlib.py
(5.21 KB)
๐
rlcompleter.py
(6.16 KB)
๐
runpy.py
(11.68 KB)
๐
sched.py
(6.07 KB)
๐
selectors.py
(18.98 KB)
๐
shelve.py
(8.33 KB)
๐
shlex.py
(11.18 KB)
๐
shutil.py
(39.11 KB)
๐
signal.py
(2.07 KB)
๐
site-packages
๐
site.py
(21 KB)
๐
smtpd.py
(34.54 KB)
๐
smtplib.py
(42.61 KB)
๐
sndhdr.py
(6.27 KB)
๐
socket.py
(26.5 KB)
๐
socketserver.py
(24.09 KB)
๐
sqlite3
๐
sre_compile.py
(17.98 KB)
๐
sre_constants.py
(6.66 KB)
๐
sre_parse.py
(34.29 KB)
๐
ssl.py
(41.36 KB)
๐
stat.py
(4.92 KB)
๐
statistics.py
(19.08 KB)
๐
string.py
(11.58 KB)
๐
stringprep.py
(12.61 KB)
๐
struct.py
(257 B)
๐
subprocess.py
(57.53 KB)
๐
sunau.py
(17.67 KB)
๐
symbol.py
(2.06 KB)
๐
symtable.py
(7.02 KB)
๐
sysconfig.py
(23.89 KB)
๐
tabnanny.py
(11.15 KB)
๐
tarfile.py
(90.89 KB)
๐
telnetlib.py
(22.48 KB)
๐
tempfile.py
(26.01 KB)
๐
test
๐
textwrap.py
(19.1 KB)
๐
this.py
(1003 B)
๐
threading.py
(47.88 KB)
๐
timeit.py
(12.11 KB)
๐
token.py
(3 KB)
๐
tokenize.py
(27.14 KB)
๐
trace.py
(30.81 KB)
๐
traceback.py
(21.66 KB)
๐
tracemalloc.py
(15.27 KB)
๐
tty.py
(879 B)
๐
types.py
(8.59 KB)
๐
typing.py
(78.26 KB)
๐
unittest
๐
urllib
๐
uu.py
(6.61 KB)
๐
uuid.py
(22.72 KB)
๐
venv
๐
warnings.py
(15.48 KB)
๐
wave.py
(17.27 KB)
๐
weakref.py
(19.99 KB)
๐
webbrowser.py
(21.32 KB)
๐
wsgiref
๐
xdrlib.py
(5.77 KB)
๐
xml
๐
xmlrpc
๐
zipapp.py
(6.99 KB)
๐
zipfile.py
(71.95 KB)
Editing: shlex.py
"""A lexical analyzer class for simple shell-like syntaxes.""" # Module and documentation by Eric S. Raymond, 21 Dec 1998 # Input stacking and error message cleanup added by ESR, March 2000 # push_source() and pop_source() made explicit by ESR, January 2001. # Posix compliance, split(), string arguments, and # iterator interface by Gustavo Niemeyer, April 2003. import os import re import sys from collections import deque from io import StringIO __all__ = ["shlex", "split", "quote"] class shlex: "A lexical analyzer class for simple shell-like syntaxes." def __init__(self, instream=None, infile=None, posix=False): if isinstance(instream, str): instream = StringIO(instream) if instream is not None: self.instream = instream self.infile = infile else: self.instream = sys.stdin self.infile = None self.posix = posix if posix: self.eof = None else: self.eof = '' self.commenters = '#' self.wordchars = ('abcdfeghijklmnopqrstuvwxyz' 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_') if self.posix: self.wordchars += ('รร รกรขรฃรครฅรฆรงรจรฉรชรซรฌรญรฎรฏรฐรฑรฒรณรดรตรถรธรนรบรปรผรฝรพรฟ' 'รรรรรร รรรรรรรรรรรรรรรรรรรรรรรร') self.whitespace = ' \t\r\n' self.whitespace_split = False self.quotes = '\'"' self.escape = '\\' self.escapedquotes = '"' self.state = ' ' self.pushback = deque() self.lineno = 1 self.debug = 0 self.token = '' self.filestack = deque() self.source = None def push_token(self, tok): "Push a token onto the stack popped by the get_token method" if self.debug >= 1: print("shlex: pushing token " + repr(tok)) self.pushback.appendleft(tok) def push_source(self, newstream, newfile=None): "Push an input source onto the lexer's input source stack." if isinstance(newstream, str): newstream = StringIO(newstream) self.filestack.appendleft((self.infile, self.instream, self.lineno)) self.infile = newfile self.instream = newstream self.lineno = 1 if self.debug: if newfile is not None: print('shlex: pushing to file %s' % (self.infile,)) else: print('shlex: pushing to stream %s' % (self.instream,)) def pop_source(self): "Pop the input source stack." self.instream.close() (self.infile, self.instream, self.lineno) = self.filestack.popleft() if self.debug: print('shlex: popping to %s, line %d' \ % (self.instream, self.lineno)) self.state = ' ' def get_token(self): "Get a token from the input stream (or from stack if it's nonempty)" if self.pushback: tok = self.pushback.popleft() if self.debug >= 1: print("shlex: popping token " + repr(tok)) return tok # No pushback. Get a token. raw = self.read_token() # Handle inclusions if self.source is not None: while raw == self.source: spec = self.sourcehook(self.read_token()) if spec: (newfile, newstream) = spec self.push_source(newstream, newfile) raw = self.get_token() # Maybe we got EOF instead? while raw == self.eof: if not self.filestack: return self.eof else: self.pop_source() raw = self.get_token() # Neither inclusion nor EOF if self.debug >= 1: if raw != self.eof: print("shlex: token=" + repr(raw)) else: print("shlex: token=EOF") return raw def read_token(self): quoted = False escapedstate = ' ' while True: nextchar = self.instream.read(1) if nextchar == '\n': self.lineno = self.lineno + 1 if self.debug >= 3: print("shlex: in state", repr(self.state), \ "I see character:", repr(nextchar)) if self.state is None: self.token = '' # past end of file break elif self.state == ' ': if not nextchar: self.state = None # end of file break elif nextchar in self.whitespace: if self.debug >= 2: print("shlex: I see whitespace in whitespace state") if self.token or (self.posix and quoted): break # emit current token else: continue elif nextchar in self.commenters: self.instream.readline() self.lineno = self.lineno + 1 elif self.posix and nextchar in self.escape: escapedstate = 'a' self.state = nextchar elif nextchar in self.wordchars: self.token = nextchar self.state = 'a' elif nextchar in self.quotes: if not self.posix: self.token = nextchar self.state = nextchar elif self.whitespace_split: self.token = nextchar self.state = 'a' else: self.token = nextchar if self.token or (self.posix and quoted): break # emit current token else: continue elif self.state in self.quotes: quoted = True if not nextchar: # end of file if self.debug >= 2: print("shlex: I see EOF in quotes state") # XXX what error should be raised here? raise ValueError("No closing quotation") if nextchar == self.state: if not self.posix: self.token = self.token + nextchar self.state = ' ' break else: self.state = 'a' elif self.posix and nextchar in self.escape and \ self.state in self.escapedquotes: escapedstate = self.state self.state = nextchar else: self.token = self.token + nextchar elif self.state in self.escape: if not nextchar: # end of file if self.debug >= 2: print("shlex: I see EOF in escape state") # XXX what error should be raised here? raise ValueError("No escaped character") # In posix shells, only the quote itself or the escape # character may be escaped within quotes. if escapedstate in self.quotes and \ nextchar != self.state and nextchar != escapedstate: self.token = self.token + self.state self.token = self.token + nextchar self.state = escapedstate elif self.state == 'a': if not nextchar: self.state = None # end of file break elif nextchar in self.whitespace: if self.debug >= 2: print("shlex: I see whitespace in word state") self.state = ' ' if self.token or (self.posix and quoted): break # emit current token else: continue elif nextchar in self.commenters: self.instream.readline() self.lineno = self.lineno + 1 if self.posix: self.state = ' ' if self.token or (self.posix and quoted): break # emit current token else: continue elif self.posix and nextchar in self.quotes: self.state = nextchar elif self.posix and nextchar in self.escape: escapedstate = 'a' self.state = nextchar elif nextchar in self.wordchars or nextchar in self.quotes \ or self.whitespace_split: self.token = self.token + nextchar else: self.pushback.appendleft(nextchar) if self.debug >= 2: print("shlex: I see punctuation in word state") self.state = ' ' if self.token or (self.posix and quoted): break # emit current token else: continue result = self.token self.token = '' if self.posix and not quoted and result == '': result = None if self.debug > 1: if result: print("shlex: raw token=" + repr(result)) else: print("shlex: raw token=EOF") return result def sourcehook(self, newfile): "Hook called on a filename to be sourced." if newfile[0] == '"': newfile = newfile[1:-1] # This implements cpp-like semantics for relative-path inclusion. if isinstance(self.infile, str) and not os.path.isabs(newfile): newfile = os.path.join(os.path.dirname(self.infile), newfile) return (newfile, open(newfile, "r")) def error_leader(self, infile=None, lineno=None): "Emit a C-compiler-like, Emacs-friendly error-message leader." if infile is None: infile = self.infile if lineno is None: lineno = self.lineno return "\"%s\", line %d: " % (infile, lineno) def __iter__(self): return self def __next__(self): token = self.get_token() if token == self.eof: raise StopIteration return token def split(s, comments=False, posix=True): lex = shlex(s, posix=posix) lex.whitespace_split = True if not comments: lex.commenters = '' return list(lex) _find_unsafe = re.compile(r'[^\w@%+=:,./-]', re.ASCII).search def quote(s): """Return a shell-escaped version of the string *s*.""" if not s: return "''" if _find_unsafe(s) is None: return s # use single quotes, and put single quotes into double quotes # the string $'b is then quoted as '$'"'"'b' return "'" + s.replace("'", "'\"'\"'") + "'" def _print_tokens(lexer): while 1: tt = lexer.get_token() if not tt: break print("Token: " + repr(tt)) if __name__ == '__main__': if len(sys.argv) == 1: _print_tokens(shlex()) else: fn = sys.argv[1] with open(fn) as f: _print_tokens(shlex(f, fn))
Upload File
Create Folder