This section details a few of the fundamental language constructs for directing the order in which a program executes.
We'll refer to this as "control flow" from now on and we'll cover how to write if/else statements, how to pattern match, how to deal with the concept of looping or iterating through collections, and some error handling basics.
If, then, else
Unison's syntax for conditional logic is if true then executeThis else
            executeThat. Your first argument to the conditional must be an expression which returns a Boolean. This could be a code block or some condition which you'd like to test extracted in a function. 
If we wanted many if/else statements expressing multiple conditions, we'd express it with successive else if blocks:
use Nat %
myList = Nat.range 0 99
myListFunction =
  if List.contains 100 myList then "100 found"
  else
    if List.any (elem -> elem % 2 === 0) myList then "Even found"
    else "Condition not met"
myListFunction⧨"Even found"Boolean Expressions
Boolean values can be combined with operators like Boolean.and, also represented as && in Unison and Boolean.or, also represented as ||.
false && base.bug "oh no"⧨falseFor an expression where the first argument to && is false, as in the one above, the latter argument will never be evaluated.
true || base.bug "oh no"⧨trueFor an expression where the first argument to || is true, the latter argument will never be evaluated.
To negate a boolean value, use Boolean.not.
Boolean.not true⧨false