Repository URL to install this package:
|
Version:
2.18 ▾
|
öXö
ã @ s, d d l m Z d d Z d d Z d S)é )Ú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)aÜ 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 is 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.
Nr éÿÿÿÿ)
Ú
isinstancer ÚSwitchÚAssertionErrorÚstmtÚCompoundÚcoordÚblock_itemsÚCaseÚDefaultÚappendÚ_extract_nested_caseÚstmts)Zswitch_nodeZnew_compoundZ last_caseÚchild© r ú../pycparser/ast_transforms.pyÚfix_switch_cases
s 3 r c C sM t | j d t j t j f rI | j | j j t | d | d S)z Recursively extract consecutive Case statements that are made nested
by the parser and add them to the stmts_list.
é r Nr )r r r r r r
Úpopr )Z case_nodeZ
stmts_listr r r r b s "r N)Ú r r r r r r r Ú<module>
s U