GCC Python plugin¶
- Building the plugin from source
- Basic usage of the plugin
- Generating custom errors and warnings
- Global data access
- Working with source code
- Overview of GCC’s internals
- Example scripts
- Working with C code
- Working with functions and control flow graphs
- gcc.Tree and its subclasses
- Gimple statements
- Optimization passes
- Working with callbacks
- Creating custom GCC attributes
- Usage example: a static analysis tool for CPython extension code
- Success Stories
- Getting Involved
- Release Notes
This document describes the Python plugin I’ve written for GCC. In theory the plugin allows you to write Python scripts that can run inside GCC as it compiles code, exposing GCC’s internal data structures as a collection of Python classes and functions. The bulk of the document describes the Python API it exposes.
Hopefully this will be of use for writing domain-specific warnings, static analysers, and the like, and for rapid prototyping of new GCC features.
I’ve tried to stay close to GCC’s internal representation, but using classes. I hope that the resulting API is pleasant to work with.
The plugin is a work-in-progress; the API may well change.
Bear in mind that writing this plugin has been the first time I have worked with the insides of GCC. I have only wrapped the types I have needed, and within them, I’ve only wrapped properties that seemed useful to me. There may well be plenty of interesting class and properties for instances that can be added (patches most welcome!). I may also have misunderstood how things work.
Most of my development has been against Python 2 (2.7, actually), but I’ve tried to make the source code of the plugin buildable against both Python 2 and Python 3 (3.2), giving separate python2.so and python3.so plugins. (I suspect that it’s only possible to use one or the other within a particular invocation of “gcc”, due to awkward dynamic-linker symbol collisions between the two versions of Python).
The plugin is Free Software, licensed under the GPLv3 (or later).