ROOTPLOIT
Server: LiteSpeed
System: Linux server71.web-hosting.com 4.18.0-513.18.1.lve.el8.x86_64 #1 SMP Thu Feb 22 12:55:50 UTC 2024 x86_64
User: niphet (1079)
PHP: 5.3.29
Disabled: NONE
Upload Files
File: //lib/python3.6/site-packages/pycparser/__pycache__/ast_transforms.cpython-36.opt-1.pyc
3

g¨wUð
ã@s ddlmZdd„Zdd„ZdS)é)Úc_astcCsšt|jtjƒs|Stjg|jjƒ}d}xh|jjD]\}t|tjtjfƒrj|jj|ƒt	||jƒ|jd}q0|dkr€|jj|ƒq0|j
j|ƒq0W||_|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éÿÿÿÿ)Ú
isinstanceZstmtrZCompoundZcoordZblock_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
s4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_listr
r
rrbsrN)Úrrrr
r
r
rÚ<module>
sU