Type Checking C++ Template Instantiation by Graph Programs

Karl Azab, Karl-Heinz Pennemann


Templates are a language feature of C++ and can be used for metaprogramming. The metaprogram is executed by the compiler and outputs source code which is then compiled. Templates are widely used in software libraries but few tools exist for programmers developing template code. In particular, error messages are often cryptic. During template instantiation, a compiler looks up names that depend on a template's formal parameters. We use graphs to represent the relevant parts of the source code and a graph program for the name lookup and type checking for expressions involving such names. This technique provides compiler writers with a visual way of writing algorithms that generate error messages and forms the basis for a visual inspection of type problems and suggested remedies for the programmer. Our graph program terminates and emits correct error messages.

Full Text:


DOI: http://dx.doi.org/10.14279/tuj.eceasst.10.148

DOI (PDF): http://dx.doi.org/10.14279/tuj.eceasst.10.148.153

Hosted By Universit├Ątsbibliothek TU Berlin.