mirror of
https://github.com/cc65/cc65.git
synced 2025-01-11 11:30:13 +00:00
ca65 documentation of .define macros, making note that parentheses in ca65 macros are problematic especially when thinking of them as "C style", replacing unclear example with an example showing how accidental parentheses can cause a problem.
This commit is contained in:
parent
709ee6a28b
commit
355696d17d
@ -4282,6 +4282,12 @@ different:
|
|||||||
some things may be done with both macro types, each type has special
|
some things may be done with both macro types, each type has special
|
||||||
usages. The types complement each other.
|
usages. The types complement each other.
|
||||||
|
|
||||||
|
<item> Parentheses work differently from C macros.
|
||||||
|
The common practice of wrapping C macros in parentheses may cause
|
||||||
|
unintended problems here, such as accidentally implying an
|
||||||
|
indirect addressing mode. While the definition of a macro requires
|
||||||
|
parentheses around its argument list, when invoked they should not be included.
|
||||||
|
|
||||||
</itemize>
|
</itemize>
|
||||||
|
|
||||||
Let's look at a few examples to make the advantages and disadvantages
|
Let's look at a few examples to make the advantages and disadvantages
|
||||||
@ -4314,20 +4320,18 @@ Macros with parameters may also be useful:
|
|||||||
DEBUG "Assembling include file #3"
|
DEBUG "Assembling include file #3"
|
||||||
</verb></tscreen>
|
</verb></tscreen>
|
||||||
|
|
||||||
Note that, while formal parameters have to be placed in braces, this is
|
Note that, while formal parameters have to be placed in braces,
|
||||||
not true for the actual parameters. Beware: Since the assembler cannot
|
the actual parameters used when invoking the macro should not use braces.
|
||||||
detect the end of one parameter, only the first token is used. If you
|
The invoked parameters are separated by commas only, if parentheses are
|
||||||
don't like that, use classic macros instead:
|
used by accident they will become part of the replaced token:
|
||||||
|
|
||||||
<tscreen><verb>
|
<tscreen><verb>
|
||||||
.macro DEBUG message
|
.define COMBINE(ta,tb,tc) ta+tb*10+tc*100
|
||||||
.out message
|
|
||||||
.endmacro
|
COMBINE 5,6,7 ; 5+6*10+7*100 = 765 correct
|
||||||
|
COMBINE(5,6,7) ; (5+6*10+7)*100 = 7200 incorrect!
|
||||||
</verb></tscreen>
|
</verb></tscreen>
|
||||||
|
|
||||||
(That is an example where a problem can be solved with both macro types).
|
|
||||||
|
|
||||||
|
|
||||||
<sect1>Characters in macros<p>
|
<sect1>Characters in macros<p>
|
||||||
|
|
||||||
When using the <ref id="option-t" name="-t"> option, characters are translated
|
When using the <ref id="option-t" name="-t"> option, characters are translated
|
||||||
|
Loading…
x
Reference in New Issue
Block a user