Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4

Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4

Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4

Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4

Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4

Warning: Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
ZMc@sdZdZddkZddkZddklZdZhadZdefdYZ d e fd YZ d e fd YZ d Z defdYZ de fdYZde fdYZde fdYZde fdYZdZdS(s Python parse tree definitions. This is a very concrete parse tree; we need to keep every token and even the comments and whitespace between tokens. There's also a pattern matching implementation here. s#Guido van Rossum iN(tStringIOicCsltpUddkl}xB|iiD]-\}}t|tjo|t|\}}||jo%|djodS|ii|dSq(WdS(s The node immediately preceding the invocant in their parent's children list. If the invocant does not have a previous sibling, it is None. iiN(R&R'R<R,(RR=R@((s$/usr/lib/python2.6/lib2to3/pytree.pyt prev_siblings   cCs"|i}|djodS|iS(s Return the string immediately following the invocant node. This is effectively equivalent to node.next_sibling.prefix uN(RAR'R#(Rtnext_sib((s$/usr/lib/python2.6/lib2to3/pytree.pyt get_suffixs  iicCst|idS(Ntascii(tunicodetencode(R((s$/usr/lib/python2.6/lib2to3/pytree.pyt__str__sN((ii(t__name__t __module__t__doc__R'RR&R,R+R;RRt__hash__RRRRRR$R%R6R:R0R>tpropertyRARBRDtsyst version_infoRH(((s$/usr/lib/python2.6/lib2to3/pytree.pyR "s0          tNodecBseZdZdddZdZdZeidjo eZ ndZ dZ dZ d Z d Zd ZeeeZd Zd ZdZRS(s+Concrete implementation for interior nodes.cCs|djp t|||_t||_x:|iD]/}|idjptt|||_q9W|dj o ||_ndS(s Initializer. Takes a type constant (a symbol number >= 256), a sequence of child nodes, and an optional context keyword argument. As a side effect, the parent pointers of the children are updated. iN(RRR*R,R&R'treprR#(RRR,tcontextR#R4((s$/usr/lib/python2.6/lib2to3/pytree.pyt__init__s      cCs#d|iit|i|ifS(s)Return a canonical string representation.s %s(%s, %r)(RRIR RR,(R((s$/usr/lib/python2.6/lib2to3/pytree.pyt__repr__s  cCsditt|iS(sk Return a pretty string representation. This reproduces the input source exactly. u(tjointmapRFR,(R((s$/usr/lib/python2.6/lib2to3/pytree.pyt __unicode__siicCs"|i|if|i|ifjS(sCompare two nodes for equality.(RR,(RR((s$/usr/lib/python2.6/lib2to3/pytree.pyRscCs4t|ig}|iD]}||iq~S(s$Return a cloned (deep) copy of self.(RPRR,R(Rt_[1]R4((s$/usr/lib/python2.6/lib2to3/pytree.pyRsccs9x-|iD]"}x|iD] }|VqWq W|VdS(s*Return a post-order iterator for the tree.N(R,R(RR@R9((s$/usr/lib/python2.6/lib2to3/pytree.pyRs    ccs9|Vx-|iD]"}x|iD] }|Vq"WqWdS(s)Return a pre-order iterator for the tree.N(R,R(RR@R9((s$/usr/lib/python2.6/lib2to3/pytree.pyRs   cCs|ipdS|idiS(sO The whitespace and comments preceding this node in the input. ti(R,R#(R((s$/usr/lib/python2.6/lib2to3/pytree.pyt_prefix_getter$s cCs"|io||id_ndS(Ni(R,R#(RR#((s$/usr/lib/python2.6/lib2to3/pytree.pyt_prefix_setter,s cCs4||_d|i|_||i|<|idS(s Equivalent to 'node.children[i] = child'. This method also sets the child's parent attribute appropriately. N(R&R'R,R0(RR=R@((s$/usr/lib/python2.6/lib2to3/pytree.pyt set_child2s  cCs*||_|ii|||idS(s Equivalent to 'node.children.insert(i, child)'. This method also sets the child's parent attribute appropriately. N(R&R,tinsertR0(RR=R@((s$/usr/lib/python2.6/lib2to3/pytree.pyt insert_child<s cCs'||_|ii||idS(s Equivalent to 'node.children.append(child)'. This method also sets the child's parent attribute appropriately. N(R&R,R/R0(RR@((s$/usr/lib/python2.6/lib2to3/pytree.pyt append_childEs N(ii(RIRJRKR'RSRTRWRNRORHRRRRRZR[RMR#R\R^R_(((s$/usr/lib/python2.6/lib2to3/pytree.pyRPs           R7cBseZdZdZdZdZd d dZdZdZ e i djo e Z ndZ dZd Zd Zd Zd ZeeeZRS(s'Concrete implementation for leaf nodes.RYicCsd|jo djnp t||dj o|\|_\|_|_n||_||_|dj o ||_ndS(s Initializer. Takes a type constant (a token number < 256), a string value, and an optional context keyword argument. iiN(RR't_prefixR8tcolumnRtvalue(RRRbRRR#((s$/usr/lib/python2.6/lib2to3/pytree.pyRSXs(    cCsd|ii|i|ifS(s)Return a canonical string representation.s %s(%r, %r)(RRIRRb(R((s$/usr/lib/python2.6/lib2to3/pytree.pyRTgs cCs|it|iS(sk Return a pretty string representation. This reproduces the input source exactly. (R#RFRb(R((s$/usr/lib/python2.6/lib2to3/pytree.pyRWmsicCs"|i|if|i|ifjS(sCompare two nodes for equality.(RRb(RR((s$/usr/lib/python2.6/lib2to3/pytree.pyRxscCs+t|i|i|i|i|iffS(s$Return a cloned (deep) copy of self.(R7RRbR#R8Ra(R((s$/usr/lib/python2.6/lib2to3/pytree.pyR|sccs |VdS(s*Return a post-order iterator for the tree.N((R((s$/usr/lib/python2.6/lib2to3/pytree.pyRsccs |VdS(s)Return a pre-order iterator for the tree.N((R((s$/usr/lib/python2.6/lib2to3/pytree.pyRscCs|iS(sP The whitespace and comments preceding this token in the input. (R`(R((s$/usr/lib/python2.6/lib2to3/pytree.pyRZscCs|i||_dS(N(R0R`(RR#((s$/usr/lib/python2.6/lib2to3/pytree.pyR[s N(ii(RIRJRKR`R8RaR'RSRTRWRNRORHRRRRRZR[RMR#(((s$/usr/lib/python2.6/lib2to3/pytree.pyR7Os          cCsp|\}}}}|p||ijo0t|djo |dSt||d|St||d|SdS(s Convert raw node information to a Node or Leaf instance. This is passed to the parser driver which calls it whenever a reduction of a grammar rule produces a new complete node, so that the tree is build strictly bottom-up. iiRRN(t number2symboltlenRPR7(tgrtraw_nodeRRbRRR,((s$/usr/lib/python2.6/lib2to3/pytree.pytconverts  t BasePatterncBs\eZdZdZdZdZdZdZdZ ddZ ddZ dZ RS(s A pattern is a tree matching pattern. It looks for a specific node type (token or symbol), and optionally for a specific content. This is an abstract base class. There are three concrete subclasses: - LeafPattern matches a single leaf node; - NodePattern matches a single node (usually non-leaf); - WildcardPattern matches a sequence of nodes of variable length. cOs$|tj p tdti|S(s>Constructor that prevents BasePattern from being instantiated.sCannot instantiate BasePattern(RhRRR(RRR((s$/usr/lib/python2.6/lib2to3/pytree.pyRscCskt|i|i|ig}x$|o|ddjo |d=q!Wd|iiditt |fS(Nis%s(%s)s, ( R RtcontentR R'RRIRURVRQ(RR((s$/usr/lib/python2.6/lib2to3/pytree.pyRTs  cCs|S(s A subclass can define this as a hook for optimizations. Returns either self or another node with the same effect. ((R((s$/usr/lib/python2.6/lib2to3/pytree.pytoptimizescCs|idj o|i|ijotS|idj oQd}|dj o h}n|i||ptS|o|i|qn|dj o|io|||i= 256). If the type is None this matches *any* single node (leaf or not), except if content is not None, in which it only matches non-leaf nodes that also match the content pattern. The content, if not None, must be a sequence of Patterns that must match the node's children exactly. If the content is given, the type must not be None. If a name is given, the matching node is stored in the results dict under that key. iN(R'RR)RtRQR*R<RhtWildcardPatternR.t wildcardsRRiR (RRRiR R=titem((s$/usr/lib/python2.6/lib2to3/pytree.pyRS.s  !     cCs|iodx\t|i|iD]E\}}|t|ijo#|dj o|i|ntSq WtSt|it|ijotSx;t |i|iD]$\}}|i ||ptSqWtS(s Match the pattern's content to the node's children. This assumes the node type matches and self.content is not None. Returns True if it matches, False if not. If results is not None, it must be a dict which will be updated with the nodes matching named subpatterns. When returning False, the results dict may still be updated. N( RwRrRiR,RdR'RlR.R+tzipRo(RR9RmtcRnt subpatternR@((s$/usr/lib/python2.6/lib2to3/pytree.pyRkKs      N(RIRJR+RwR'RSRk(((s$/usr/lib/python2.6/lib2to3/pytree.pyRu*sRvcBsheZdZd ded dZdZd dZd dZdZ dZ dZ d Z RS( s A wildcard pattern can match zero or more nodes. This has all the flexibility needed to implement patterns like: .* .+ .? .{m,n} (a b c | d e | f) (...)* (...)+ (...)? (...){m,n} except it always uses non-greedy matching. icCsd|jo|jo tjnpt||f|dj odttt|}t|ptt|x/|D]#}t|ptt|qWn||_||_||_ ||_ dS(s Initializer. Args: content: optional sequence of subsequences of patterns; if absent, matches one node; if present, each subsequence is an alternative [*] min: optinal minumum number of times to match, default 0 max: optional maximum number of times tro match, default HUGE name: optional name assigned to this match [*] Thus, if content is [[a, b, c], [d, e], [f, g, h]] this is equivalent to (a b c | d e | f g h); if content is None, this is equivalent to '.' in regular expression terms. The min and max parameters work as follows: min=0, max=maxint: .* min=1, max=maxint: .+ min=0, max=1: .? min=1, max=1: . If content is not None, replace the dot with the parenthesized list of alternatives, e.g. (a b c | d e | f g h)* iN( tHUGERR'ttupleRVRdRQRitmintmaxR (RRiR~RR talt((s$/usr/lib/python2.6/lib2to3/pytree.pyRSus: %   cCs@d}|idj oEt|idjo/t|iddjo|idd}n|idjo`|idjoP|idjotd|iS|dj o|i|ijo |iSn|idjoat|t oQ|idjoA|i|ijo.t |i|i|i|i|i|iS|S(s+Optimize certain stacked wildcard patterns.iiR N( R'RiRdR~RRuR RjR)Rv(RR{((s$/usr/lib/python2.6/lib2to3/pytree.pyRjs 0   #    cCs|i|g|S(s'Does this pattern exactly match a node?(Rq(RR9Rm((s$/usr/lib/python2.6/lib2to3/pytree.pyRoscCs{xt|i|D]c\}}|t|joD|dj o2|i||iot|||i|dj o$t|tptt|n||_dS(s Initializer. The argument is either a pattern or None. If it is None, this only matches an empty sequence (effectively '$' in regex lingo). If it is not None, this matches whenever the argument pattern doesn't have any matches. N(R'R)RhRRQRi(RRi((s$/usr/lib/python2.6/lib2to3/pytree.pyRS"s $cCstS(N(R+(RR9((s$/usr/lib/python2.6/lib2to3/pytree.pyRo/scCst|djS(Ni(Rd(RRp((s$/usr/lib/python2.6/lib2to3/pytree.pyRq3sccsi|idjo&t|djodhfVqen0x!|ii|D] \}}dSWdhfVdS(Ni(RiR'RdRr(RRpRzRn((s$/usr/lib/python2.6/lib2to3/pytree.pyRr7s N(RIRJR'RSRoRqRr(((s$/usr/lib/python2.6/lib2to3/pytree.pyR s  c cs|pdhfVn|d|d}}x|i|D]u\}}|p||fVq;xPt|||D];\}}h}|i||i||||fVqqWq;WdS(sR Generator yielding matches for a sequence of patterns and nodes. Args: patterns: a sequence of patterns nodes: a sequence of nodes Yields: (count, results) tuples where: count: the entire sequence of patterns matches nodes[:count]; results: dict containing named submatches. iiN(RrRl( tpatternsRptptrestRRRRRn((s$/usr/lib/python2.6/lib2to3/pytree.pyRrCs     (RKt __author__RNR RR|RR RR RPR7RgRhRsRuRvRRr(((s$/usr/lib/python2.6/lib2to3/pytree.pyt s"   hF V,=#