;ò †ùšBc@s"dZdkZdkTddddddd d d d d ddddddddgZeZeZeZ e Z e Z hZdZdd„Zdd„Zdd„Zdd„Zdd„Zdd„Zd„Zd„Zdd „Zd!fd"„ƒYZd#fd$„ƒYZd%fd&„ƒYZdS('s©Support for regular expressions (RE). This module provides regular expression matching operations similar to those found in Perl. It's 8-bit clean: the strings being processed may contain both null bytes and characters whose high bit is set. Regular expression pattern strings may not contain null bytes, but can specify the null byte using the \\number notation. Characters with the high bit set may be included. Regular expressions can contain both special and ordinary characters. Most ordinary characters, like "A", "a", or "0", are the simplest regular expressions; they simply match themselves. You can concatenate ordinary characters, so last matches the string 'last'. The special characters are: "." Matches any character except a newline. "^" Matches the start of the string. "$" Matches the end of the string. "*" Matches 0 or more (greedy) repetitions of the preceding RE. Greedy means that it will match as many repetitions as possible. "+" Matches 1 or more (greedy) repetitions of the preceding RE. "?" Matches 0 or 1 (greedy) of the preceding RE. *?,+?,?? Non-greedy versions of the previous three special characters. {m,n} Matches from m to n repetitions of the preceding RE. {m,n}? Non-greedy version of the above. "\\" Either escapes special characters or signals a special sequence. [] Indicates a set of characters. A "^" as the first character indicates a complementing set. "|" A|B, creates an RE that will match either A or B. (...) Matches the RE inside the parentheses. The contents can be retrieved or matched later in the string. (?iLmsx) Set the I, L, M, S, or X flag for the RE. (?:...) Non-grouping version of regular parentheses. (?P...) The substring matched by the group is accessible by name. (?P=name) Matches the text matched earlier by the group named name. (?#...) A comment; ignored. (?=...) Matches if ... matches next, but doesn't consume the string. (?!...) Matches if ... doesn't match next. The special sequences consist of "\\" and a character from the list below. If the ordinary character is not on the list, then the resulting RE will match the second character. \\number Matches the contents of the group of the same number. \\A Matches only at the start of the string. \\Z Matches only at the end of the string. \\b Matches the empty string, but only at the start or end of a word. \\B Matches the empty string, but not at the start or end of a word. \\d Matches any decimal digit; equivalent to the set [0-9]. \\D Matches any non-digit character; equivalent to the set [^0-9]. \\s Matches any whitespace character; equivalent to [ \\t\\n\\r\\f\\v]. \\S Matches any non-whitespace character; equiv. to [^ \\t\\n\\r\\f\\v]. \\w Matches any alphanumeric character; equivalent to [a-zA-Z0-9_]. With LOCALE, it will match the set [0-9_] plus characters defined as letters for the current locale. \\W Matches the complement of \\w. \\\\ Matches a literal backslash. This module exports the following functions: match Match a regular expression pattern to the beginning of a string. search Search a string for the presence of a pattern. sub Substitute occurrences of a pattern found in a string. subn Same as sub, but also return the number of substitutions made. split Split a string by the occurrences of a pattern. findall Find all occurrences of a pattern in a string. compile Compile a pattern into a RegexObject. escape Backslash all non-alphanumerics in a string. This module exports the following classes: RegexObject Holds a compiled regular expression pattern. MatchObject Contains information about pattern matches. Some of the functions in this module takes flags as optional parameters: I IGNORECASE Perform case-insensitive matching. L LOCALE Make \w, \W, \b, \B, dependent on the current locale. M MULTILINE "^" matches the beginning of lines as well as the string. "$" matches the end of lines as well as the string. S DOTALL "." matches any character at all, including the newline. X VERBOSE Ignore whitespace and comments for nicer looking RE's. This module also defines an exception 'error'. N(s*smatchssearchssubssubnssplitsfindallsescapescompilesIsLsMsSsXs IGNORECASEsLOCALEs MULTILINEsDOTALLsVERBOSEserroriicCsp||f}y t|SWntj onXt||ƒ}ttƒtjoti ƒn|t|<|SdS(N( spatternsflagsskeys_cachesKeyErrorscompilesvalueslens _MAXCACHEsclear(spatternsflagssvalueskey((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys _cachecompile€s   cCst||ƒi|ƒSdS(sšmatch (pattern, string[, flags]) -> MatchObject or None If zero or more characters at the beginning of string match the regular expression pattern, return a corresponding MatchObject instance. Return None if the string does not match the pattern; note that this is different from a zero-length match. Note: If you want to locate a match anywhere in string, use search() instead. N(s _cachecompilespatternsflagssmatchsstring(spatternsstringsflags((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysmatchŒs cCst||ƒi|ƒSdS(s~search (pattern, string[, flags]) -> MatchObject or None Scan through string looking for a location where the regular expression pattern produces a match, and return a corresponding MatchObject instance. Return None if no position in the string matches the pattern; note that this is different from finding a zero-length match at some point in the string. N(s _cachecompilespatternsflagsssearchsstring(spatternsstringsflags((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssearch›s cCs@t|ƒtdƒjot|ƒ}n|i|||ƒSdS(s†sub(pattern, repl, string[, count=0]) -> string Return the string obtained by replacing the leftmost non-overlapping occurrences of pattern in string by the replacement repl. If the pattern isn't found, string is returned unchanged. repl can be a string or a function; if a function, it is called for every non-overlapping occurrence of pattern. The function takes a single match object argument, and returns the replacement string. The pattern may be a string or a regex object; if you need to specify regular expression flags, you must use a regex object, or use embedded modifiers in a pattern; e.g. sub("(?i)b+", "x", "bbbb BBBB") returns 'x x'. The optional argument count is the maximum number of pattern occurrences to be replaced; count must be a non-negative integer, and the default value of 0 means to replace all occurrences. sN(stypespatterns _cachecompilessubsreplsstringscount(spatternsreplsstringscount((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssub§scCs@t|ƒtdƒjot|ƒ}n|i|||ƒSdS(s¯subn(pattern, repl, string[, count=0]) -> (string, num substitutions) Perform the same operation as sub(), but return a tuple (new_string, number_of_subs_made). sN(stypespatterns _cachecompilessubnsreplsstringscount(spatternsreplsstringscount((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssubnÀscCs=t|ƒtdƒjot|ƒ}n|i||ƒSdS(s‘split(pattern, string[, maxsplit=0]) -> list of strings Split string by the occurrences of pattern. If capturing parentheses are used in pattern, then the text of all groups in the pattern are also returned as part of the resulting list. If maxsplit is nonzero, at most maxsplit splits occur, and the remainder of the string is returned as the final element of the list. sN(stypespatterns _cachecompilessplitsstringsmaxsplit(spatternsstringsmaxsplit((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssplitËs cCs:t|ƒtdƒjot|ƒ}n|i|ƒSdS(s5findall(pattern, string) -> list Return a list of all non-overlapping matches of pattern in string. If one or more groups are present in the pattern, return a list of groups; this will be a list of tuples if the pattern has more than one group. Empty matches are included in the result. sN(stypespatterns _cachecompilesfindallsstring(spatternsstring((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysfindallÚscCst|ƒ}x_tt|ƒƒD]K}||}|iƒ o-|djod|| string Return string with all non-alphanumerics backslashed; this is useful if you want to match an arbitrary literal string that may have regular expression metacharacters in it. ss\000s\sN( slistspatternsresultsrangeslensischarsisalnumsjoin(spatternsischarsresult((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysescapeçs   cCs/h}t|||ƒ}t||||ƒSdS(sÉcompile(pattern[, flags]) -> RegexObject Compile a regular expression pattern into a regular expression object, which can be used for matching using its match() and search() methods. N(s groupindexs pcre_compilespatternsflagsscodes RegexObject(spatternsflagsscodes groupindex((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyscompile÷ss RegexObjectcBs}tZdZd„Zded„Zded„Zdd„Zdd„Zdd„Z d„Z d „Z d „Z d „Z RS( sÊHolds a compiled regular expression pattern. Methods: match Match the pattern to the beginning of a string. search Search a string for the presence of the pattern. sub Substitute occurrences of the pattern found in a string. subn Same as sub, but also return the number of substitutions made. split Split a string by the occurrences of the pattern. findall Find all occurrences of the pattern in a string. cCs(||_||_||_||_dS(N(scodesselfsflagsspatterns groupindex(sselfspatternsflagsscodes groupindex((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys__init__s   icCs |tjp|t|ƒjot|ƒ}n||jo |}n|ii|||dƒ}|tjotSnt|ƒ|_ t |||||ƒSdS(sõsearch(string[, pos][, endpos]) -> MatchObject or None Scan through string looking for a location where this regular expression produces a match, and return a corresponding MatchObject instance. Return None if no position in the string matches the pattern; note that this is different from finding a zero-length match at some point in the string. The optional pos and endpos parameters have the same meaning as for the match() method. iN( sendpossNoneslensstringspossselfscodesmatchsregss _num_regss MatchObject(sselfsstringspossendpossregs((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssearchs    cCs |tjp|t|ƒjot|ƒ}n||jo |}n|ii|||tƒ}|tjotSnt|ƒ|_ t |||||ƒSdS(smatch(string[, pos][, endpos]) -> MatchObject or None If zero or more characters at the beginning of string match this regular expression, return a corresponding MatchObject instance. Return None if the string does not match the pattern; note that this is different from a zero-length match. Note: If you want to locate a match anywhere in string, use search() instead. The optional second parameter pos gives an index in the string where the search is to start; it defaults to 0. This is not completely equivalent to slicing the string; the '' pattern character matches at the real beginning of the string and at positions just after a newline, but not necessarily at the index where the search is to start. The optional parameter endpos limits how far the string will be searched; it will be as if the string is endpos characters long, so only the characters from pos to endpos will be searched for a match. N( sendpossNoneslensstringspossselfscodesmatchsANCHOREDsregss _num_regss MatchObject(sselfsstringspossendpossregs((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysmatch4s   cCs|i|||ƒdSdS(s]sub(repl, string[, count=0]) -> string Return the string obtained by replacing the leftmost non-overlapping occurrences of the compiled pattern in string by the replacement repl. If the pattern isn't found, string is returned unchanged. Identical to the sub() function, using the compiled pattern. iN(sselfssubnsreplsstringscount(sselfsreplsstringscount((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssubXs cCs_|djo td‚n|djo ti}nd}d} d}g}t|ƒ}t |ƒt dƒjo`yt t|ƒ}Wn@ttfj o.t||d|gƒ} |t d„}qéXt} nt||d|gƒ} |ii}|i}x9||jo | |jo||| |dƒ} | oPnt| ƒ|_| d\} } | | jo |jno"| d} |||| !ƒqn| | jo||| | !ƒn| o&| | _| | _||| ƒƒn ||ƒ| } }| | jo| d} |||| !ƒn|d}qW||| ƒdi|ƒ|fSdS(sœsubn(repl, string[, count=0]) -> tuple Perform the same operation as sub(), but return a tuple (new_string, number_of_subs_made). isnegative substitution countiÿÿÿÿscCs |||ƒS(N(sexpandsmsrepl(smsreplsexpand((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys~siN(scountserrorssyssmaxintsnsposs lastmatchsresultsslenssourcesendstypesrepls pcre_expands_Dummys TypeErrors MatchObjectsselfsmsNonescodesmatchsappendsregss _num_regssisjsjoin(sselfsreplssourcescountsresultss lastmatchsappendsendsmatchsregsspossisjsmsn((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssubnesZ                cCs†|djo td‚n|djo ti}nd} d} d} g} t|ƒ}|i i }| i} x| |joò||| |dƒ}| oPn|d\}}||jo#| |joPn| d} qpn| || |!ƒ|d}|oVxS|D]G\}}|djp |djo t}n|||!}| |ƒqWn|} } | d} qpW| || ƒ| SdS(sµsplit(source[, maxsplit=0]) -> list of strings Split string by the occurrences of the compiled pattern. If capturing parentheses are used in the pattern, then the text of all groups in the pattern are also returned as part of the resulting list. If maxsplit is nonzero, at most maxsplit splits occur, and the remainder of the string is returned as the final element of the list. isnegative split countiiÿÿÿÿN(smaxsplitserrorssyssmaxintsnsposs lastmatchsresultsslenssourcesendsselfscodesmatchsappendsregssisjsrestsasbsNonesgroup(sselfssourcesmaxsplitsasregssbsendsisjsresultsspossns lastmatchsappendsgroupsrestsmatch((s*/mnt/gmirror/ports/devel/aap/work/aapre.pyssplit¢sH                 cCs-d} t|ƒ}g} |ii} | i} xõ| |joç| || |dƒ}| oPn|d\}}|d} | o|||!}nrt| ƒdjo!| d\}}|||!}n>g}x(| D] \}}|i|||!ƒqÓWt|ƒ}| |ƒt|| dƒ} q0W| SdS(sUfindall(source) -> list Return a list of all non-overlapping matches of the compiled pattern in string. If one or more groups are present in the pattern, return a list of groups; this will be a list of tuples if the pattern has more than one group. Empty matches are included in the result. iiN(sposslenssourcesendsresultssselfscodesmatchsappendsregssisjsrestsgrsasbstuplesmax(sselfssourcesasregssbsendsgrsisjspossresultssappendsrestsmatch((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysfindallÑs4         cCsttttfSdS(N(sNone(sself((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys__getinitargs__öscCs|i|i|ifSdS(N(sselfspatternsflagss groupindex(sself((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys __getstate__ûscCs:|d|_|d|_|d|_t|Œ|_dS(Niii(s statetuplesselfspatternsflagss groupindexs pcre_compilescode(sselfs statetuple((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys __setstate__ýs   (s__name__s __module__s__doc__s__init__sNonessearchsmatchssubssubnssplitsfindalls__getinitargs__s __getstate__s __setstate__(((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys RegexObjects  $ = / %  s_DummycBstZeZRS(N(s__name__s __module__sNonesgroup(((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys_Dummyss MatchObjectcBs\tZdZd„Zdd„Zdd„Zdd„Zed„Zd„Z ed„Z RS( sÕHolds a compiled regular expression pattern. Methods: start Return the index of the start of a matched substring. end Return the index of the end of a matched substring. span Return a tuple of (start, end) of a matched substring. groups Return a tuple of all the subgroups of the match. group Return one or more subgroups of the match. groupdict Return a dictionary of all the named subgroups of the match. cCs1||_||_||_||_||_dS(N(sresselfsstringspossendpossregs(sselfsresstringspossendpossregs((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys__init__s     icCsnt|ƒtdƒjoBy|ii|}Wq[ttfj otd| ‚q[Xn|i|dSdS(sstart([group=0]) -> int or None Return the index of the start of the substring matched by group; group defaults to zero (meaning the whole matched substring). Return -1 if group exists but did not contribute to the match. ssgroup %s is undefinediN( stypesgsselfsres groupindexsKeyErrors TypeErrors IndexErrorsregs(sselfsg((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysstartscCsnt|ƒtdƒjoBy|ii|}Wq[ttfj otd| ‚q[Xn|i|dSdS(send([group=0]) -> int or None Return the indices of the end of the substring matched by group; group defaults to zero (meaning the whole matched substring). Return -1 if group exists but did not contribute to the match. ssgroup %s is undefinediN( stypesgsselfsres groupindexsKeyErrors TypeErrors IndexErrorsregs(sselfsg((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysend+scCsjt|ƒtdƒjoBy|ii|}Wq[ttfj otd| ‚q[Xn|i|SdS(súspan([group=0]) -> tuple Return the 2-tuple (m.start(group), m.end(group)). Note that if group did not contribute to the match, this is (-1, -1). Group defaults to zero (meaning the whole matched substring). ssgroup %s is undefinedN( stypesgsselfsres groupindexsKeyErrors TypeErrors IndexErrorsregs(sselfsg((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysspan;scCs‰g}xrtd|iiƒD][}|i|\}}|djp |djo|i |ƒq|i |i ||!ƒqWt |ƒSdS(sgroups([default=None]) -> tuple Return a tuple containing all the subgroups of the match, from 1 up to however many groups are in the pattern. The default argument is used for groups that did not participate in the match. iiÿÿÿÿN( sresultsrangesselfsres _num_regssgsregssasbsappendsdefaultsstringstuple(sselfsdefaultsasbsgsresult((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysgroupsKscGsWt|ƒdjo df}ng}xæ|D]Þ}t|ƒtdƒjoBy|ii|}WqŽtt fj ot d| ‚qŽXn|t|i ƒjot d| ‚n|i |\}}|djp |djo|itƒq-|i|i||!ƒq-Wt|ƒdjot|ƒSn$t|ƒdjo |dSnfSdS(sÜgroup([group1, group2, ...]) -> string or tuple Return one or more subgroups of the match. If there is a single argument, the result is a single string; if there are multiple arguments, the result is a tuple with one item per argument. Without arguments, group1 defaults to zero (i.e. the whole match is returned). If a groupN argument is zero, the corresponding return value is the entire matching string; if it is in the inclusive range [1..99], it is the string matching the the corresponding parenthesized group. If a group number is negative or larger than the number of groups defined in the pattern, an IndexError exception is raised. If a group is contained in a part of the pattern that did not match, the corresponding result is None. If a group is contained in a part of the pattern that matched multiple times, the last match is returned. If the regular expression uses the (?P...) syntax, the groupN arguments may also be strings identifying groups by their group name. If a string argument is not used as a group name in the pattern, an IndexError exception is raised. issgroup %s is undefinediÿÿÿÿiN(slensgroupssresultsgstypesselfsres groupindexsKeyErrors TypeErrors IndexErrorsregssasbsappendsNonesstringstuple(sselfsgroupssasgsbsresult((s*/mnt/gmirror/ports/devel/aap/work/aapre.pysgroup]s,  cCs€h}xo|iiiƒD][\}}|i|\}}|djp |djo||| dictionary Return a dictionary containing all the named subgroups of the match, keyed by the subgroup name. The default argument is used for groups that did not participate in the match. iÿÿÿÿN( sadictsselfsres groupindexsitemssnamesindexsregssasbsdefaultsstring(sselfsdefaultsasindexsbsnamesadict((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys groupdictŒs ( s__name__s __module__s__doc__s__init__sstartsendsspansNonesgroupssgroups groupdict(((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys MatchObjects       /(s__doc__ssysspcres__all__s IGNORECASEsIsLOCALEsLs MULTILINEsMsDOTALLsSsVERBOSEsXs_caches _MAXCACHEs _cachecompilesmatchssearchssubssubnssplitsfindallsescapescompiles RegexObjects_Dummys MatchObject(sescapessubns_cachesfindalls RegexObjectssubs__all__ssplitsmatchs_DummysIsMsLsSsXssysssearchs MatchObjectscompiles _MAXCACHEs _cachecompile((s*/mnt/gmirror/ports/devel/aap/work/aapre.pys?Ys, ?      û