__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
"""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.
# changes to tokenize more like Posix shells by Vinay Sajip, July 2016.
import os
import re
import sys
from collections import deque
from io import StringIO
__all__ = ["shlex", "split", "quote", "join"]
class shlex:
"A lexical analyzer class for simple shell-like syntaxes."
def __init__(self, instream=None, infile=None, posix=False,
punctuation_chars=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
if not punctuation_chars:
punctuation_chars = ''
elif punctuation_chars is True:
punctuation_chars = '();<>|&'
self._punctuation_chars = punctuation_chars
if punctuation_chars:
# _pushback_chars is a push back queue used by lookahead logic
self._pushback_chars = deque()
# these chars added because allowed in file names, args, wildcards
self.wordchars += '~-./*?='
#remove any punctuation chars from wordchars
t = self.wordchars.maketrans(dict.fromkeys(punctuation_chars))
self.wordchars = self.wordchars.translate(t)
@property
def punctuation_chars(self):
return self._punctuation_chars
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:
if self.punctuation_chars and self._pushback_chars:
nextchar = self._pushback_chars.pop()
else:
nextchar = self.instream.read(1)
if nextchar == '\n':
self.lineno += 1
if self.debug >= 3:
print("shlex: in state %r I see character: %r" % (self.state,
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 += 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.punctuation_chars:
self.token = nextchar
self.state = 'c'
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 += 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 += 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.state
self.token += nextchar
self.state = escapedstate
elif self.state in ('a', 'c'):
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 += 1
if self.posix:
self.state = ' '
if self.token or (self.posix and quoted):
break # emit current token
else:
continue
elif self.state == 'c':
if nextchar in self.punctuation_chars:
self.token += nextchar
else:
if nextchar not in self.whitespace:
self._pushback_chars.append(nextchar)
self.state = ' '
break
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 and
nextchar not in self.punctuation_chars)):
self.token += nextchar
else:
if self.punctuation_chars:
self._pushback_chars.append(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):
"""Split the string *s* using shell-like syntax."""
if s is None:
raise ValueError("s argument must not be None")
lex = shlex(s, posix=posix)
lex.whitespace_split = True
if not comments:
lex.commenters = ''
return list(lex)
def join(split_command):
"""Return a shell-escaped string from *split_command*."""
return ' '.join(quote(arg) for arg in split_command)
_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 tt := lexer.get_token():
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))
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __phello__ | Folder | 0755 |
|
|
| __pycache__ | Folder | 0755 |
|
|
| asyncio | Folder | 0755 |
|
|
| collections | Folder | 0755 |
|
|
| concurrent | Folder | 0755 |
|
|
| config-3.12-x86_64-linux-gnu | Folder | 0755 |
|
|
| ctypes | Folder | 0755 |
|
|
| curses | Folder | 0755 |
|
|
| dbm | Folder | 0755 |
|
|
| Folder | 0755 |
|
||
| encodings | Folder | 0755 |
|
|
| html | Folder | 0755 |
|
|
| http | Folder | 0755 |
|
|
| importlib | Folder | 0755 |
|
|
| json | Folder | 0755 |
|
|
| lib-dynload | Folder | 0755 |
|
|
| logging | Folder | 0755 |
|
|
| multiprocessing | Folder | 0755 |
|
|
| pydoc_data | Folder | 0755 |
|
|
| re | Folder | 0755 |
|
|
| sqlite3 | Folder | 0755 |
|
|
| test | Folder | 0755 |
|
|
| tomllib | Folder | 0755 |
|
|
| unittest | Folder | 0755 |
|
|
| urllib | Folder | 0755 |
|
|
| venv | Folder | 0755 |
|
|
| wsgiref | Folder | 0755 |
|
|
| xml | Folder | 0755 |
|
|
| xmlrpc | Folder | 0755 |
|
|
| zipfile | Folder | 0755 |
|
|
| zoneinfo | Folder | 0755 |
|
|
| EXTERNALLY-MANAGED | File | 645 B | 0644 |
|
| LICENSE.txt | File | 13.61 KB | 0644 |
|
| __future__.py | File | 5.1 KB | 0644 |
|
| __hello__.py | File | 227 B | 0644 |
|
| _aix_support.py | File | 3.93 KB | 0644 |
|
| _collections_abc.py | File | 31.33 KB | 0644 |
|
| _compat_pickle.py | File | 8.56 KB | 0644 |
|
| _compression.py | File | 5.55 KB | 0644 |
|
| _distutils_system_mod.py | File | 5.58 KB | 0644 |
|
| _markupbase.py | File | 14.31 KB | 0644 |
|
| _osx_support.py | File | 21.51 KB | 0644 |
|
| _py_abc.py | File | 6.04 KB | 0644 |
|
| _pydatetime.py | File | 89.94 KB | 0644 |
|
| _pydecimal.py | File | 223.85 KB | 0644 |
|
| _pyio.py | File | 91.4 KB | 0644 |
|
| _pylong.py | File | 8.83 KB | 0644 |
|
| _sitebuiltins.py | File | 3.05 KB | 0644 |
|
| _strptime.py | File | 24.04 KB | 0644 |
|
| _sysconfigdata__linux_x86_64-linux-gnu.py | File | 48.34 KB | 0644 |
|
| _sysconfigdata__x86_64-linux-gnu.py | File | 48.34 KB | 0644 |
|
| _threading_local.py | File | 7.05 KB | 0644 |
|
| _weakrefset.py | File | 5.75 KB | 0644 |
|
| abc.py | File | 6.38 KB | 0644 |
|
| aifc.py | File | 33.41 KB | 0644 |
|
| antigravity.py | File | 500 B | 0644 |
|
| argparse.py | File | 99.37 KB | 0644 |
|
| ast.py | File | 62.75 KB | 0644 |
|
| base64.py | File | 20.12 KB | 0755 |
|
| bdb.py | File | 31.7 KB | 0644 |
|
| bisect.py | File | 3.34 KB | 0644 |
|
| bz2.py | File | 11.57 KB | 0644 |
|
| cProfile.py | File | 6.4 KB | 0755 |
|
| calendar.py | File | 24.82 KB | 0644 |
|
| cgi.py | File | 33.61 KB | 0755 |
|
| cgitb.py | File | 12.13 KB | 0644 |
|
| chunk.py | File | 5.37 KB | 0644 |
|
| cmd.py | File | 14.52 KB | 0644 |
|
| code.py | File | 10.44 KB | 0644 |
|
| codecs.py | File | 36.01 KB | 0644 |
|
| codeop.py | File | 5.77 KB | 0644 |
|
| colorsys.py | File | 3.97 KB | 0644 |
|
| compileall.py | File | 20.12 KB | 0644 |
|
| configparser.py | File | 52.53 KB | 0644 |
|
| contextlib.py | File | 26.99 KB | 0644 |
|
| contextvars.py | File | 129 B | 0644 |
|
| copy.py | File | 8.21 KB | 0644 |
|
| copyreg.py | File | 7.44 KB | 0644 |
|
| crypt.py | File | 3.82 KB | 0644 |
|
| csv.py | File | 16 KB | 0644 |
|
| dataclasses.py | File | 60.31 KB | 0644 |
|
| datetime.py | File | 268 B | 0644 |
|
| decimal.py | File | 320 B | 0644 |
|
| difflib.py | File | 81.36 KB | 0644 |
|
| dis.py | File | 29.5 KB | 0644 |
|
| doctest.py | File | 103.98 KB | 0644 |
|
| enum.py | File | 79.72 KB | 0644 |
|
| filecmp.py | File | 9.95 KB | 0644 |
|
| fileinput.py | File | 15.35 KB | 0644 |
|
| fnmatch.py | File | 5.86 KB | 0644 |
|
| fractions.py | File | 37.17 KB | 0644 |
|
| ftplib.py | File | 33.92 KB | 0644 |
|
| functools.py | File | 37.23 KB | 0644 |
|
| genericpath.py | File | 5.44 KB | 0644 |
|
| getopt.py | File | 7.31 KB | 0644 |
|
| getpass.py | File | 5.85 KB | 0644 |
|
| gettext.py | File | 21.24 KB | 0644 |
|
| glob.py | File | 8.53 KB | 0644 |
|
| graphlib.py | File | 9.43 KB | 0644 |
|
| gzip.py | File | 24.28 KB | 0644 |
|
| hashlib.py | File | 9.13 KB | 0644 |
|
| heapq.py | File | 22.48 KB | 0644 |
|
| hmac.py | File | 7.54 KB | 0644 |
|
| imaplib.py | File | 52.43 KB | 0644 |
|
| imghdr.py | File | 4.29 KB | 0644 |
|
| inspect.py | File | 122.48 KB | 0644 |
|
| io.py | File | 3.5 KB | 0644 |
|
| ipaddress.py | File | 76.46 KB | 0644 |
|
| keyword.py | File | 1.05 KB | 0644 |
|
| linecache.py | File | 5.52 KB | 0644 |
|
| locale.py | File | 76.72 KB | 0644 |
|
| lzma.py | File | 12.97 KB | 0644 |
|
| mailbox.py | File | 77.06 KB | 0644 |
|
| mailcap.py | File | 9.11 KB | 0644 |
|
| mimetypes.py | File | 22.35 KB | 0644 |
|
| modulefinder.py | File | 23.14 KB | 0644 |
|
| netrc.py | File | 6.76 KB | 0644 |
|
| nntplib.py | File | 40.12 KB | 0644 |
|
| ntpath.py | File | 29.32 KB | 0644 |
|
| nturl2path.py | File | 2.82 KB | 0644 |
|
| numbers.py | File | 11.2 KB | 0644 |
|
| opcode.py | File | 12.87 KB | 0644 |
|
| operator.py | File | 10.71 KB | 0644 |
|
| optparse.py | File | 58.95 KB | 0644 |
|
| os.py | File | 38.85 KB | 0644 |
|
| pathlib.py | File | 49.95 KB | 0644 |
|
| pdb.py | File | 67.83 KB | 0755 |
|
| pickle.py | File | 63.38 KB | 0644 |
|
| pickletools.py | File | 91.66 KB | 0644 |
|
| pipes.py | File | 8.77 KB | 0644 |
|
| pkgutil.py | File | 17.85 KB | 0644 |
|
| platform.py | File | 42.32 KB | 0755 |
|
| plistlib.py | File | 27.68 KB | 0644 |
|
| poplib.py | File | 13.83 KB | 0644 |
|
| posixpath.py | File | 17.21 KB | 0644 |
|
| pprint.py | File | 23.59 KB | 0644 |
|
| profile.py | File | 22.55 KB | 0755 |
|
| pstats.py | File | 28.6 KB | 0644 |
|
| pty.py | File | 5.99 KB | 0644 |
|
| py_compile.py | File | 7.69 KB | 0644 |
|
| pyclbr.py | File | 11.13 KB | 0644 |
|
| pydoc.py | File | 110.44 KB | 0755 |
|
| queue.py | File | 11.23 KB | 0644 |
|
| quopri.py | File | 7.01 KB | 0755 |
|
| random.py | File | 33.87 KB | 0644 |
|
| reprlib.py | File | 6.42 KB | 0644 |
|
| rlcompleter.py | File | 7.64 KB | 0644 |
|
| runpy.py | File | 12.6 KB | 0644 |
|
| sched.py | File | 6.2 KB | 0644 |
|
| secrets.py | File | 1.94 KB | 0644 |
|
| selectors.py | File | 19.21 KB | 0644 |
|
| shelve.py | File | 8.36 KB | 0644 |
|
| shlex.py | File | 13.04 KB | 0644 |
|
| shutil.py | File | 56.76 KB | 0644 |
|
| signal.py | File | 2.44 KB | 0644 |
|
| site.py | File | 23.34 KB | 0644 |
|
| sitecustomize.py | File | 155 B | 0644 |
|
| smtplib.py | File | 42.51 KB | 0755 |
|
| sndhdr.py | File | 7.27 KB | 0644 |
|
| socket.py | File | 36.53 KB | 0644 |
|
| socketserver.py | File | 27.2 KB | 0644 |
|
| sre_compile.py | File | 231 B | 0644 |
|
| sre_constants.py | File | 232 B | 0644 |
|
| sre_parse.py | File | 229 B | 0644 |
|
| ssl.py | File | 49.63 KB | 0644 |
|
| stat.py | File | 5.36 KB | 0644 |
|
| statistics.py | File | 49.05 KB | 0644 |
|
| string.py | File | 11.51 KB | 0644 |
|
| stringprep.py | File | 12.61 KB | 0644 |
|
| struct.py | File | 257 B | 0644 |
|
| subprocess.py | File | 86.65 KB | 0644 |
|
| sunau.py | File | 18.04 KB | 0644 |
|
| symtable.py | File | 10.5 KB | 0644 |
|
| sysconfig.py | File | 32 KB | 0644 |
|
| tabnanny.py | File | 11.26 KB | 0755 |
|
| tarfile.py | File | 109.92 KB | 0755 |
|
| telnetlib.py | File | 22.75 KB | 0644 |
|
| tempfile.py | File | 36.46 KB | 0644 |
|
| textwrap.py | File | 19.26 KB | 0644 |
|
| this.py | File | 1003 B | 0644 |
|
| threading.py | File | 58.71 KB | 0644 |
|
| timeit.py | File | 13.15 KB | 0755 |
|
| token.py | File | 2.42 KB | 0644 |
|
| tokenize.py | File | 20.72 KB | 0644 |
|
| trace.py | File | 28.5 KB | 0755 |
|
| traceback.py | File | 45.24 KB | 0644 |
|
| tracemalloc.py | File | 17.62 KB | 0644 |
|
| tty.py | File | 1.99 KB | 0644 |
|
| turtle.py | File | 142.93 KB | 0644 |
|
| types.py | File | 10.74 KB | 0644 |
|
| typing.py | File | 114.68 KB | 0644 |
|
| uu.py | File | 7.19 KB | 0755 |
|
| uuid.py | File | 28.96 KB | 0644 |
|
| warnings.py | File | 21.25 KB | 0644 |
|
| wave.py | File | 22.24 KB | 0644 |
|
| weakref.py | File | 21.01 KB | 0644 |
|
| webbrowser.py | File | 23.07 KB | 0755 |
|
| xdrlib.py | File | 5.8 KB | 0644 |
|
| zipapp.py | File | 7.37 KB | 0644 |
|
| zipimport.py | File | 27.47 KB | 0644 |
|