5 Conditionals and Matching
expression | ||||
| ||||
| ||||
expression | ||||
|
> count(0)
- String
"none"
> count(2)
- String
"some"
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
expression | ||||||||
| ||||||||
| ||||||||
|
The most common use of match is the variant_id form, with or without ~else. All of the variant_ids must be for variants of the same type, and the type of target_expr must match that type. If ~else is not present, every variant associated with the type must have a case. In the unusual case that only ~else is present, the type of target_expr is unconstrained.
> area(circle(1))
- Int
3
> area(rectangle(3, 4))
- Int
12
In the list form of match, the [] and cons clauses can actually be in either order, and a second one can be replaced with ~else.
> sum([1, 2, 3])
- Int
6
match lst
| cons(f, r):
match r
| []: f
| ~else:
def r_max = max_element(r)
| []: error(#'max_element, "empty list")
> max_element([1, 20, 3])
- Int
20
In the syntax-pattern form of match, target_expr must produce a syntax object, and it is compared to the quoted patterns until a match is found. A pattern can include an escape with $ followed by an identifier, in which case it binds the identifier to one part of the input syntax or as a repetition for multiple parts. See Syntax Objects, Patterns, and Templates for more information and for examples.
In the integer-case form of match, each clause has an integer or multiple integers separated by ||.
match n
| 0: "none"
| 1: "single"
| 2: "pair"
| 3 || 4 || 5: "some"
| ~else: "many"
> describe_quantity(1)
- String
"single"
> describe_quantity(4)
- String
"some"