mirror of
https://github.com/amyinspace/MagicSetEditor2.git
synced 2026-06-10 13:06:59 -04:00
1d4a3c700b
git-svn-id: svn://svn.code.sf.net/p/magicseteditor/code/trunk@985 0fc631ac-6414-0410-93d0-97cfa31319b6
35 lines
1.6 KiB
Plaintext
35 lines
1.6 KiB
Plaintext
Default arguments
|
|
|
|
It is possible to declare default arguments for functions using the @@@@ operator.
|
|
> function := { "argument was: " + arg }@(arg:"default")
|
|
If this function is called without the @arg@ argument, then the default value @"default"@ is used instead.
|
|
For example:
|
|
> function() == "argument was: default"
|
|
> function(arg: "something else") == "argument was: something else"
|
|
|
|
For determining whether the argument is set only explicit arguments count, not everything in scope, so
|
|
> arg := "something else"
|
|
> function() == "argument was: default"
|
|
|
|
//Defaults are evaluated at the time the @@@@ operator is evaluated, so they can be used to simulate static scoping.
|
|
|
|
--Rule functions--
|
|
|
|
Some functions are available in ''rule form''.
|
|
|
|
These rule form functions are functions that create a new [[type:function]] with some defaults filled in.
|
|
That new function, the rule, applies some transformation to the input and returns the result.
|
|
|
|
A rule is like a normal function with all parameters given, except for the @input@.
|
|
|
|
Rules are often combined using the + operator, for example:
|
|
> # First all "a"s are replaced, then all "b"s.
|
|
> remove_as_and_bs := replace_rule(match: "a", replace: "") +
|
|
> replace_rule(match: "b", replace: "")
|
|
>
|
|
> text_with_as_and_bs := "bla bla bla"
|
|
> text_without_as_and_bs := remove_as_and_bs(text_with_as_and_bs)
|
|
|
|
|
|
<div style="text-align:right;">previous: <a href="functions">← Functions</a> | next: <a href="control_structures">Control structures →</a></div>
|