Metaprogramming

This is an old revision of this page, as edited by Chlewbot (talk | contribs) at 17:28, 10 February 2006 (robot Adding: es). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.
This article is about the programming technique. For the management technique, see metaprogramming (management).

Metaprogramming is the writing of programs that write or manipulate other programs (or themselves) as their data or that do part of the work that is otherwise done at runtime during compile time. In many cases, this allows programmers to get more done in the same amount of time as they would take to write all the code manually.

The language in which the metaprogram is written is called the meta-language. The language of the programs that are manipulated is called the object-language. The capacity of a programming language to be its own meta-language is called reflexivity.

A simple example of a metaprogram is this bash script, which is an example of generative programming:

#!/bin/bash
# metaprogram
echo '#!/bin/bash' >program
for ((I=1; I<=992; I++)); do
    echo "echo $I" >>program
done
chmod +x program

This script (or program) generates a new 993 line program which prints out the numbers 1–992. This is only an illustration on how to use code to write more code, not the most efficient way to print out a list of numbers. Nonetheless, a good programmer can write and execute this metaprogram in just a couple of minutes, and will have generated exactly 1000 lines of code in that amount of time.

Not all metaprogramming involves generative programming. If programs are modifiable at runtime (as in Lisp, Smalltalk, Ruby, and other languages), then techniques can be used to accomplish metaprogramming without actually generating source code.

  • The most common metaprogramming tool is a compiler which allows a programmer to write a relatively short program in a high-level language and uses it to write an equivalent assembly language or machine language program. This generally saves a good deal of time compared to writing the machine language program directly.
  • Another still fairly common example of metaprogramming might be found in the use of lex (see also: flex) and yacc (see also: bison), which are used to generate compilers and interpreters.
  • A quine is a special kind of metaprogram that has its own source as its output.

Reflection is a valuable language feature for facilitating metaprogramming. Having the programming language itself as a first class data type (as in Lisp) is also very useful.

See also