Metaprogramming

From Erlang Community

(Difference between revisions)
Revision as of 17:08, 22 September 2006 (edit)
Vladdu (Talk | contribs)
m
← Previous diff
Current revision (07:39, 23 September 2006) (edit) (undo)
Vladdu (Talk | contribs)

 
(2 intermediate revisions not shown.)
Line 2: Line 2:
Vlad Vlad
-==Overview==+==Note==
- +For technical reasons, this article has moved here [http://erlide.sourceforge.net/merlin/metaprogramming.html]. It will be moved back here when it's completed.
<p> <p>
-Here I will gather some thoughts about metaprogramming in Erlang. Hopefully this will result in an implementation too (some parts have already been implemented). I put this here so that I can get input and the result will become a HowTo.+Feel free to add your comments here, though.
</p> </p>
-<p> 
-'''This is very much a work in progress. Please don't delete anything, just add your comments.'''</p> 
- 
-==What is metaprogramming?== 
- 
-I won't go into the gory details here, there are plenty of papers on the matter. What I do mean by MP here is the capability of writing programs that handle programs. 
- 
-==Current status== 
- 
-<p> 
-Erlang has already support for MP. It is composed from two parts: 
-*the parse trees for Erlang code are regular Erlang terms 
-*through the ''parse_transform'' concept, one can manipulate a module's parse tree before it is compiled 
-</p><p> 
-This is enough for quite advanced applications, but has the disadvantage that it's quite unwieldy and thus few have ventured into that area. Ulf Wiger has written code to make development of parse transforms easier. Another issue is that one has to use Erlang syntax for all extensions, which might make them not so easy to read and use. 
-</p> 
- 
-==MP extensions== 
- 
-<p> 
-There are several areas where MP would be useful. 
-*[[Embedding domain specific languages]] 
-</p> 
- 
-==Embedding domain specific languages== 
- 
-One example discussed recently is SQL.  
-<p> 
-Sometimes one wants to be able to use a DSL inside Erlang code. This can be done today by using the textual representation of the DSL code, which is prone to errors, or by using an Erlang representation of that code (i.e. a parse tree), which is great for matching and traversing but may be quite far from the original representation and the user is required to learn the new one. 
-</p><p> 
-Wouldn't it be wonderful if one could combine the two? That is, one would write the textual form but behind the scenes handle the parse tree. 
-</p><p> 
-For example, the user writes <code>X = "select id from users"</code> and the resulting beam code is exactly the same as if he/she had written <code>X = {select, [{fields, [id]}, {from, [users]}]}</code><br> Okay, this is very simple, but I promise there will be mode complicated exmples later on! 
-</p> 
- 
-===Handling Erlang code=== 
- 
-===Macros=== 
- 
-==License== 
-  
-The code associated with this HOWTO is available under a license to be defined.  
-==Disclaimer==+==Comments==
-Don't blame me if this stuff blows in your face or if your cat starts barking like a dog! :-) 
[[Category:Concepts]] [[Category:Concepts]]

Current revision

[edit] Author

Vlad

[edit] Note

For technical reasons, this article has moved here [1]. It will be moved back here when it's completed.

Feel free to add your comments here, though.

[edit] Comments

Erlang/OTP Projects
Personal tools