{- Returns the first non-empty `Optional` value in a `List` Examples: ``` ./head Natural [ [ ] : Optional Natural , [ 1 ] : Optional Natural , [ 2 ] : Optional Natural ] = [ 1 ] : Optional Natural ./head Natural [ [] : Optional Natural, [] : Optional Natural ] = [] : Optional Natural ./head Natural ([] : List (Optional Natural)) = [] : Optional Natural ``` -} let head : ∀(a : Type) → List (Optional a) → Optional a = λ(a : Type) → λ(xs : List (Optional a)) → List/fold (Optional a) xs (Optional a) ( λ(l : Optional a) → λ(r : Optional a) → Optional/fold a l (Optional a) (λ(x : a) → [ x ] : Optional a) r ) ([] : Optional a) in head