ó
g¨wUc           @   s&   d  d l  m Z d „  Z d „  Z d S(   i   (   t   c_astc         C   sí   t  |  t j ƒ s t ‚ t  |  j t j ƒ s1 |  St j g  |  j j ƒ } d } xŽ |  j j D]€ } t  | t j	 t j
 f ƒ r­ | j j | ƒ t | | j ƒ | j d } q\ | d k rÌ | j j | ƒ q\ | j j | ƒ q\ W| |  _ |  S(   sÜ   The 'case' statements in a 'switch' come out of parsing with one
        child node, so subsequent statements are just tucked to the parent
        Compound. Additionally, consecutive (fall-through) case statements
        come out messy. This is a peculiarity of the C grammar. The following:

            switch (myvar) {
                case 10:
                    k = 10;
                    p = k + 1;
                    return 10;
                case 20:
                case 30:
                    return 20;
                default:
                    break;
            }

        Creates this tree (pseudo-dump):

            Switch
                ID: myvar
                Compound:
                    Case 10:
                        k = 10
                    p = k + 1
                    return 10
                    Case 20:
                        Case 30:
                            return 20
                    Default:
                        break

        The goal of this transform it to fix this mess, turning it into the
        following:

            Switch
                ID: myvar
                Compound:
                    Case 10:
                        k = 10
                        p = k + 1
                        return 10
                    Case 20:
                    Case 30:
                        return 20
                    Default:
                        break

        A fixed AST node is returned. The argument may be modified.
    iÿÿÿÿN(   t
   isinstanceR    t   Switcht   AssertionErrort   stmtt   Compoundt   coordt   Nonet   block_itemst   Caset   Defaultt   appendt   _extract_nested_caset   stmts(   t   switch_nodet   new_compoundt	   last_caset   child(    (    s<   /usr/lib/python2.7/site-packages/pycparser/ast_transforms.pyt   fix_switch_cases   s    3	c         C   sP   t  |  j d t j t j f ƒ rL | j |  j j ƒ  ƒ t | d | ƒ n  d S(   s€    Recursively extract consecutive Case statements that are made nested
        by the parser and add them to the stmts_list.
    i    iÿÿÿÿN(   R   R   R    R	   R
   R   t   popR   (   t	   case_nodet
   stmts_list(    (    s<   /usr/lib/python2.7/site-packages/pycparser/ast_transforms.pyR   b   s    "N(   t    R    R   R   (    (    (    s<   /usr/lib/python2.7/site-packages/pycparser/ast_transforms.pyt   <module>
   s   	U