💾 Archived View for tris.fyi › pydoc › pycparser.ast_transforms captured on 2022-03-01 at 16:05:54. Gemini links have been rewritten to link to archived content

View Raw

More Information

⬅️ Previous capture (2022-01-08)

➡️ Next capture (2022-07-16)

-=-=-=-=-=-=-

Back to module index

Go to module by name

pycparser

pycparser.ast_transforms

This module has no docstring.

Functions

fix_switch_cases

fix_switch_cases(switch_node)

   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.
    

Modules

c_ast