!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/usr/lib/python2.4/site-packages/Ft/Xml/ThirdParty/Xvif/   drwxr-xr-x
Free 3.38 GB of 27.03 GB (12.51%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     xmlchargen.py (13.05 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
# From 2nd edition
BaseChar = "[#x0041-#x005A] | [#x0061-#x007A] | [#x00C0-#x00D6] | [#x00D8-#x00F6] | [#x00F8-#x00FF] | [#x0100-#x0131] | [#x0134-#x013E] | [#x0141-#x0148] | [#x014A-#x017E] | [#x0180-#x01C3] | [#x01CD-#x01F0] | [#x01F4-#x01F5] | [#x01FA-#x0217] | [#x0250-#x02A8] | [#x02BB-#x02C1] | #x0386 | [#x0388-#x038A] | #x038C | [#x038E-#x03A1] | [#x03A3-#x03CE] | [#x03D0-#x03D6] | #x03DA | #x03DC | #x03DE | #x03E0 | [#x03E2-#x03F3] | [#x0401-#x040C] | [#x040E-#x044F] | [#x0451-#x045C] | [#x045E-#x0481] | [#x0490-#x04C4] | [#x04C7-#x04C8] | [#x04CB-#x04CC] | [#x04D0-#x04EB] | [#x04EE-#x04F5] | [#x04F8-#x04F9] | [#x0531-#x0556] | #x0559 | [#x0561-#x0586] | [#x05D0-#x05EA] | [#x05F0-#x05F2] | [#x0621-#x063A] | [#x0641-#x064A] | [#x0671-#x06B7] | [#x06BA-#x06BE] | [#x06C0-#x06CE] | [#x06D0-#x06D3] | #x06D5 | [#x06E5-#x06E6] | [#x0905-#x0939] | #x093D | [#x0958-#x0961] | [#x0985-#x098C] | [#x098F-#x0990] | [#x0993-#x09A8] | [#x09AA-#x09B0] | #x09B2 | [#x09B6-#x09B9] | [#x09DC-#x09DD] | [#x09DF-#x09E1] | [#x09F0-#x09F1] | [#x0A05-#x0A0A] | [#x0A0F-#x0A10] | [#x0A13-#x0A28] | [#x0A2A-#x0A30] | [#x0A32-#x0A33] | [#x0A35-#x0A36] | [#x0A38-#x0A39] | [#x0A59-#x0A5C] | #x0A5E | [#x0A72-#x0A74] | [#x0A85-#x0A8B] | #x0A8D | [#x0A8F-#x0A91] | [#x0A93-#x0AA8] | [#x0AAA-#x0AB0] | [#x0AB2-#x0AB3] | [#x0AB5-#x0AB9] | #x0ABD | #x0AE0 | [#x0B05-#x0B0C] | [#x0B0F-#x0B10] | [#x0B13-#x0B28] | [#x0B2A-#x0B30] | [#x0B32-#x0B33] | [#x0B36-#x0B39] | #x0B3D | [#x0B5C-#x0B5D] | [#x0B5F-#x0B61] | [#x0B85-#x0B8A] | [#x0B8E-#x0B90] | [#x0B92-#x0B95] | [#x0B99-#x0B9A] | #x0B9C | [#x0B9E-#x0B9F] | [#x0BA3-#x0BA4] | [#x0BA8-#x0BAA] | [#x0BAE-#x0BB5] | [#x0BB7-#x0BB9] | [#x0C05-#x0C0C] | [#x0C0E-#x0C10] | [#x0C12-#x0C28] | [#x0C2A-#x0C33] | [#x0C35-#x0C39] | [#x0C60-#x0C61] | [#x0C85-#x0C8C] | [#x0C8E-#x0C90] | [#x0C92-#x0CA8] | [#x0CAA-#x0CB3] | [#x0CB5-#x0CB9] | #x0CDE | [#x0CE0-#x0CE1] | [#x0D05-#x0D0C] | [#x0D0E-#x0D10] | [#x0D12-#x0D28] | [#x0D2A-#x0D39] | [#x0D60-#x0D61] | [#x0E01-#x0E2E] | #x0E30 | [#x0E32-#x0E33] | [#x0E40-#x0E45] | [#x0E81-#x0E82] | #x0E84 | [#x0E87-#x0E88] | #x0E8A | #x0E8D | [#x0E94-#x0E97] | [#x0E99-#x0E9F] | [#x0EA1-#x0EA3] | #x0EA5 | #x0EA7 | [#x0EAA-#x0EAB] | [#x0EAD-#x0EAE] | #x0EB0 | [#x0EB2-#x0EB3] | #x0EBD | [#x0EC0-#x0EC4] | [#x0F40-#x0F47] | [#x0F49-#x0F69] | [#x10A0-#x10C5] | [#x10D0-#x10F6] | #x1100 | [#x1102-#x1103] | [#x1105-#x1107] | #x1109 | [#x110B-#x110C] | [#x110E-#x1112] | #x113C | #x113E | #x1140 | #x114C | #x114E | #x1150 | [#x1154-#x1155] | #x1159 | [#x115F-#x1161] | #x1163 | #x1165 | #x1167 | #x1169 | [#x116D-#x116E] | [#x1172-#x1173] | #x1175 | #x119E | #x11A8 | #x11AB | [#x11AE-#x11AF] | [#x11B7-#x11B8] | #x11BA | [#x11BC-#x11C2] | #x11EB | #x11F0 | #x11F9 | [#x1E00-#x1E9B] | [#x1EA0-#x1EF9] | [#x1F00-#x1F15] | [#x1F18-#x1F1D] | [#x1F20-#x1F45] | [#x1F48-#x1F4D] | [#x1F50-#x1F57] | #x1F59 | #x1F5B | #x1F5D | [#x1F5F-#x1F7D] | [#x1F80-#x1FB4] | [#x1FB6-#x1FBC] | #x1FBE | [#x1FC2-#x1FC4] | [#x1FC6-#x1FCC] | [#x1FD0-#x1FD3] | [#x1FD6-#x1FDB] | [#x1FE0-#x1FEC] | [#x1FF2-#x1FF4] | [#x1FF6-#x1FFC] | #x2126 | [#x212A-#x212B] | #x212E | [#x2180-#x2182] | [#x3041-#x3094] | [#x30A1-#x30FA] | [#x3105-#x312C] | [#xAC00-#xD7A3]"

Ideographic = "[#x4E00-#x9FA5] | #x3007 | [#x3021-#x3029]"

CombiningChar = "[#x0300-#x0345] | [#x0360-#x0361] | [#x0483-#x0486] | [#x0591-#x05A1] | [#x05A3-#x05B9] | [#x05BB-#x05BD] | #x05BF | [#x05C1-#x05C2] | #x05C4 | [#x064B-#x0652] | #x0670 | [#x06D6-#x06DC] | [#x06DD-#x06DF] | [#x06E0-#x06E4] | [#x06E7-#x06E8] | [#x06EA-#x06ED] | [#x0901-#x0903] | #x093C | [#x093E-#x094C] | #x094D | [#x0951-#x0954] | [#x0962-#x0963] | [#x0981-#x0983] | #x09BC | #x09BE | #x09BF | [#x09C0-#x09C4] | [#x09C7-#x09C8] | [#x09CB-#x09CD] | #x09D7 | [#x09E2-#x09E3] | #x0A02 | #x0A3C | #x0A3E | #x0A3F | [#x0A40-#x0A42] | [#x0A47-#x0A48] | [#x0A4B-#x0A4D] | [#x0A70-#x0A71] | [#x0A81-#x0A83] | #x0ABC | [#x0ABE-#x0AC5] | [#x0AC7-#x0AC9] | [#x0ACB-#x0ACD] | [#x0B01-#x0B03] | #x0B3C | [#x0B3E-#x0B43] | [#x0B47-#x0B48] | [#x0B4B-#x0B4D] | [#x0B56-#x0B57] | [#x0B82-#x0B83] | [#x0BBE-#x0BC2] | [#x0BC6-#x0BC8] | [#x0BCA-#x0BCD] | #x0BD7 | [#x0C01-#x0C03] | [#x0C3E-#x0C44] | [#x0C46-#x0C48] | [#x0C4A-#x0C4D] | [#x0C55-#x0C56] | [#x0C82-#x0C83] | [#x0CBE-#x0CC4] | [#x0CC6-#x0CC8] | [#x0CCA-#x0CCD] | [#x0CD5-#x0CD6] | [#x0D02-#x0D03] | [#x0D3E-#x0D43] | [#x0D46-#x0D48] | [#x0D4A-#x0D4D] | #x0D57 | #x0E31 | [#x0E34-#x0E3A] | [#x0E47-#x0E4E] | #x0EB1 | [#x0EB4-#x0EB9] | [#x0EBB-#x0EBC] | [#x0EC8-#x0ECD] | [#x0F18-#x0F19] | #x0F35 | #x0F37 | #x0F39 | #x0F3E | #x0F3F | [#x0F71-#x0F84] | [#x0F86-#x0F8B] | [#x0F90-#x0F95] | #x0F97 | [#x0F99-#x0FAD] | [#x0FB1-#x0FB7] | #x0FB9 | [#x20D0-#x20DC] | #x20E1 | [#x302A-#x302F] | #x3099 | #x309A"

Digit = "[#x0030-#x0039] | [#x0660-#x0669] | [#x06F0-#x06F9] | [#x0966-#x096F] | [#x09E6-#x09EF] | [#x0A66-#x0A6F] | [#x0AE6-#x0AEF] | [#x0B66-#x0B6F] | [#x0BE7-#x0BEF] | [#x0C66-#x0C6F] | [#x0CE6-#x0CEF] | [#x0D66-#x0D6F] | [#x0E50-#x0E59] | [#x0ED0-#x0ED9] | [#x0F20-#x0F29]"

Extender = "#x00B7 | #x02D0 | #x02D1 | #x0387 | #x0640 | #x0E46 | #x0EC6 | #x3005 | [#x3031-#x3035] | [#x309D-#x309E] | [#x30FC-#x30FE]"

import re,types,string
intervall = re.compile(r"^\[#x([0-9A-F]+)-#x([0-9A-F]+)\]$")
single = re.compile("^#x[0-9A-F]+$")

def uniclass(i):
    c = unichr(i)
    if c in (u'-',u']'):
        c = r'\x%02x' % i
    return c

def compatrepr(s):
    """Return a repr of a string that is syntactically correct in
    Python 1.5 as well."""
    if type(s) == types.UnicodeType:
        return "unicode(%s,'utf-16-be')" % repr(s.encode('utf-16-be'))
    return repr(s)

class CharacterParser:
    def __init__(self, chars = None):
        self.alts = []
        self.contents = {}
        if chars is None:
            return
        alts = chars.split(" | ")
        for a in alts:
            m = single.match(a)
            if m:
                val = int(a[2:],16)
                self.contents[val] = val
                self.alts.append(val)
                continue
            m = intervall.match(a)
            assert m, a
            val1 = int(m.group(1),16)
            val2 = int(m.group(2),16)
            assert val2>val1
            for i in range(val1,val2+1):
                self.contents[i] = i
            self.alts.append((val1,val2))

    def build_alts(self):
        values = self.contents.keys()
        values.sort()
        start = stop = values[0]
        for i in values[1:]:
            if i == stop+1:
                stop = i
                continue
            if start==stop:
                self.alts.append(start)
            else:
                self.alts.append((start,stop))
            start = stop = i
        if start==stop:
            self.alts.append(start)
        else:
            self.alts.append((start,stop))

    def as_spec_string(self):
        """Return the character class in the notation of the XML
        recommendation"""
        alts = []
        for a in self.alts:
            if type(a) is types.TupleType:
                alts.append("[#%0.4X-#%0.4X]" % a)
            else:
                alts.append("#%0.4X" % a)
        return string.join(alts," | ")

    def as_re_class(self):
        """Return the character class as a regular expression"""
        alts = [u"["]
        xalts = self.alts
        # sre matches from left to right, so starting with the
        # smallest ordinals is faster
        #xalts.reverse()
        for a in xalts:
            if type(a) is types.TupleType:
                alts.append(u"%s-%s" % (uniclass(a[0]),uniclass(a[1])))
            else:
                alts.append(uniclass(a))
        alts.append(u"]")
        return string.join(alts,u"")

    def _fill_range(self,alts,low,high):
        assert low<=high
        alts.append((sre_parse.NEGATE, None))
        if low == high:
            alts.append((sre_parse.LITERAL, low))
        else:
            alts.append((sre_parse.RANGE,(low,high)))
        alts.append((sre_parse.NEGATE, None))

    def _as_sre_subpattern(self,pattern):
        s = sre_parse.SubPattern(pattern)
        alts = []
        old = 0
        for a in self.alts:
            if type(a) is types.TupleType:
                self._fill_range(alts,old,a[0]-1)
                alts.append((sre_parse.RANGE,a))
                old = a[1]+1
            else:
                self._fill_range(alts,old,a-1)
                alts.append((sre_parse.LITERAL,a))
                old = a+1
        s.append((sre_parse.IN,alts))
        return s

    def as_sre_class(self):
        import sre_parse,sre_compile
        p = sre_parse.Pattern()
        p.flags = sre_parse.SRE_FLAG_UNICODE
        p.str = self.as_re_class()
        return sre_compile.compile(self._as_sre_subpattern(p))

    def as_chardict(self):
        res = {}
        for k in self.contents.keys():
            c = unichr(k)
            res[c] = c
        return res

    def as_array(self):
        # Using array slows down the matching process
        #import array
        #res = array.array("b",[0]*65536)
        res = [0] * 65536
        for k in self.contents.keys():
            res[k] = 1
        return res

def union(*args):
    result = CharacterParser()
    for a in args:
        result.contents.update(a.contents)
    result.build_alts()
    return result

BaseChar = CharacterParser(BaseChar)
Ideographic = CharacterParser(Ideographic)
CombiningChar = CharacterParser(CombiningChar)
Digit = CharacterParser(Digit)
Extender = CharacterParser(Extender)

Letter = union(BaseChar, Ideographic)

NameChar = union(Letter, Digit,
                 CharacterParser("#x002E | #x002D | #x005F | #x003A"),
                 CombiningChar, Extender)

# not in XML
FirstNameChar = union(Letter,
                      CharacterParser("#x003A | #x005F"))

LetterDigit = union(Letter, Digit)
# Namespaces in XML

FirstNCNameChar = union(Letter, CharacterParser ("#x005F"))
NCNameChar=union(Letter, Digit, CombiningChar, Extender, CharacterParser ("#x005F | #x002E | #x002D"))


if __name__=='__main__':
    print "# This file was generated using xmlchargen.py"
    print "S =",compatrepr("[\n\t \r]+")
    print "BaseChar =",compatrepr(BaseChar.as_re_class())
    print "Ideographic =",compatrepr(Ideographic.as_re_class())
    print "CombiningChar =",compatrepr(CombiningChar.as_re_class())
    print "Digit =",compatrepr(Digit.as_re_class())
    print "Extender =",compatrepr(Extender.as_re_class())
    print "Letter =",compatrepr(Letter.as_re_class())
    print "NameChar =",compatrepr(NameChar.as_re_class())
    first = FirstNameChar.as_re_class()
    follow = NameChar.as_re_class()
    name = first+follow+"*"
    print "Name =",compatrepr(name)
    print "Names = Name+'('+S+Name+')*'"
    print "Nmtoken =",compatrepr(follow+"+")
    print "Nmtokens = Nmtoken+'('+S+Nmtoken+')*'"
    print "FirstNCNameChar =",compatrepr(FirstNCNameChar.as_re_class())
    print "NCNameChar =",compatrepr(NCNameChar.as_re_class())
    ncfirst = FirstNCNameChar.as_re_class()
    ncfollow = NCNameChar.as_re_class()
    ncname = "^"+ncfirst+ncfollow+"*$"
    print "NCName =",compatrepr(ncname)

    print "import re"
    for n in ['BaseChar','Ideographic','CombiningChar','Digit',
             'Extender','Letter','NameChar','Name','Names',
              'Nmtoken','Nmtokens','FirstNCNameChar','NCNameChar','NCName']:
        print '_re_%s = None' % n
        print 'def re_%s():' % n
        print '  global _re_%s' % n
        print '  if _re_%s is None:' % n
        print '    _re_%s = re.compile(%s)' % (n,n)
        print '  return _re_%s' % n

# BEGIN GARBAGE: various data about the XML character classes,
#                in comparison to the Python 2.0 database

# BaseChar: all alpha, except for 0x2182 0x2181 0x2180 0x212e
#           (roman numerals 1000, 5000, 10000: category Nl)
#           (estimated symbol, category So in 3.0.1, Ll in 2.0)

# Ideographic: all alnum (3007, 3021-3029 are digit)

# LetterDigit: all alnum except for 212e
#

# \w covers much more than NameChar, e.g.
#    U+00AA: FEMININE ORDINAL INDICATOR (Ll)
#    U+00B2: SUPERSCRIPT TWO            (No)
#    ...

#  for i in LetterDigit.contents.keys():
#      c = unichr(i)
#      if not c.isalnum():
#          print hex(i),

#  for i in range(65536):
#      c = unichr(i)
#      if c.isdigit() and not LetterDigit.contents.has_key(i):
#          print hex(i),

# Categories:
#  Normative
#       Mn = Mark, Non-Spacing
#       Mc = Mark, Spacing Combining
#       Me = Mark, Enclosing
#
#       Nd = Number, Decimal Digit
#       Nl = Number, Letter
#       No = Number, Other
#
#       Zs = Separator, Space
#       Zl = Separator, Line
#       Zp = Separator, Paragraph
#
#       Cc = Other, Control
#       Cf = Other, Format
#       Cs = Other, Surrogate
#       Co = Other, Private Use
#       Cn = Other, Not Assigned
#
#   Informative
#       Lu = Letter, Uppercase
#       Ll = Letter, Lowercase
#       Lt = Letter, Titlecase
#       Lm = Letter, Modifier
#       Lo = Letter, Other
#
#       Pc = Punctuation, Connector
#       Pd = Punctuation, Dash
#       Ps = Punctuation, Open
#       Pe = Punctuation, Close
#      *Pi = Punctuation, Initial quote
#      *Pf = Punctuation, Final quote
#       Po = Punctuation, Other
#
#       Sm = Symbol, Math
#       Sc = Symbol, Currency
#       Sk = Symbol, Modifier
#       So = Symbol, Other

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0045 ]--