404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.227.140.235: ~ $
3

g�wU�
�@s ddlmZdd�Zdd�ZdS)�)�c_astcCs�t|tj�st�t|jtj�s"|Stjg|jj�}d}xh|jjD]\}t|tjtj	f�rz|jj
|�t||j�|jd}q@|dkr�|jj
|�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 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.
    Nr���)
�
isinstancerZSwitch�AssertionErrorZstmtZCompoundZcoordZblock_items�Case�Default�append�_extract_nested_case�stmts)Zswitch_nodeZnew_compoundZ	last_caseZchild�r�$/usr/lib/python3.6/ast_transforms.py�fix_switch_cases
s3r
cCs:t|jdtjtjf�r6|j|jj��t|d|�dS)z� Recursively extract consecutive Case statements that are made nested
        by the parser and add them to the stmts_list.
    �rNr)rr
rrrr�popr	)Z	case_nodeZ
stmts_listrrrr	bsr	N)�rr
r	rrrr�<module>
sU

Filemanager

Name Type Size Permission Actions
__init__.cpython-36.opt-1.pyc File 2.48 KB 0644
__init__.cpython-36.pyc File 2.48 KB 0644
_ast_gen.cpython-36.opt-1.pyc File 8.46 KB 0644
_ast_gen.cpython-36.pyc File 8.46 KB 0644
_build_tables.cpython-36.opt-1.pyc File 467 B 0644
_build_tables.cpython-36.pyc File 467 B 0644
ast_transforms.cpython-36.opt-1.pyc File 2.39 KB 0644
ast_transforms.cpython-36.pyc File 2.43 KB 0644
c_ast.cpython-36.opt-1.pyc File 29.03 KB 0644
c_ast.cpython-36.pyc File 29.03 KB 0644
c_generator.cpython-36.opt-1.pyc File 14.54 KB 0644
c_generator.cpython-36.pyc File 14.54 KB 0644
c_lexer.cpython-36.opt-1.pyc File 11.95 KB 0644
c_lexer.cpython-36.pyc File 11.95 KB 0644
c_parser.cpython-36.opt-1.pyc File 54.32 KB 0644
c_parser.cpython-36.pyc File 54.46 KB 0644
lextab.cpython-36.opt-1.pyc File 5.58 KB 0644
lextab.cpython-36.pyc File 5.58 KB 0644
plyparser.cpython-36.opt-1.pyc File 2 KB 0644
plyparser.cpython-36.pyc File 2 KB 0644
yacctab.cpython-36.opt-1.pyc File 103.49 KB 0644
yacctab.cpython-36.pyc File 103.49 KB 0644