tQc@sEdZddlZddlZddlmZdddYZdS(sk HyperParser =========== This module defines the HyperParser class, which provides advanced parsing abilities for the ParenMatch and other extensions. The HyperParser uses PyParser. PyParser is intended mostly to give information on the proper indentation of code. HyperParser gives some information on the structure of code, used by extensions to help the user. iN(tPyParset HyperParsercBsteZdZdZdZdZdedZdZe j e j dZ e j dZ dZd ZRS( cCs||_|j|_}tj|j|j}d}||j|}|jsx|jD]}t ||d}t |d} d|} |j |j | | d|j |j| } | d k s|dkrbPqbqbW|j| pdn_|jd|} | r%| d} nd} d|} |j |j | | d|jd|jd |_| |_|j|_gtt|jD]8} | dko|j| d|j| ddk^q|_|j|d S( s[Initialize the HyperParser to analyze the surroundings of the given index. cSstt|S(N(tinttfloat(tindex((s)/sys/lib/python2.7/idlelib/HyperParser.pyt index2linesis.0s%d.ends itconsoles1.0iN(teditwinttextRtParsert indentwidthttabwidthRtcontext_use_ps1tnum_context_linestmaxtreprtset_strtgettfind_good_parse_startt_build_char_in_string_functNonetset_lot tag_prevrangetstrtrawtextt stopatindextget_last_stmt_bracketingt bracketingtrangetlentisopenert set_index(tselfRRRtparserRtlnotcontexttstartatt startatindexRtbodtrti((s)/sys/lib/python2.7/idlelib/HyperParser.pyt__init__s:        TcCst|jt|jj||j}|dkrFtdn||_d|_xP|jt|jdkr|j|jdd|jkr|jd7_q[W|jt|jdkr|j|jdd|jkr|j |jd r|jd7_ndS(siSet the index to which the functions relate. Note that it must be in the same statement. is0The index given is before the analyzed statementiN( RRRRRt ValueErrortindexinrawtextt indexbracketRR(R RR+((s)/sys/lib/python2.7/idlelib/HyperParser.pyRHs+   !!cCs/|j|jo.|j|j|jddkS(s5Is the index given to the HyperParser is in a string?it"t'(R-R.(RR,RR(R ((s)/sys/lib/python2.7/idlelib/HyperParser.pyt is_in_string[scCs0|j|j p/|j|j|jddkS(s:Is the index given to the HyperParser is in a normal code?it#R-R.(R0R-R.(RR,RR(R ((s)/sys/lib/python2.7/idlelib/HyperParser.pyt is_in_codebss([{c Cs|j|jd}|j}x{|j| sc|j|j|d|ksc|j|d|kr|d8}|dkr}dSt||j|d}q W|jd}x:|t|jkr|j|d|kr|d7}qW|jjd|j t|j|j|df}|t|jksQ|j|dt|jkrg|r[dS|j }n;|jjd|j t|j|j|ddf}||fS(sIf the index given to the HyperParser is surrounded by a bracket defined in openers (or at least has one before it), return the indices of the opening bracket and the closing bracket (or the end of line, whichever comes first). If it is not surrounded by brackets, or the end of line comes before the closing bracket and mustclose is True, returns None. iis%s-%dcN( RR,RRRtminRRRR(R topenerst mustclosetbracketingleveltbeforetaftert beforeindext afterindex((s)/sys/lib/python2.7/idlelib/HyperParser.pytget_surrounding_bracketshs0     +   )s \t_cCs|}x1||kr9||d|jkr9|d8}q W||krx|||jksotj|||!rx|}n||S(Ni(t _id_charst_id_first_charstkeywordt iskeyword(R RtlimittposR(((s)/sys/lib/python2.7/idlelib/HyperParser.pyt_eat_identifiers& c Csr|jstdn|j}|j}|j}||d}|j}|}t}xx||kr||d|jkr|d8}q_| r||kr||ddkr|d8}t}q_||kr*|dkr*|||dddkr*|d8}||d}||dd}q_Pq_|s8Pn|j|||}|rl||}|}t }q\||kr`||d} x2|dkr||dd| kr|d8}qW||d|krPn||d}|d8}||d}|}||dkrqa||dkr\x.|dkrR||dd krR|d8}q%W|}nPq\Pq\|||j!S( sReturn a string with the Python expression which ends at the given index, which is empty if there is no real one. s?get_expression should only be called if index is inside a code.iit.R0is([s'"trRbBuU( R1R*RRR,R+tTruet_whitespace_charsRBtFalse( R RRt brck_indext brck_limitRAtlast_identifier_post postdot_phasetrettlevel((s)/sys/lib/python2.7/idlelib/HyperParser.pytget_expressionsb     #        ' # (t__name__t __module__R)RR/R1RGR:RFtstringt ascii_letterstdigitsR<R=RBRN(((s)/sys/lib/python2.7/idlelib/HyperParser.pyRs 7   '  ((t__doc__RQR>tidlelibRR(((s)/sys/lib/python2.7/idlelib/HyperParser.pyt s