1
0
Fork 0
doc/devel/style/design/style-macro.en.tm

85 lines
3.1 KiB
Tcl

<TeXmacs|1.0.3.7>
<style|tmdoc>
<\body>
<tmdoc-title|Macro expansion>
The main interest of the <TeXmacs>' style-sheet language is the possibility
to define macros. These come in three flavours: ordinary macros, macros
which take an arbitrary number of arguments and external macros, whose
expansion is computed by <name|Scheme> or a plug-in. The macro-related
primitives are available from the <menu|Source|Macro> menu. Below, we will
only describe the ordinary macros. For more details, we refer to the
section about <hyper-link|macro primitives|../../format/primitives/prim-macro.en.tm>.
Ordinary macros are usually defined using
<\tm-fragment>
<inactive*|<assign|my-macro|<macro|<active*|x<rsub|1>>|<active*|<with|mode|math|\<cdots\>>>|<active*|x<rsub|n>>|body>>>
</tm-fragment>
After such an assignment, <markup|my-macro> becomes a new primitive with
<with|mode|math|n> arguments, which may be called using
<\tm-fragment>
<inactive|<my-macro|<active*|y<rsub|1>>|<active*|<with|mode|math|\<cdots\>>>|<active*|y<rsub|n>>>>
</tm-fragment>
Inside the body of the macro, the <markup|arg> primitive may be used to
retrieve the values of the arguments to the macro.
<\tm-fragment>
<inactive*|<assign|hello|<macro|name|Hello <arg|name>, you look nice
today!>>>
</tm-fragment>
It is possible to call a macro with less or more arguments than the
expected number. Superfluous arguments are simply ignored. Missing
arguments take the nullary <markup|uninit> primitive as value:
<\tm-fragment>
<inactive*|<assign|hey|<macro|first|second|<style-with|src-compact|none|<if|<equal|<arg|second>|<uninit>>|Hey
<arg|first>, you look lonely today...|Hey <arg|first> and <arg|second>,
you form a nice couple!>>>>>
</tm-fragment>
We finally notice that you are allowed to compute with macros, in a similar
way as in functional programming, except that our macros are not closures
(yet). For instance:
<\tm-fragment>
<inactive|<assign|my-macro-copy|<inactive|<value|my-macro>>>>
</tm-fragment>
The <markup|compound> tag may be used to apply macros which are the result
of a computation:
<\tm-fragment>
<inactive*|<assign|overloaded-hi|<macro|name|<style-with|src-compact|none|<compound|<if|<nice-weather>|<value|happy-hi>|<value|sad-hi>>|<arg|name>>>>>>
</tm-fragment>
<tmdoc-copyright|1998--2004|Joris van der Hoeven>
<tmdoc-license|Permission is granted to copy, distribute and/or modify this
document under the terms of the GNU Free Documentation License, Version 1.1
or any later version published by the Free Software Foundation; with no
Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
Texts. A copy of the license is included in the section entitled "GNU Free
Documentation License".>
</body>
<\initial>
<\collection>
<associate|page-bot|30mm>
<associate|page-even|30mm>
<associate|page-odd|30mm>
<associate|page-reduce-bot|15mm>
<associate|page-reduce-left|25mm>
<associate|page-reduce-right|25mm>
<associate|page-reduce-top|15mm>
<associate|page-right|30mm>
<associate|page-top|30mm>
<associate|par-width|150mm>
</collection>
</initial>