mirror of
https://github.com/cc65/cc65.git
synced 2025-01-14 16:33:00 +00:00
Document the new curly braces feature
git-svn-id: svn://svn.cc65.org/cc65/trunk@3015 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
b10b7cd3e8
commit
7d8b69f6f0
103
doc/ca65.sgml
103
doc/ca65.sgml
@ -1075,16 +1075,22 @@ either a string or an expression.
|
||||
|
||||
<sect1><tt>.BLANK</tt><label id=".BLANK"><p>
|
||||
|
||||
Builtin function. The function evaluates its argument in braces and
|
||||
yields "false" if the argument is non blank (there is an argument), and
|
||||
"true" if there is no argument. As an example, the <tt/.IFBLANK/ statement
|
||||
may be replaced by
|
||||
Builtin function. The function evaluates its argument in braces and yields
|
||||
"false" if the argument is non blank (there is an argument), and "true" if
|
||||
there is no argument. The token list that makes up the function argument
|
||||
may optionally be enclosed in curly braces. This allows the inclusion of
|
||||
tokens that would otherwise terminate the list (the closing right
|
||||
parenthesis). The curly braces are not considered part of the list, a list
|
||||
just consisting of curly braces is considered to be empty.
|
||||
|
||||
As an example, the <tt/.IFBLANK/ statement may be replaced by
|
||||
|
||||
<tscreen><verb>
|
||||
.if .blank(arg)
|
||||
.if .blank({arg})
|
||||
</verb></tscreen>
|
||||
|
||||
|
||||
|
||||
<sect1><tt>.CONCAT</tt><label id=".CONCAT"><p>
|
||||
|
||||
Builtin string function. The function allows to concatenate a list of string
|
||||
@ -1145,7 +1151,10 @@ either a string or an expression.
|
||||
</verb></tscreen>
|
||||
|
||||
The first integer expression gives the number of tokens to extract from
|
||||
the token list. The second argument is the token list itself.
|
||||
the token list. The second argument is the token list itself. The token
|
||||
list may optionally be enclosed into curly braces. This allows the
|
||||
inclusion of tokens that would otherwise terminate the list (the closing
|
||||
right paren in the given case).
|
||||
|
||||
Example:
|
||||
|
||||
@ -1155,7 +1164,7 @@ either a string or an expression.
|
||||
<tscreen><verb>
|
||||
.macro ldax arg
|
||||
...
|
||||
.if (.match (.left (1, arg), #))
|
||||
.if (.match (.left (1, {arg}), #))
|
||||
|
||||
; ldax called with immidiate operand
|
||||
...
|
||||
@ -1205,7 +1214,10 @@ either a string or an expression.
|
||||
<item>end-of-file
|
||||
</itemize>
|
||||
|
||||
Often a macro parameter is used for any of the token lists.
|
||||
The token lists may optionally be enclosed into curly braces. This allows
|
||||
the inclusion of tokens that would otherwise terminate the list (the closing
|
||||
right paren in the given case). Often a macro parameter is used for any of
|
||||
the token lists.
|
||||
|
||||
Please note that the function does only compare tokens, not token
|
||||
attributes. So any number is equal to any other number, regardless of the
|
||||
@ -1224,7 +1236,7 @@ either a string or an expression.
|
||||
<tscreen><verb>
|
||||
.macro asr arg
|
||||
|
||||
.if (.not .blank(arg)) .and (.not .match (arg, a))
|
||||
.if (.not .blank(arg)) .and (.not .match ({arg}, a))
|
||||
.error "Syntax error"
|
||||
.endif
|
||||
|
||||
@ -1251,10 +1263,12 @@ either a string or an expression.
|
||||
.MID (<int expr>, <int expr>, <token list>)
|
||||
</verb></tscreen>
|
||||
|
||||
The first integer expression gives the starting token in the list (the
|
||||
first token has index 0). The second integer expression gives the number
|
||||
of tokens to extract from the token list. The third argument is the
|
||||
token list itself.
|
||||
The first integer expression gives the starting token in the list (the first
|
||||
token has index 0). The second integer expression gives the number of tokens
|
||||
to extract from the token list. The third argument is the token list itself.
|
||||
The token list may optionally be enclosed into curly braces. This allows the
|
||||
inclusion of tokens that would otherwise terminate the list (the closing
|
||||
right paren in the given case).
|
||||
|
||||
Example:
|
||||
|
||||
@ -1264,7 +1278,7 @@ either a string or an expression.
|
||||
<tscreen><verb>
|
||||
.macro ldax arg
|
||||
...
|
||||
.if (.match (.mid (0, 1, arg), #))
|
||||
.if (.match (.mid (0, 1, {arg}), #))
|
||||
|
||||
; ldax called with immidiate operand
|
||||
...
|
||||
@ -1303,8 +1317,11 @@ either a string or an expression.
|
||||
.RIGHT (<int expr>, <token list>)
|
||||
</verb></tscreen>
|
||||
|
||||
The first integer expression gives the number of tokens to extract from
|
||||
the token list. The second argument is the token list itself.
|
||||
The first integer expression gives the number of tokens to extract from the
|
||||
token list. The second argument is the token list itself. The token list
|
||||
may optionally be enclosed into curly braces. This allows the inclusion of
|
||||
tokens that would otherwise terminate the list (the closing right paren in
|
||||
the given case).
|
||||
|
||||
See also the <tt><ref id=".LEFT" name=".LEFT"></tt> and <tt><ref id=".MID"
|
||||
name=".MID"></tt> builtin functions.
|
||||
@ -1440,8 +1457,12 @@ either a string or an expression.
|
||||
|
||||
<sect1><tt>.TCOUNT</tt><label id=".TCOUNT"><p>
|
||||
|
||||
Builtin function. The function accepts a token list in braces. The
|
||||
function result is the number of tokens given as argument.
|
||||
Builtin function. The function accepts a token list in braces. The function
|
||||
result is the number of tokens given as argument. The token list may
|
||||
optionally be enclosed into curly braces which are not considered part of
|
||||
the list and not counted. Enclosement in curly braces allows the inclusion
|
||||
of tokens that would otherwise terminate the list (the closing right paren
|
||||
in the given case).
|
||||
|
||||
Example:
|
||||
|
||||
@ -1451,10 +1472,10 @@ either a string or an expression.
|
||||
|
||||
<tscreen><verb>
|
||||
.macro ldax arg
|
||||
.if (.match (.mid (0, 1, arg), #))
|
||||
.if (.match (.mid (0, 1, {arg}), #))
|
||||
; ldax called with immidiate operand
|
||||
lda #<(.right (.tcount (arg)-1, arg))
|
||||
ldx #>(.right (.tcount (arg)-1, arg))
|
||||
lda #<(.right (.tcount ({arg})-1, {arg}))
|
||||
ldx #>(.right (.tcount ({arg})-1, {arg}))
|
||||
.else
|
||||
...
|
||||
.endif
|
||||
@ -1482,7 +1503,10 @@ either a string or an expression.
|
||||
<item>end-of-file
|
||||
</itemize>
|
||||
|
||||
Often a macro parameter is used for any of the token lists.
|
||||
The token lists may optionally be enclosed into curly braces. This allows
|
||||
the inclusion of tokens that would otherwise terminate the list (the closing
|
||||
right paren in the given case). Often a macro parameter is used for any of
|
||||
the token lists.
|
||||
|
||||
The function compares tokens <em/and/ token values. If you need a function
|
||||
that just compares the type of tokens, have a look at the <tt><ref
|
||||
@ -3194,6 +3218,26 @@ parameters:
|
||||
ldaxy 1,2,3 ; .PARAMCOUNT = 3
|
||||
</verb></tscreen>
|
||||
|
||||
Macro parameters may optionally be enclosed into curly braces. This allows the
|
||||
inclusion of tokens that would otherwise terminate the parameter (the comma in
|
||||
case of a macro parameter).
|
||||
|
||||
<tscreen><verb>
|
||||
.macro foo arg1, arg2
|
||||
...
|
||||
.endmacro
|
||||
|
||||
foo ($00,x) ; Two parameters passed
|
||||
foo {($00,x)} ; One parameter passed
|
||||
</verb></tscreen>
|
||||
|
||||
In the first case, the macro is called with two parameters: '<tt/($00/'
|
||||
and 'x)'. The comma is not passed to the macro, since it is part of the
|
||||
calling sequence, not the parameters.
|
||||
|
||||
In the second case, '($00,x)' is passed to the macro, this time
|
||||
including the comma.
|
||||
|
||||
|
||||
<sect1>Detecting parameter types<p>
|
||||
|
||||
@ -3205,14 +3249,14 @@ functions will allow you to do exactly this:
|
||||
|
||||
<tscreen><verb>
|
||||
.macro ldax arg
|
||||
.if (.match (.left (1, arg), #))
|
||||
.if (.match (.left (1, {arg}), #))
|
||||
; immediate mode
|
||||
lda #<(.right (.tcount (arg)-1, arg))
|
||||
ldx #>(.right (.tcount (arg)-1, arg))
|
||||
lda #<(.right (.tcount ({arg})-1, {arg}))
|
||||
ldx #>(.right (.tcount ({arg})-1, {arg}))
|
||||
.else
|
||||
; assume absolute or zero page
|
||||
lda arg
|
||||
ldx 1+(arg)
|
||||
ldx 1+({arg})
|
||||
.endif
|
||||
.endmacro
|
||||
</verb></tscreen>
|
||||
@ -3220,7 +3264,12 @@ functions will allow you to do exactly this:
|
||||
Using the <tt/<ref id=".MATCH" name=".MATCH">/ function, the macro is able to
|
||||
check if its argument begins with a hash mark. If so, two immediate loads are
|
||||
emitted, Otherwise a load from an absolute zero page memory location is
|
||||
assumed. So this macro can be used as
|
||||
assumed. Please note how the curly braces are used to enclose parameters to
|
||||
pseudo functions handling token lists. This is necessary, because the token
|
||||
lists may include commas or parens, which would be treated by the assembler
|
||||
as end-of-list.
|
||||
|
||||
The macro can be used as
|
||||
|
||||
<tscreen><verb>
|
||||
foo: .word $5678
|
||||
|
Loading…
x
Reference in New Issue
Block a user