Treelang
Template:Short description Treelang is a "toy" programming language distributed with the GNU Compiler Collection (GCC) to demonstrate the features of its code-generation backend. It was developed by Tim Josling, based on a language called Toy created by Richard Kenner. During the GCC 4.3 release cycle, a patch was committed to remove the language,<ref>GCC Wiki (online)</ref> because of high maintenance costs outweighing its benefits and also because it was no longer considered a good front-end example by GCC developers.<ref>{{#invoke:citation/CS1|citation |CitationClass=web }}</ref>
OverviewEdit
Treelang is loosely based on the C programming language, but omits complex features such as pointers, arrays, and records. It has never been completed, although there were plans to gradually add more demonstrative features.
From the documentation distributed with GCC:<ref>Treelang Documentation Template:Webarchive</ref>
- Treelang is a sample language, useful only to help people understand how to implement a new language front end to GCC. It is not a useful language in itself other than as an example or basis for building a new language. Therefore only language developers are likely to have an interest in it.
ExampleEdit
The following example is from the Treelang documentation, modified by adding the main function, and is included to give an impression of the Treelang syntax and semantics:
<syntaxhighlight lang=c>
// function prototypes // function 'add' taking two ints and returning an int external_definition int add(int arg1, int arg2); external_definition int subtract(int arg3, int arg4); external_definition int first_nonzero(int arg5, int arg6); external_definition int double_plus_one(int arg7); external_definition int main();
// function definition add { // return the sum of arg1 and arg2 return arg1 + arg2; } subtract { return arg3 - arg4; }
double_plus_one { // aaa is a variable, of type integer and allocated at the start of the function automatic int aaa; // set aaa to the value returned from add, when passed arg7 and arg7 as the two parameters aaa=add(arg7, arg7); aaa=add(aaa, aaa); aaa=subtract(subtract(aaa, arg7), arg7) + 1; return aaa; } first_nonzero { // C-like if statement if (arg5) { return arg5; } else { } return arg6; }
// Like C, 'gtreelang' needs the main to be defined to create an executable. main { return double_plus_one(5); }
</syntaxhighlight>
Note that C-style comments (with the /* */
syntax) are not legal in Treelang.
CommentaryEdit
As a simple, C-like language, Treelang is interoperable with C and C++ with some minor datatype caveats. The designated filename extension for Treelang source code files is .tree
. Treelang source code can be compiled by invoking gcc
normally or as gtreelang
. Both invocations run the Treelang frontend (internally labelled tree1
) and produce machine code as output. Treelang can also issue some warning messages.<ref>Treelang Documentation, § 5 - Compiler Overview Template:Webarchive</ref>
ReferencesEdit
<references/>