Sophie

Sophie

distrib > Fedora > 17 > i386 > by-pkgid > 22d19aa2887b575b22775df3fe562f02 > files > 30

gcc-python-plugin-docs-0.9-4.1.fc17.i686.rpm

.. Copyright 2011 David Malcolm <dmalcolm@redhat.com>
   Copyright 2011 Red Hat, Inc.

   This is free software: you can redistribute it and/or modify it
   under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful, but
   WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see
   <http://www.gnu.org/licenses/>.

Example scripts
===============

There are various sample scripts located in the `examples` subdirectory.

Once you've built the plugin (with `make`), you can run them via:

   .. code-block:: bash

      $ ./gcc-with-python examples/NAME-OF-SCRIPT.py test.c

`show-docs.py`
--------------

  A trivial script to make it easy to read the builtin documentation for the
  gcc API:

   .. code-block:: bash

     $ ./gcc-with-python examples/show-docs.py test.c

  with this source:

   .. literalinclude:: ../examples/show-docs.py
    :lines: 17-
    :language: python

  giving output::

     Help on built-in module gcc:

     NAME
         gcc

     FILE
         (built-in)

     CLASSES
         __builtin__.object
             BasicBlock
             Cfg
             Edge
             Function
             Gimple
     (truncated)

`show-passes.py`
----------------

You can see the passes being executed via:

   .. code-block:: bash

     $ ./gcc-with-python examples/show-passes.py test.c

This is a simple script that registers a trivial callback:

   .. literalinclude:: ../examples/show-passes.py
    :lines: 17-
    :language: python

Sample output, showing passes being called on two different functions (`main`
and `helper_function`)::

     (gcc.GimplePass(name='*warn_unused_result'), gcc.Function('main'))
     (gcc.GimplePass(name='omplower'), gcc.Function('main'))
     (gcc.GimplePass(name='lower'), gcc.Function('main'))
     (gcc.GimplePass(name='eh'), gcc.Function('main'))
     (gcc.GimplePass(name='cfg'), gcc.Function('main'))
     (gcc.GimplePass(name='*warn_function_return'), gcc.Function('main'))
     (gcc.GimplePass(name='*build_cgraph_edges'), gcc.Function('main'))
     (gcc.GimplePass(name='*warn_unused_result'), gcc.Function('helper_function'))
     (gcc.GimplePass(name='omplower'), gcc.Function('helper_function'))
     (gcc.GimplePass(name='lower'), gcc.Function('helper_function'))
     (gcc.GimplePass(name='eh'), gcc.Function('helper_function'))
     (gcc.GimplePass(name='cfg'), gcc.Function('helper_function'))
     [...truncated...]


`show-gimple.py`
----------------

A simple script for viewing each function in the source file after it's been
converted to "GIMPLE" form, using GraphViz to visualize the control flow graph:

   .. code-block:: bash

      $ ./gcc-with-python examples/show-gimple.py test.c

It will generate a file `test.png` for each function, and opens it in an image
viewer.

   .. figure:: sample-gimple-cfg.png
      :scale: 50 %
      :alt: image of a control flow graph in GIMPLE form

The Python code for this is:

   .. literalinclude:: ../examples/show-gimple.py
    :lines: 19-
    :language: python

`show-ssa.py`
-------------

This is similar to `show-gimple.py`, but shows each function after the GIMPLE
has been converted to Static Single Assignment form ("SSA"):

   .. code-block:: bash

     $ ./gcc-with-python examples/show-ssa.py test.c

As before, it generates an image file for each function and opens it in a
viewer.

.. figure:: sample-gimple-ssa-cfg.png
   :scale: 50 %
   :alt: image of a control flow graph in GIMPLE SSA form

The Python code for this is:

   .. literalinclude:: ../examples/show-ssa.py
    :lines: 17-
    :language: python

`show-callgraph.py`
-------------------

This simple script sends GCC's interprocedural analysis data through GraphViz.

   .. code-block:: bash

     $ ./gcc-with-python examples/show-callgraph.py test.c

It generates an image file showing which functions call which other functions,
and opens it in a viewer.

.. figure:: sample-callgraph.png
   :alt: image of a call graph

The Python code for this is:

   .. literalinclude:: ../examples/show-callgraph.py
    :lines: 18-
    :language: python